electron-vue开发环境内存泄漏问题汇总
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 vue教程问题描述
在开发环境中,修改主进程保存后,每次保存会多出⼀到两个electron进程,根据友反馈2.0.8也是存在这个问题的,只是出现的频率较低
排查过程以及解决思路
1、⾸先先看了fig.js,然⽽并没有发现有什么异样的地⽅,配置了只启动⼀个应⽤程序,每次退出前也使⽤it()强制退出,然⽽并没有任何好转,遂新建⼀个项⽬,⽤来测试
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 /`, 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的版本更新记录中并没有发现那条更新记录会导致这个问题,时间有限,也没有去看到底在哪个版本后造成这个问题,技艺拙劣,始终没有到出现的原因
以上就是本⽂的全部内容,希望对⼤家的学习有所帮助,也希望⼤家多多⽀持。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。