react打包发到线上报错Minified React error #130

开发过程中遇到一个问题,记录一下

本地打包发布正常,发测试环境正常,可是通过Jenkins打包发布线上报错

报错信息

index-67fbbd81.js:39 Error: Minified React error #130; visit https://reactjs.org/docs/error-decoder.html?invariant=130\&args\[\]=undefined\&args\[\]= for the full message or use the non-minified dev environment for full errors and additional helpful warnings.

打开报错信息发现报错

由于这次更新内容比较多,开始怀疑是不是本地代码问题,

组件undefined一般是引入导出组件名问题。让cursor检查了一遍代码,发现代码没有问题。

又从git上重新拉取代码,下载依赖,运行,也是没问题。

本地生产环境没问题,线上报错,说明问题很可能出在环境差异上。

对比了一下Jenkins上的node版本,react版本等,发现版本号一致。

猜想可能是使用本地包的问题,在服务器上单独下载了依赖,导致线上本地依赖包不一致。

原本的Jenkins打包命令

复制代码
yarn install
yarn build

yarn install 不是严格模式,可能会根据 semver 自动升级依赖,导致和本地 node_modules 不一致。

如果 Jenkins 的 node_modules 目录有残留,可能会混入旧依赖,导致打包产物和本地不一样。

更改后的Jenkins命令

复制代码
rm -rf node_modules
yarn cache clean
yarn install --frozen-lockfile
yarn build

rm -rf node_modules:彻底清理依赖,避免残留

yarn cache clean:清理 yarn 缓存

yarn install --frozen-lockfile:严格按照 yarn.lock 安装依赖,保证和本地一模一样

yarn build:正常打包

这样可以100% 保证 Jenkins 构建出来的依赖和本地完全一致,不会因为依赖包差异导致线上 undefined 或 React #130 错误。

很多线上"本地没问题,线上报错"的根因,都是因为 CI/CD 没有严格依赖锁定

接下来重新用用Jenkins打包----正常-----线上-----正常!

完美解决!

相关推荐
DoraBigHead3 分钟前
小Dora 的 JavaScript 修炼日记 · Day 1:变量三兄弟与作用域迷宫
前端·javascript·面试
年纪轻轻就扛不住8 分钟前
Express 入门指南(超详细教程)
前端·前端框架·node.js·express·js
Trust yourself24317 分钟前
easyui碰到想要去除顶部栏按钮边框
前端·javascript·easyui
一洽客服系统28 分钟前
网页嵌入与接入功能说明
开发语言·前端·javascript
DoraBigHead42 分钟前
this 的前世今生:谁在叫我,我听谁的
前端·javascript·面试
蓝婷儿1 小时前
每天一个前端小知识 Day 28 - Web Workers / 多线程模型在前端中的应用实践
前端
琹箐1 小时前
Ant ASpin自定义 indicator 报错
前端·javascript·typescript
小小小小小惠1 小时前
Responsetype blob会把接口接收的二进制文件转换成blob格式
前端·javascript
爱电摇的小码农1 小时前
【深度探究系列(5)】:前端开发打怪升级指南:从踩坑到封神的解决方案手册
前端·javascript·css·vue.js·node.js·html5·xss
kymjs张涛2 小时前
零一开源|前沿技术周报 #7
android·前端·ios