最近开发一个vue项目时遇到电脑卡死问题,突然间系统就非常卡,然后卡着卡着就死机了,鼠标也动不了了,只能冷启动。而且因为是突然卡死,没来得及打开任务管理器。

最开始以为是硬盘的问题,但是在卡死几次后,就想到把任务管理器开着玩项目,看看到底是不是哪个程序把硬盘或者CPU占满了导致的卡死。经过一番排查,发现是node.js进程的内存一直在暴涨,内存直接100%,然后系统将所有休眠进程换到虚拟内存,但是还是不够,就一直换直到崩盘,硬盘也被占满100%。

这时候我才知道是运行项目开发环境导致的。然后想到前段时间更新了项目的依赖(更新前没发生过内存爆的问题),就逐一排查,发现是

 这三个依赖的问题。如果强制版本号为3.10.0,如上图中那样,就不会发生问题。如果改为"^3.10.0",就会发生问题。

记录下遇到的这个问题,分享给大家,也给自己加深一下印象。

SASS预处理器推荐:

因为众所周知的node-sass在windows系统上的一系列(cao)问(dan)题,我推荐大家使用dart-sass(包名为"sass"),完爆node-sass。(也可参考sass-loader官方github的readme)

附上我的项目的整个依赖:

{
"dependencies": {
        "@dclovec/ts-tools": "^1.0.3",
        "@types/echarts": "^4.1.10",
        "axios": "^0.19.0",
        "core-js": "^2.6.5",
        "echarts": "^4.2.1",
        "element-ui": "^2.11.1",
        "vue": "^2.6.10",
        "vue-amap": "^0.5.10",
        "vue-class-component": "^7.0.2",
        "vue-property-decorator": "^8.1.0",
        "vue-router": "^3.0.3",
        "vuex": "^3.0.1"
    },
    "devDependencies": {
        "@vue/cli-plugin-babel": "3.10.0",
        "@vue/cli-plugin-typescript": "3.10.0",
        "@vue/cli-service": "3.10.0",
        "compression-webpack-plugin": "^3.0.0",
        "sass": "^1.22.9",
        "sass-loader": "^7.1.0",
        "terser-webpack-plugin": "^2.1.2",
        "typescript": "^3.4.3",
        "vue-template-compiler": "^2.6.10"
    }
}
01-07 19:30