项目场景:
最近项目上用户提了一个故障单,说是表格的某个功能不生效,经过阅读源码发现是依赖的组件不支持该功能,遂产生了给第三方组件打补丁的想法。打补丁用的是 patch-package ,打完补丁,本地测试通过后,欢天喜地的部署到环境,准备下班时,发现没有生效。。。。。。。。
前端的用框架是react、打包工具webpack、脚手架:ucf-web
问题描述
当我用patch-package 打完补丁后,尝试在 CI (Gitlab) 上构建 Docker 期间运行补丁包时,它会失败并出现以下错误导致补丁不生效,运行报错 :can not run in wd XXX patch-package (wd 表示你服务的所在路径),但这并不会导致项目起不来。
原因分析:
npm 出于安全考虑不支持以 root 用户运行,即使你用 root 用户身份运行了,npm 会自动转成一个叫 nobody 的用户来运行,而这个用户几乎没有任何权限。这样的话如果脚本里有一些需要权限的操作,比如写文件(执行install 的时候 patch-package 会往第三方库写代码)就会崩掉
解决方案:
将全局的.npmrc 复制一份到你的工程内,和package.json 同级,然后再运行即可解决,内容如下:
registry=你的镜像地址
unsafe-perm = true