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的动态增删改查表格信息,可左键/右键提示(原创自Zjmainstay)
Jul 31 Javascript
JS防止用户多次提交的简单代码
Aug 01 Javascript
关于jquery中全局函数each使用介绍
Dec 10 Javascript
Javascript前端UI框架Kit使用指南之Kitjs简介
Nov 28 Javascript
javascript简单实现类似QQ头像弹出效果的方法
Aug 03 Javascript
深入浅析JavaScript面向对象和原型函数
Feb 06 Javascript
Vuejs第八篇之Vuejs组件的定义实例解析
Sep 05 Javascript
实现easyui的datagrid导出为excel的示例代码
Nov 10 Javascript
Vue.js项目实战之多语种网站的功能实现(租车)
Aug 07 Javascript
CountUp.js数字滚动插件使用方法详解
Oct 17 Javascript
vue中的双向数据绑定原理与常见操作技巧详解
Mar 16 Javascript
JS sort排序详细使用方法示例解析
Sep 27 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
PHP7 新特性详细介绍
2016/09/06 PHP
PHP后台实现微信小程序登录
2018/08/03 PHP
用YUI做了个标签浏览效果
2007/02/20 Javascript
用Javascript做flash做的事..才完成的一个类.Auntion Action var 0.1
2007/02/23 Javascript
用JAVASCRIPT如何给<textarea></textarea>赋值
2007/04/20 Javascript
document.getElementById为空或不是对象的解决方法
2010/01/24 Javascript
JS中获取数据库中的值的方法
2013/07/14 Javascript
快速查找数组中的某个元素并返回下标示例
2013/09/03 Javascript
JavaScript中发布/订阅模式的简单实例
2014/11/05 Javascript
js判断某个字符出现的次数的简单实例
2016/06/03 Javascript
AngularJS ngModel实现指令与输入直接的数据通信
2016/09/21 Javascript
Bootstrap Table使用心得总结
2016/11/29 Javascript
JS中页面与页面之间超链接跳转中文乱码问题的解决办法
2016/12/15 Javascript
angular 动态组件类型详解(四种组件类型)
2017/02/22 Javascript
jQuery中animate()的使用方法及解决$(”body“).animate({“scrollTop”:top})不被Firefox支持的问题
2017/04/04 jQuery
js插件实现图片滑动验证码
2020/09/29 Javascript
基于three.js编写的一个项目类示例代码
2018/01/05 Javascript
iSlider手机端图片滑动切换插件使用详解
2019/12/24 Javascript
原生js实现自定义难度的扫雷游戏
2021/01/22 Javascript
Python-Seaborn热图绘制的实现方法
2019/07/15 Python
使用pyqt 实现重复打开多个相同界面
2019/12/13 Python
python利用paramiko实现交换机巡检的示例
2020/09/22 Python
Jogun Shop中文官网:韩国知名时尚男装网站
2016/10/12 全球购物
波兰汽车配件网上商店:iParts.pl
2020/09/08 全球购物
说一下Linux下有关用户和组管理的命令
2014/08/18 面试题
高一英语教学反思
2014/01/22 职场文书
春季运动会广播稿大全
2014/02/19 职场文书
运输服务质量承诺书
2014/03/27 职场文书
《蜗牛的奖杯》教后反思
2014/04/24 职场文书
法学专业求职信
2014/07/15 职场文书
讲党性心得体会
2014/09/03 职场文书
大学生十八大感想
2015/08/11 职场文书
五年级语文教学反思
2016/03/03 职场文书
Python打包exe时各种异常处理方案总结
2021/05/18 Python
如何搭建 MySQL 高可用高性能集群
2021/06/21 MySQL
Java实现超大Excel文件解析(XSSF,SXSSF,easyExcel)
2022/07/15 Java/Android