背景
环境:linux,nodejs 6.4.1,npm 10.15.3,cross-env 5.2.0。
在服务器上运行多环境脚本:npm run test_pm2。(实际执行:cross-env NODE_ENV=development pm2 start bin/www --name 'medicare-web-test')
然后报错:Error:Cannot find module '..'。
当时我就在想依赖我都装了呀,而且不放心 也卸载重新安装了,还是不行。而且单纯运行pm2 start bin/www --name 'medicare-web-test' 是可以运行,所以说明是多环境命令有问题。
- 多环境执行脚本
"scripts": {
"start": "cross-env NODE_ENV=production node bin/www",
"test": "cross-env NODE_ENV=development node bin/www",
"dev": "cross-env NODE_ENV=local node bin/www",
"start_pm2": "cross-env NODE_ENV=production pm2 start bin/www --name 'medicare-web'",
"test_pm2": "cross-env NODE_ENV=development pm2 start bin/www --name 'medicare-web-test'"
}
在测试环境,执行:npm run test_pm2,然后就报以下这个错了。
看到这个错,它是说找不到依赖。依赖是有安装了,就是很奇怪为啥没发现。于是网上查了一下,然后试操作一下。
问题试排查:
- 1、找不到依赖,那就重新安装依赖:npm install。安装后,运行还是报一样的错
- 2、可能依赖冲突了,于是卸载了依赖包之后,重新安装。运行还是报一样的错
-
3、多环境依赖包的版本太低了?那卸载cross-env依赖重新安装最新版本,额... 这卸载不掉?
然后我再仔细看一下日志,报错是在node_modules下的.bin文件里面cross-env文件 第四行代码找不到依赖。
node_modues/.bin文件夹下,对于一个npm包,有两个可执行文件,没有后缀名的是是对应unix系的shell脚本,.cmd文件对应的是windows bat脚本,内容都是用node执行一个js文件。通过它去执行cross-env报错说找不到命令,于是我就把脚本改了一下,直接指定文件路径去执行。
- 修改后的多环境执行脚本
"scripts": {
"start": "cross-env NODE_ENV=production node bin/www",
"test": "cross-env NODE_ENV=development node bin/www",
"dev": "cross-env NODE_ENV=local node bin/www",
"start_pm2": "node node_modules/cross-env/dist/bin/cross-env.js NODE_ENV=production pm2 start bin/www --name 'medicare-web'",
"test_pm2": "node node_modules/cross-env/dist/bin/cross-env.js NODE_ENV=development pm2 start bin/www --name 'medicare-web-test'"
}
然后再执行npm run test_pm2,就能正常运行了。
最开始的脚本,有的服务器的就可以,有的就不行,而且我本地是正常的。很奇怪,不知道为啥会导致这样子。