verdaccio安装及发布包到npm私有仓库教程
前言
在公司里我们有很多需要公共组件或者是工具函数工具类,和一些封装的sdk
,这样的代码有的核心的不方便发布到外网中,所以这就是我们为什么需要搭建 npm 私有仓库。
verdaccio 是一个非常方便使用和管理的 npm 私有仓库搭建工具,搭建好后设置 npm 源为 verdaccio 服务就可以使用 npm 私有仓库了。
下载
直接 npm 下载到全局安装
npm install -g verdaccio
1
运行
verdaccio
看到这个界面就说明运行成功了
进入后如下图所示,我发布了一个包在 verdaccio 服务器里。
运行 verdaccio 可以看到当前你的 verdaccio 配置文件的位置
配置
storage: ./storage
# path to a directory with plugins to include
plugins: ./plugins
web:
title: Verdaccio
auth:
htpasswd:
file: ./htpasswd
uplinks:
npmjs:
url: https://registry.npmmirror.com/
packages:
"@*/*":
access: $all
publish: $authenticated
unpublish: $authenticated
proxy: npmjs
"**":
access: $all
publish: $authenticated
unpublish: $authenticated
proxy: npmjs
server:
keepAliveTimeout: 60
listen:
# - localhost:4873 # default value
# - http://localhost:4873 # same thing
0.0.0.0:4873 # listen on all addresses (INADDR_ANY)
middlewares:
audit:
enabled: true
# https://verdaccio.org/docs/logger
# log settings
logs: { type: stdout, format: pretty, level: http }
主要需要修改的地方
淘宝源
uplinks.npmjs 设置为淘宝源。
uplinks:
npmjs:
url: https://registry.npmmirror.com/
开发访问
listen: 0.0.0.0:4873 开发访问,不然内网访问不到你的 verdaccio 服务。
listen:
# - localhost:4873 # default value
# - http://localhost:4873 # same thing
0.0.0.0:4873 # listen on all addresses (INADDR_ANY)
修改好后保存重启 verdaccio
创建用户
npm adduser --registry http://localhost:4873/
接着,它会要求你填写用户名、密码和邮箱,用于登陆私有 npm 库:
删除用户
既然有注册用户,不可避免的需求是在一些场景下,我们需要删除某个用户来禁止其登陆私有 npm 库。
前面也提及了 Verdaccio 默认使用的是 htpasswd
来实现鉴权。相应地,注册的用户信息会存储在 ~/.config/verdaccio/htpasswd
文件中:
liuliu:kqK9KoK7nGEso:autocreated 2022-12-03T13:08:59.155Z
这里一条记录对应一个用户,也就是如果这条记录被删除了,那么该用户就不能登陆了,即删除了该用户。
添加、切换源
这里我们为了操作方面,通过 nrm
来切换源。没有安装 nrm
的同学,可以先安装一下:
npm i -g nrm
然后,使用 nrm
添加一个源:
nrm add private http://localhostm:4873/
这里的 private
代表你这个源的简称,你可以因自己的喜好来命名。
接着,我们可以运行 nrm ls
命令来查看目前存在的源:
使用 nrm use private
切换到我们的私有 npm 源上
切换好源后,我们之后的 npm i
就会先去私有库查找包,如果不存在则会去 https://registry.npmmirror.com/
(因为上面配置了 proxy
)查找包。
发布
因为 verdaccio 上面的配置发布包必须要登录。所以我们使用npm login
进行输入用户名,密码,邮箱后进行登录
然后就在某个需要发布包的根路径下运行
npm publish
注意 package.json 的 private 要设置为 false
{
"name": "xskit",
"version": "0.0.1",
"description": "",
"keywords": ["modern", "framework", "sdk"],
"author": "liuliu",
"license": "UNLICENSED",
"private": false,
"scripts": {
"publish-lib": "npm publish"
}
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南