码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 前端基于Verdaccio搭建私有npm仓库,上传npm插件包,及下载使用自己的npm插件包


    文章目录

        • 一、原理
        • 二、常用的仓库地址
        • 三、优势
        • 四、准备环境
        • 六、使用verdaccio搭建私有npm服务
          • 1、安装
          • 2、运行
          • 3、配置config.yaml,使局域网下能共享访问,否则只能本机访问。
          • 4、重新运行
        • 七、npm常见操作
          • 查看当前用户信息
          • 查看源地址
          • 切换源地址
          • 删除源地址
          • 创建用户
          • 登录
          • 发布
        • 八、项目使用
          • 1、你可以通过以下命令来设置 registry。
          • 2、你可以在需要时带上 --registry 参数。
          • 3、在你的 .npmrc 中设置一个 registry 属性。
          • 4、在你的 package.json 中设置 publishConfig
        • 九、插件打包
          • 1、 package.json 中新增一条编译为库的命令
          • 2、 执行打包命令
          • 3、打包成功
        • 十、插件上传
          • 1、设置镜像源
          • 2、 配置 package.json
          • 3、登录到 npm
          • 4、公布到 npm
        • 十一、上传包到私库报错
          • 1、错误信息
          • 2、解决方案
          • 3、重启verdaccio后再publish

    搭建团队的私有仓库,保证团队组件的安全维护和私密性,是进阶前端开发主管路上,必不可少的一项技能。

    一、原理

    我们平时使用npm publish进行发布时,上传的仓库默认地址是npm,通过Verdaccio工具在本地新建一个仓库地址,再把本地的默认上传仓库地址切换到本地仓库地址即可。当npm install时没有找到本地的仓库,则Verdaccio默认配置中会从npm中央仓库下载。

    二、常用的仓库地址

    • npm : https://registry.npmjs.org/
    • cnpm : http://r.cnpmjs.org/
    • taobao: https://registry.npm.taobao.org/

    三、优势

    • 私密性高,仅团队共享。
    • 安全性高,能够有效的防治恶意代码攻击。
    • 使用局域网,传输速度快。

    四、准备环境

    • node(v12或更高)
    • npm(pnpm或yarn)
    • verdaccio(v5)
    • nrm(快速切换仓库源)
    • pm2(守护进程)

    六、使用verdaccio搭建私有npm服务

    1、安装
    npm install -g verdaccio
    
    • 1
    2、运行

    启动时间会很久,断开cmd会关掉服务,可以使用pm2守护进程即可。
    // 访问http://localhost:4837

    verdaccio
    
    • 1
    3、配置config.yaml,使局域网下能共享访问,否则只能本机访问。

    C:\Users\admin\AppData\Roaming\verdaccio\config.yaml
    // 最后面添加以下配置
    listen: 0.0.0.0:4873
    重启,必须重启电脑配置才能生效。

    4、重新运行

    // 访问http://ip:port/
    // 不要访问本地localhost下的

    verdaccio
    
    • 1

    七、npm常见操作

    查看当前用户信息
    npm who am I
    
    • 1
    查看源地址
    npm config list
    
    • 1
    切换源地址
    npm set  
    
    • 1
    删除源地址
    npm config rm 
    
    • 1
    创建用户
    npm adduser
    
    • 1
    登录
    npm login
    
    • 1
    发布
    npm publish
    
    • 1

    八、项目使用

    1、你可以通过以下命令来设置 registry。
    npm set registry http://localhost:4873/
    
    • 1
    2、你可以在需要时带上 --registry 参数。
    npm install --registry http://localhost:4873
    
    • 1
    3、在你的 .npmrc 中设置一个 registry 属性。
    .npmrc
    registry=http://localhost:4873
    
    • 1
    • 2
    4、在你的 package.json 中设置 publishConfig
    {
      "publishConfig": {
        "registry": "http://localhost:4873"
      }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5

    九、插件打包

    1、 package.json 中新增一条编译为库的命令
    "lib": "vue-cli-service build --target lib --name vue-verdaccio-zourongle --dest lib src/plugins/index.js"
    
    • 1

    –target : 构建指标,默认为利用模式。这里批改为 lib 启用库模式。
    –dest : 输入目录,默认 dist 。这里咱们改成 lib
    [entry] : 最初一个参数为入口文件,默认为 src/App.vue 。这里咱们指定编译 src/plugins/index.js 组件库目录。
    –name : 输出名称,这里咱们改成 自己的名称

    2、 执行打包命令
    npm run lib
    
    • 1
    3、打包成功

    生成包文件夹lib

    在这里插入图片描述

    在这里插入图片描述

    十、插件上传

    1、设置镜像源
    npm set registry http://localhost:4873/
    
    • 1
    2、 配置 package.json

    在插件包文件夹里面创建package.json

    {
        "name": "vue-verdaccio-zourongle",
        "version": "0.1.0",
        "description": "今天我发布一个插件",
        "main": "vue-verdaccio-zourongle.umd.min.js",
        "license": "MIT",
        "private": false
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    private : 必须设置为 fasle
    main : 我的项目入口,默认为同级目录的 index.js
    name : npm包名,就是咱们 import xxx from packagename 中的包名

    3、登录到 npm

    在插件包的文件夹里面执行

    npm login
    
    • 1
    4、公布到 npm
    npm publish
    
    • 1

    在这里插入图片描述

    在这里插入图片描述

    十一、上传包到私库报错

    1、错误信息

    503 Service Unavailable - PUT http://localhost:4873/xxxx - one of the uplinks is down, refuse to publish

    2、解决方案

    在verdaccio启动的配置文件config.yaml加上配置:

    publish:
      allow_offline: true
    
    • 1
    • 2
    3、重启verdaccio后再publish

    上传成功了。

  • 相关阅读:
    css主题切换
    物联网网关:连接设备与云端的桥梁
    机器学习算法(二十四):启发式算法优化机器学习算法
    推荐一个适合App、小程序等所有前端应用的图表库
    苍穹外卖 day12 Echats 营业台数据可视化整合
    C++中的多态
    重温Python基础,都是最基础的知识点
    补码:将减法运算转化为另一种形式的加法运算
    Minimum Varied Number Codeforces 1714C
    对比分析法、多维度拆解、辛普森悖论
  • 原文地址:https://blog.csdn.net/shanghai597/article/details/130861684
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号