内网使用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. 脚本自动执行上传,直至结束。

至此上传步骤完毕。

相关推荐
镜宇秋霖丶6 小时前
2026.5.6@霖宇博客制作中遇见的问题
前端·javascript·vue.js
小李子呢02118 小时前
前端八股Vue---Vue-router路由管理器
前端·javascript·vue.js
洛_尘9 小时前
Python 5:使用库
java·前端·python
Bigger9 小时前
Bun 能上生产吗?我的实战结论
前端·node.js·bun
kyriewen11 小时前
你的前端滤镜慢得像PPT?用Rust+WebAssembly,一秒处理4K图
前端·rust·webassembly
kyriewen1111 小时前
你等的Babel编译,够喝三杯咖啡了——用Rust重写的SWC,只需眨个眼
开发语言·前端·javascript·后端·性能优化·rust·前端框架
IT_陈寒11 小时前
SpringBoot自动配置坑了我,原来要这样绕过去
前端·人工智能·后端
东方小月11 小时前
Claude Code 完整上手指南:MCP、Skills、第三方模型配置一次搞定
前端·人工智能·后端
XZ探长12 小时前
基于 Trae Solo 移动办公修复 Vue3 前端服务问题
前端
蝎子莱莱爱打怪12 小时前
Claude Code 省 Token 小妙招:RTK + Caveman 组合拳
前端·人工智能·后端