如何搭建本地的 NPM 私有仓库 Nexus

NPM 本地私有仓库,是在本地搭建NPM私有仓库,对公司级别的组件库进行管理。在日常开发中,经常会遇到抽象公共组件的场景,在项目内部进行公用。新的项目开始时,也会拷贝一份创建一个新的项目,这样做不易于管理,也没有进行有效的版本控制,组件升级之后,也很难对已有项目进行更新,最后个项目各自为政,各自维护,新开发功能不能共享。

公司的共用组件大多是公司内部资产,由于涉及到知识产权的问题,禁止发布到公网。所以,内部前端私有仓库非常有必要,开源的 NPM 私有仓库又很多选择,轻量级例如Verdaccio,我这里用的是 Nexus,Nexus 的优势是,它不仅支持 NPM 私有仓库,也支持 Maven 的私有仓库,这样前后端都可以用同一个系统去管理,减轻了运维的压力。

安装

使用 docker 进行安装,进入查看是否安装成功 http://localhost:8081/

docker run -d -p 8081:8081 --name nexus -v nexus-data:/nexus-data sonatype/nexus3

## 查找 admin 密码
docker exec -ti nexus cat /opt/sonatype/sonatype-work/nexus3/admin.password

创建项目

下面我们添加一个项目进行测试

  1. 创建测试项目
mkdir test-module
cd test-module
npm init -y 

2 添加文件 index.js

function greet(name) {
    return `Hello, ${name}!`;
}

module.exports = greet;
  1. 创建仓库
    输入名称,设置是否允许更新,这里设置的是允许重新发布。
    在这里插入图片描述
    设置 Security – Realms,激活 npm Bearer Token Realm
    在这里插入图片描述

  2. 提交新项目

设置 registry

npm config set registry http://nexus-server-url:8081/repository/localnpm/

登录并提交项目

npm login --registry=http://nexus-server-url:8081/repository/localnpm/
npm publish

检查项目是否上传成功

在这里插入图片描述

  1. 设置 repository group,由于本地仓库初始化时只有内部库,而开发项目时我们需要很多三方库,Nexus 支持缓存外部库。拉取时我们要指定 registry 为 repository group,这个group 包括两个本地仓库和代理仓库,本地库找不到,就去代理库找,添加代理仓库和仓库组。
    添加 npm proxy,设置taobao 镜像地址
    在这里插入图片描述
    添加仓库组:
    在这里插入图片描述
    设置registry 并测试
#设置registry,这样可以拉到本地库和远程三方库
npm config set registry http://nexus-server-url:8081/repository/npm-all/

#发布时要指定为本地仓
npm publish --registry http://nexus-server-url:8081/repository/localnpm/

错误排查

如果遇到以下问题
com.orientechnologies.orient.core.storage.impl.local.paginated.OLocalPaginatedStorage - Exception 5F000189 in storage plocal:/nexus-data/db/config: 2.2.36 (build d3beb772c02098ceaea89779a7afd4b7305d3788, branch 2.2.x)
com.orientechnologies.orient.core.exception.OStorageException: Cannot open local storage ‘/nexus-data/db/config’ with mode=rw

