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 相关文章推荐
Locate a File Using a File Open Dialog Box
Jun 18 Javascript
js parentElement和offsetParent之间的区别
Mar 23 Javascript
一个CSS+jQuery实现的放大缩小动画效果
Feb 19 Javascript
JavaScript数组深拷贝和浅拷贝的两种方法
Apr 16 Javascript
一分钟理解js闭包
May 04 Javascript
第一篇初识bootstrap
Jun 21 Javascript
简单实现bootstrap选项卡效果
Feb 08 Javascript
基于jQuery代码实现圆形菜单展开收缩效果
Feb 13 Javascript
JS实现百度搜索接口及链接功能实例代码
Feb 02 Javascript
基于vue.js中关于下拉框的值默认及绑定问题
Aug 22 Javascript
react项目实践之webpack-dev-serve
Sep 14 Javascript
Angular ui-roter 和AngularJS 通过 ocLazyLoad 实现动态(懒)加载模块和依赖
Nov 25 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
php 分页类 扩展代码
2009/06/11 PHP
PHP防CC攻击实现代码
2011/12/29 PHP
THINKPHP支持YAML配置文件的设置方法
2015/03/17 PHP
php使用curl并发减少后端访问时间的方法分析
2016/05/12 PHP
Yii2框架实现利用mpdf创建pdf文件功能示例
2019/02/08 PHP
javascript 限制输入脚本大全
2009/11/03 Javascript
javascript实现的DES加密示例
2013/10/30 Javascript
js判断滚动条是否已到页面最底部或顶部实例
2014/11/20 Javascript
jQuery对象的length属性用法实例
2014/12/27 Javascript
jQuery插件slicebox实现3D动画图片轮播切换特效
2015/04/12 Javascript
Node.js环境下JavaScript实现单链表与双链表结构
2016/06/12 Javascript
jQuery实现右下角可缩放大小的层完整实例
2016/06/20 Javascript
jQuery+ajax读取并解析XML文件的方法
2016/09/09 Javascript
nodejs根据ip数组在百度地图中进行定位
2017/03/06 NodeJs
vue.js提交按钮时进行简单的if判断表达式详解
2018/08/08 Javascript
浅析VUE防抖与节流
2020/11/24 Vue.js
Python实现list反转实例汇总
2014/11/11 Python
详解python脚本自动生成需要文件实例代码
2017/02/04 Python
python十进制和二进制的转换方法(含浮点数)
2018/07/07 Python
Python打开文件,将list、numpy数组内容写入txt文件中的方法
2018/10/26 Python
Python socket 套接字实现通信详解
2019/08/27 Python
基于Python的图像阈值化分割(迭代法)
2020/11/20 Python
Selenium 安装和简单使用的实现
2020/12/04 Python
不可轻视HTML5!App三年内将被html5顶替彻底消失
2015/11/18 HTML / CSS
您在慕尼黑的跑步商店:Lauf-bar
2019/10/11 全球购物
Harrods英国:世界领先的奢侈品百货商店
2020/09/23 全球购物
英国鲜花递送:Blossoming Gifts
2020/07/10 全球购物
超市营业员求职简历的自我评价
2013/10/17 职场文书
体育教育毕业生自荐信
2013/11/21 职场文书
同事吵架检讨书
2014/02/05 职场文书
小班重阳节活动方案
2014/02/08 职场文书
气象学专业个人求职信
2014/03/15 职场文书
副校长竞聘演讲稿
2014/09/01 职场文书
2014年采购部工作总结
2014/11/20 职场文书
2015年超市工作总结范文
2015/05/26 职场文书
Django 实现jwt认证的示例
2021/04/30 Python