electron-vue开发环境内存泄漏问题汇总


Posted in Javascript onOctober 10, 2019

package.json

"dependencies": {
  "vue": "^2.5.16"
 },
 "devDependencies": {
  "ajv": "^6.5.0",
  "babel-core": "^6.26.3",
  "babel-loader": "^7.1.4",
  "babel-plugin-transform-runtime": "^6.23.0",
  "babel-preset-env": "^1.7.0",
  "babel-preset-stage-0": "^6.24.1",
  "babel-register": "^6.26.0",
  "babili-webpack-plugin": "^0.1.2",
  "cfonts": "^2.1.2",
  "chalk": "^2.4.1",
  "copy-webpack-plugin": "^4.5.1",
  "cross-env": "^5.1.6",
  "css-loader": "^0.28.11",
  "del": "^3.0.0",
  "devtron": "^1.4.0",
  "electron": "3.0.0",
  "electron-builder": "^20.19.2",
  "electron-debug": "^1.5.0",
  "electron-devtools-installer": "^2.2.4",
  "file-loader": "^1.1.11",
  "html-webpack-plugin": "^3.2.0",
  "mini-css-extract-plugin": "0.4.0",
  "multispinner": "^0.2.1",
  "node-loader": "^0.6.0",
  "style-loader": "^0.21.0",
  "url-loader": "^1.0.1",
  "vue-html-loader": "^1.2.4",
  "vue-loader": "^15.2.4",
  "vue-style-loader": "^4.1.0",
  "vue-template-compiler": "^2.5.16",
  "webpack": "^4.15.1",
  "webpack-cli": "^3.0.8",
  "webpack-dev-server": "^3.1.4",
  "webpack-hot-middleware": "^2.22.2",
  "webpack-merge": "^4.1.3"
 }

electron测试版本3.0.0, 4.0.0, 4.2.6

问题描述

在开发环境中,修改主进程保存后,每次保存会多出一到两个electron进程,根据群友反馈2.0.8也是存在这个问题的,只是出现的频率较低

排查过程以及解决思路

1、 首先先看了webpack.main.config.js,然而并没有发现有什么异样的地方,配置了只启动一个应用程序,每次退出前也使用app.exit()强制退出,然而并没有任何好转,遂新建一个项目,用来测试
2、 在创建完毕后(electron v4.0.0),发现每次保存并不是都会出现一个新的进程,经过多次测试后,发现问题出在保存完后,主进程未生成成功,然后再次保存,于是进程创建了多次,但是只杀死了最开始的进程,造成内存泄漏。
3、 在dev-runner.js中找到了关于杀死进程的方法

if (electronProcess && electronProcess.kill) {
    manualRestart = true
    process.kill(electronProcess.pid)
    electronProcess = null
    startElectron()

    setTimeout(() => {
     manualRestart = false
    }, 5000)
   }

4、 好吧他是直接通过调用process.kill来杀死进程,然后造成这个问题,遂进行了修改,修改后代码如下,注意引入exec,然后将延时器删除,感觉整个程序的运行速度都快了不少,哈哈哈

if (electronProcess && electronProcess.kill) {
    manualRestart = true
    const pid = electronProcess.pid
    exec(`TASKKILL /F /IM electron.exe`, function (err, data) {
     if (err) console.log(err)
     else console.log('kill pid: ' + pid + ' success!')
     electronProcess = null
     startElectron()
     manualRestart = false
    })
   }

总结