## 删除wal 文件,重启即可
rm -rf /nexus-data/db/config/*.wal

密码重置

## 登录容器
docker exec -it nexus /bin/bash

## 进如数据库目录
cd /nexus-data/db

## 进入数据库控制台
java -jar $NEXUS_HOME/lib/support/nexus-orient-console.jar

## 链接数据库
connect plocal:./security admin admin

## 查询 Admin
select * from user where id = "admin"

## 修改密码为admin123
update user SET password="$shiro1$SHA-512$1024$NE+wqQq/TmjZMvfI7ENh/g==$V4yPw8T64UQ6GfJfxYq2hLsVrBY8D1v+bktfOxGdt4b/9BthpWPNUy/CBk6V9iA0nHpzYzJFWO8v/tZFtES8CA==" UPSERT WHERE id="admin"

这时应该可以正常进入了,如果不行,重新启动 Nexus

在这里插入图片描述

是的,**Nexus** 可以用来搭建 **NPM 私有仓库**。Nexus 是一个强大的 **仓库管理器**,由 Sonatype 公司开发,全称是 **Nexus Repository Manager**,它支持多种包格式(如 Maven、NPM、Docker、YUM、PyPI 等),可以用来搭建私有仓库、代理远程仓库、缓存依赖等。 --- ## ✅ Nexus 的主要作用 ### 1. **私有仓库** - 企业内部可以搭建私有 NPM 仓库,存放私有模块,避免将敏感代码发布到公网。 ### 2. **代理仓库** - 可以代理官方 NPM 仓库(如 `https://registry.npmjs.org`),缓存常用包,提高访问速度,减少对外请求。 ### 3. **仓库组(仓库合并)** - 可以将多个仓库(如私有 + 代理)合并为一个统一的访问地址,方便客户端配置。 ### 4. **权限控制** - 支持用户和角色权限管理,控制谁可以上传(publish)和下载(install)包。 ### 5. **安全与审计** - 支持 HTTPS、用户认证、访问日志等,适合企业级使用。 --- ## ✅ 使用 Nexus 搭建 NPM 私有仓库的步骤 ### 1. 安装 Nexus Repository Manager #### 方式一:使用 Docker 安装(推荐) ```bash docker run -d -p 8081:8081 --name nexus nexus3 ``` > 首次启动需要等待几分钟初始化。 #### 方式二:下载安装包(Linux/Windows) 官网地址:[https://www.sonatype.com/download-oss-sonatype](https://www.sonatype.com/download-oss-sonatype) 解压后运行即可。 --- ### 2. 登录 Nexus Web 管理界面 访问:`http://localhost:8081` 默认账号密码: - 用户名:admin - 密码:admin123(首次登录后会提示修改) --- ### 3. 创建 NPM 类型的仓库 #### 3.1 创建 **NPM Hosted** 仓库私有仓库) - 登录 Nexus 管理界面 - 点击 **Repository > Repositories** - 点击 **Create repository** - 选择 `npm (hosted)` - 填写仓库名称,如:`npm-private` - 点击 **Create repository** #### 3.2 创建 **NPM Proxy** 仓库(代理官方仓库) - 选择 `npm (proxy)` - 填写名称,如:`npmjs-org` - Remote storage URL 填写:`https://registry.npmjs.org` - 点击 **Create repository** #### 3.3 创建 **NPM Group** 仓库(合并仓库) - 选择 `npm (group)` - 填写名称,如:`npm-all` - 在 `Group` 选项中,将 `npm-private` 和 `npmjs-org` 移动到右侧 - 点击 **Create repository** 这样,客户端只需要访问 `npm-all` 这个 group 仓库,就可以同时访问私有包和官方代理包。 --- ### 4. 配置 npm 客户端 #### 4.1 设置 npm registry ```bash npm config set registry http://localhost:8081/repository/npm-all/ ``` #### 4.2 登录 Nexus(用于发布包) ```bash npm adduser --registry http://localhost:8081/repository/npm-private/ ``` 输入 Nexus 用户名、密码、邮箱。 #### 4.3 发布包 ```bash npm publish --registry http://localhost:8081/repository/npm-private/ ``` #### 4.4 安装包(自动从 group 仓库查找) ```bash npm install your-package-name ``` --- ## ✅ 总结 | 功能 | 是否支持 | |------|----------| | 搭建 NPM 私有仓库 | ✅ | | 代理官方 NPM 仓库 | ✅ | | 支持 HTTPS | ✅(需配置 SSL) | | 支持权限控制 | ✅ | | 支持多仓库合并 | ✅(通过 group) | | 支持高并发访问 | ✅(适合企业级部署) | ---
评论 2
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值