node版本升级后,项目跑不起来

26 阅读2分钟

升级node版本,导致项目跑不起来

版本号

原版本新版本
node@16.20.2node@22.17.0
pnpm@8.15.9pnpm@10.12.3

新版本跑项目历程

pnpm i

等待下载完依赖后,发现有这一段warning

image.png

忽略这一warning直接跑项目

pnpm run start:stage

报错1:-4058,找不到esbuild

image.png

这时候去查,得知都使用这个命令node ./node_modules/esbuild/install.js手动安装一下esbuild就行了,于是照猫画虎

image.png

还是报错!!!!

果然不止我一个人这样照猫画虎,有人指出需要注意path

image.png

报错1解决方案

正确的命名应该是:

node ./node_modules/.pnpm/esbuild@0.8.57/node_modules/esbuild/install.js

image.png

执行该命令没有报错,应该也是安装成功了。

以为万无一失了,跑项目:

pnpm run start:stage

我没事,我很好。。。

报错2:Error: error:0308010C:digital envelope routines::unsupported

image.png

又去查文章,找到一篇疑似翻译的文章

抄笔记:

这个报错大致原因是:由于Node.js和OpenSSL之间的兼容性问题,在Node.js 17版本以及更高版本中,OpenSSL 3.0中默认禁用了某些加密功能。

需要执行set NODE_OPTIONS=--openssl-legacy-provider命令

于是分开执行命令

image.png

发现还是不行,没事哒没事哒,没有什么困难是打败不了我的

尝试一起执行set NODE_OPTIONS=--openssl-legacy-provider && pnpm run start:stage

image.png

嗯,还是不行

有些人可能到这一步不会出现问题,我是因为在bash命令行中执行的,在cmd或者PowerShell中不一定行不通。

报错2解决方案1

我还得继续,于是把set NODE_OPTIONS=--openssl-legacy-provider加到package.json中

"start:stage": "set NODE_OPTIONS=--openssl-legacy-provider && npx ……",

再执行

pnpm run start:stage

发现成功跑起来了

小小脑袋大大疑问

疑问:为什么set NODE_OPTIONS=--openssl-legacy-provider && pnpm run start:stage这样不行,但是把set写进package.json可以?

image.png

image.png

在 package.json 中,整个命令链是在 同一个 shell 进程 中顺序执行的

报错2解决方案2

但是我不想改package.json文件,AI给出方案,我挑了一个最简单的:

npx cross-env NODE_OPTIONS=--openssl-legacy-provider pnpm run start:stage

总结

1.执行命令解决esbuild问题(注意路径)

node ./node_modules/.pnpm/esbuild@0.8.57/node_modules/esbuild/install.js

解决esbuild还有一个方法,我目前没去尝试,可以参考文章去试试

image.png

2.执行命令解决OpenSLL3.0加密兼容性问题并运行项目

set NODE_OPTIONS=--openssl-legacy-provider && pnpm run start:stage

或者

npx cross-env NODE_OPTIONS=--openssl-legacy-provider pnpm run start:stage