npm私有源构建项目下载依赖报错

Jenkins构建项目报错,依赖找不到

js 复制代码
Error: Couldn't find any versions for "@babel/helper-module-imports" that matches "^7.22.15"
    at MessageError.ExtendableBuiltin (/data1/jenkins/tools/jenkins.plugins.nodejs.tools.NodeJSInstallation/node16/lib/node_modules/yarn/lib/cli.js:721:66)
    at new MessageError (/data1/jenkins/tools/jenkins.plugins.nodejs.tools.NodeJSInstallation/node16/lib/node_modules/yarn/lib/cli.js:750:123)
    at Function.<anonymous> (/data1/jenkins/tools/jenkins.plugins.nodejs.tools.NodeJSInstallation/node16/lib/node_modules/yarn/lib/cli.js:50351:13)
    at Generator.next (<anonymous>)
    at step (/data1/jenkins/tools/jenkins.plugins.nodejs.tools.NodeJSInstallation/node16/lib/node_modules/yarn/lib/cli.js:310:30)
    at /data1/jenkins/tools/jenkins.plugins.nodejs.tools.NodeJSInstallation/node16/lib/node_modules/yarn/lib/cli.js:321:13
    at runMicrotasks (<anonymous>)
    at processTicksAndRejections (node:internal/process/task_queues:96:5)
Build step 'Execute shell' marked build as failure
Deleting 1 temporary files
SSH: Current build result is [FAILURE], not going to run.
Finished: FAILURE

前置小知识

Node.js中package.json中^和~的区别

  1. ~会匹配最近的小版本依赖包,比如~1.2.3会匹配所有1.2.x版本,但是不包括1.3.0
  2. ^会匹配最新的大版本依赖包,比如 ^1.2.3会匹配所有1.x.x的包,包括1.3.0,但是不包括2.0.0

分析问题

  1. 由于项目依赖一般都以~或者^开头,npm源某些依赖如果升级,那我们项目在构建的时候,就会根据前置小知识中的规则去获取最新包
  2. 公司搭建了npm私有源,但是与npm官方源同步频率时间未设置,导致下载不到应有的最新的包

解决方案

方案一

  1. npm官方网站看当前下载失败的依赖上一次稳定的版本号

  2. 找到合适的版本号 在项目中package.json进行锁定版本号,举例说明如下:

    json 复制代码
    {
    	"resolutions": {
    	    "@babel/helper-module-imports": "7.22.5",
    	  }
    }

方案二

npm私有源是通过Nexus统一管理的

  1. 登录Nexus
  2. 我们配置npm私有源一般会建立三个仓库
项目 说明
hosted 本地仓库。提供本地私库功能
group 组仓库。组类型,可以组合多个仓库为一个地址提供服务
proxy 代理仓库。提供代理其他仓库的类型,可以设置官方源或者镜像源
  1. 进入proxy仓库配置页
  2. 修改配置

Maximum component age

这个的含义是获取到 remote 包后,多长时间开始缓存,改成 -1, 意思是获取到就缓存
Maximum metadata age

多长时间去 remote 仓库获取下源信息, 默认是 30天 ,

比方说 vue 这个包,今天上午10点发布了一个版本 2.7.15,你在11点执行 npm install vue@2.7.15,是会报 404 的,因为私服是30天获取一次 remote 仓库的信息,所以最好设置 30分钟以内,这样就可以快速获取到更新了

相关推荐
@小红花21 分钟前
从0到1学习Vue框架Day03
前端·javascript·vue.js·学习·ecmascript
前端与小赵24 分钟前
vue3中 ref() 和 reactive() 的区别
前端·javascript·vue.js
魔云连洲38 分钟前
Vue的响应式底层原理:Proxy vs defineProperty
前端·javascript·vue.js
专注VB编程开发20年42 分钟前
CSS定义网格的列模板grid-template-columns什么意思,为什么要用这么复杂的单词
前端·css
IT_陈寒1 小时前
Redis性能提升50%的7个关键优化策略,90%开发者都不知道第5点!
前端·人工智能·后端
Hilaku1 小时前
深入URL和URLSearchParams:别再用正则表达式去折磨URL了
前端·javascript·代码规范
pubuzhixing1 小时前
Canvas 的性能卓越,用它解决一个棘手问题
前端
weixin_456904271 小时前
Vue.jsmain.js/request.js/user.js/store/index.js Vuex状态管理项目核心模块深度解析
前端·javascript·vue.js
伍哥的传说1 小时前
Vue 3.6 Alien Signals:让响应式性能飞跃式提升
前端·javascript·vue.js·vue性能优化·alien-signals·细粒度更新·vue 3.6新特性
永日456701 小时前
学习日记-HTML-day51-9.9
前端·学习·html