内网使用nexus3搭建npm私库方法

内网使用nexus3搭建npm私库大致分为下载tgz和批量上传两个步骤。如下。

第一步,批量下载tgz依赖。

  1. 新建一个文件夹,比如download;

  2. 拷贝出项目中package.json或者package-lock.json。放进download文件夹中;

  3. 确保电脑本地已经安装好nodejs,确保nodejs相关环境变量配置成功;

  4. 拷贝download.sh 脚本到downlaod 文件夹中,和package.json同一目录;脚本如下所示:

    bash 复制代码
    echo ">>> 正在下载未压缩依赖... <<<"
    npm i
    echo ">>> 下载完成 <<<"
    echo ">>> 正在下载tgz格式依赖... <<<"
    npm install node-tgz-downloader -g
    download-tgz package-lock package-lock.json
    echo ">>> 下载完成 <<<"
    echo ">>> 正在移动tgz文件... \n"
    mkdir tgz
    find ./tarballs -maxdepth 4 -name "*.tgz" | xargs mv -t ./tgz
    echo ">>> 移动完成 \n"

    文件夹结构如图所示:

  5. 在downlaod文件夹下执行download.sh脚本。Windows环境需要下载git执行shell脚本,linux环境可直接执行脚本;

  6. 在脚本执行后,会下载以来,然后对package-lock.json的rsolve字段进行解析下载tgz包;

  7. 最后,脚本依次执行下载,会相继出现downloading 、complete等字样;

  8. 下载完成后,会在download文件夹下自动创建tgz文件夹,该文件夹下即是所需tgz包;如下图所示:

第二步,批量上传nexus。

  1. 新建upload文件夹;
  2. 登录nexus,找到需要上传的npm-hosted(本地)地址。如下图所示:
  1. 找到批量上传tgz包的接口地址,如下图所示:
  1. 拷贝upload.sh 脚本,放进upload文件夹中;脚本如下所示:55
bash 复制代码
#!/bin/bash
targetDir=./tgz
publishRestful=你的nexusIP/service/rest/v1/components?repository=你的npm-hosted路径
echo ">>> 文件所在目录:$targetDir <<<"
dir=$(ls -l $targetDir | awk '/.tgz$/ {print $NF}')
cd $targetDir
 
for file in $dir
do
  echo ">>> $targetDir/$file 上传开始 \n"
  ret=`curl -u 用户名:密码 -X POST "$publishRestful" -H "Accept: application/json" -H "Content-Type: multipart/form-data" -F "npm.asset=@$file;type=application/x-compressed"`
  echo $ret
  echo ">>> $targetDir/$file 上传完成 \n"
done
  1. 将下载好的tgz文件夹,放进upload文件夹,如下图所示:
  1. 同样在此文件夹下执行upload.sh 脚本;如下图所示:
  1. 脚本自动执行上传,直至结束。

至此上传步骤完毕。

相关推荐
小兵张健1 小时前
价值1000的 AI 工作流:Codex 通用前端协作模式
前端·aigc·ai编程
sunny_2 小时前
面试踩大坑!同一段 Node.js 代码,CJS 和 ESM 的执行顺序居然是反的?!99% 的人都答错了
前端·面试·node.js
拉不动的猪2 小时前
移动端调试工具VConsole初始化时的加载阻塞问题
前端·javascript·微信小程序
ayqy贾杰3 小时前
Agent First Engineering
前端·vue.js·面试
IT_陈寒4 小时前
SpringBoot实战:5个让你的API性能翻倍的隐藏技巧
前端·人工智能·后端
iceiceiceice4 小时前
iOS PDF阅读器段评实现:如何从 PDFSelection 精准还原一个自然段
前端·人工智能·ios
大金乄4 小时前
封装一个vue2的elementUI 表格组件(包含表格编辑以及多级表头)
前端·javascript
葡萄城技术团队5 小时前
【性能优化篇】面对万行数据也不卡顿?揭秘协同服务器的“片段机制 (Fragments)”
前端
程序员阿峰5 小时前
2026前端必备:TensorFlow.js,浏览器里的AI引擎,不写Python也能玩转智能
前端
Jans5 小时前
Shipfe — Rust 写的前端静态部署工具:一条命令上线 + 零停机 + 可回滚 + 自动清理
前端