在解决了问题后,去看版本更新记录,在2.0.8-3.0.0的版本更新记录中并没有发现那条更新记录会导致这个问题,时间有限,也没有去看到底在哪个版本后造成这个问题,技艺拙劣,始终没有找到出现的原因

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jquery自动切换tabs选项卡的具体实现
Dec 24 Javascript
基于jQuery实现带动画效果超炫酷的弹出对话框(附源码下载)
Feb 22 Javascript
jQuery实现滚动鼠标放大缩小图片的方法(附demo源码下载)
Mar 05 Javascript
Node.js中npm常用命令大全
Jun 09 Javascript
JS随机打乱数组的方法小结
Jun 22 Javascript
基于angularJS的表单验证指令介绍
Oct 21 Javascript
vue-resourse将json数据输出实例
Mar 08 Javascript
基于AngularJS的简单使用详解
Sep 10 Javascript
浅谈angular.copy() 深拷贝
Sep 14 Javascript
Vue 打包体积优化方案小结
May 20 Javascript
基于vue中的scoped坑点解说
Sep 04 Javascript
Node快速切换版本、版本回退(降级)、版本更新(升级)
Jan 07 Javascript
Vue使用NProgress的操作过程解析
Oct 10 #Javascript
使用 Element UI Table 的 slot-scope方法
Oct 10 #Javascript
使用vscode快速建立vue模板过程详解
Oct 10 #Javascript
浅谈vue3中effect与computed的亲密关系
Oct 10 #Javascript
JavaScript如何把两个数组对象合并过程解析
Oct 10 #Javascript
Node使用Selenium进行前端自动化操作的代码实现
Oct 10 #Javascript
Vue 开发必须知道的36个技巧(小结)
Oct 09 #Javascript
You might like
MySQL连接数超过限制的解决方法
2011/07/17 PHP
php中10个不同等级压缩优化图片操作示例
2016/11/14 PHP
PHP静态方法和静态属性及常量属性的区别与介绍
2019/03/22 PHP
获取当前网页document.url location.href区别总结
2008/05/10 Javascript
写入cookie的JavaScript代码库 cookieLibrary.js
2009/10/24 Javascript
写JQuery插件的基本知识
2013/11/25 Javascript
浅析jQuery(function(){})与(function(){})(jQuery)之间的区别
2014/01/09 Javascript
jquery实现ajax提交form表单的方法总结
2014/03/03 Javascript
js解决movebox移动问题
2016/03/29 Javascript
用JavaScript获取页面文档内容的实现代码
2016/06/10 Javascript
Vue.js每天必学之过渡与动画
2016/09/06 Javascript
Ajax使用原生态JS验证用户名是否存在
2020/05/26 Javascript
微信小程序 实现tabs选项卡效果实例代码
2016/10/31 Javascript
Vue 中批量下载文件并打包的示例代码
2017/11/20 Javascript
JS实现简单的浮动碰撞效果示例
2017/12/28 Javascript
thinkjs微信中控之微信鉴权登陆的实现代码
2019/08/08 Javascript
微信小程序实现购物车代码实例详解
2019/08/29 Javascript
javascript实现留言板功能
2020/02/08 Javascript
JavaScript canvas动画实现时钟效果
2020/02/10 Javascript
基于Python的身份证号码自动生成程序
2014/08/15 Python
实例解析Python中的__new__特殊方法
2016/06/02 Python
对numpy的array和python中自带的list之间相互转化详解
2018/04/13 Python
Python实现的朴素贝叶斯算法经典示例【测试可用】
2018/06/13 Python
python3爬虫之设计签名小程序
2018/06/19 Python
对dataframe数据之间求补集的实例详解
2019/01/30 Python
Python2.7版os.path.isdir中文路径返回false的解决方法
2019/06/21 Python
基于Python实现ComicReaper漫画自动爬取脚本过程解析
2019/11/11 Python
Python run()函数和start()函数的比较和差别介绍
2020/05/03 Python
简单的Python人脸识别系统
2020/07/14 Python
Python使用lambda抛出异常实现方法解析
2020/08/20 Python
高中生国庆节演讲稿范文2014
2014/09/21 职场文书
岗位竞聘报告范文
2014/11/06 职场文书
美术教师求职信范文
2015/03/20 职场文书
2015年银行信贷员工作总结
2015/05/19 职场文书
军训阅兵新闻稿
2015/07/17 职场文书
致三级跳运动员加油稿
2015/07/21 职场文书