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

至此上传步骤完毕。

相关推荐
HaSaKing_7212 分钟前
Vue 父子页面使用指南
前端·javascript·vue.js
雾散声声慢15 分钟前
从一个双非本学渣到自学前端上岸,我都做了些什么
前端
艾恩小灰灰27 分钟前
为何Web前端开发仍坚守 HTML 和 CSS,而不全然拥抱纯 JavaScript?
开发语言·前端·javascript·css·html·纯js
吃葡萄不吐葡萄皮嘻嘻42 分钟前
vue实现左右拖动分屏
前端·vue.js
GIS-CL1 小时前
前端面试题2(vue3)
前端·vue.js
王天平·Jason Wong1 小时前
汉王、绘王签字版调用封装
开发语言·前端·javascript
**之火1 小时前
ArrayBuffer 对象常见的几个用途
前端·javascript
GIS-CL1 小时前
前端面试题6(怎样打包封装自己的插件)
前端
东方佑2 小时前
使用tkinter 制作工作流ui
前端·windows·笔记·python·ui·分类
xiongxinyu102 小时前
让一个元素水平垂直居中的方式
前端·javascript·css·面试