Nexus仓库

简介: Nexus是一款开源仓库管理工具,支持Maven、NPM、Docker等格式。本文介绍其在Linux与Docker环境下的安装配置,包括JDK部署、OSS版下载、仓库创建、用户权限管理及密码重置方法,并涵盖私服搭建、持久化存储、资源上传与匿名访问设置,助力企业高效构建私有仓库体系。

Nexus仓库
Linux安装
安装jdk8,并配置环境变量
安装后的路径为:/usr/java/jdk1.8.0_181-amd64
到 sonatype 官网下载Nexus Repository Manager OSS
Nexus分为开源免费的OSS版和Pro版。
此处可以选择下载开源免费的OSS版。
pro版多了资源健康检查等功能。
将下载的压缩包放到服务器解压
解压后会有两个文件夹:
sonatype将Nexus安装包托管到了 Fastly CDN,国内访问Fastly CDN非常卡顿。可能会下载失败,需要多试几次。
nexus-3.30.0-01
nexus软件
sonatype-work
nexus工作目录。
该文件夹和nexus软件在相同路径中,最好不要改动。
修改nexus的配置
编辑 nexus-3.30.0-01/etc/nexus-default.properties 文件
启动nexus
windows版:
使用管理员身份将nexus安装成一个windows服务
在windows的“服务”中可以找到nexus服务,启动该服务

Linux版:
执行 nexus指令查看其参数
不带参数直接运行nexus指令,会返回nexus可选参数列表
启动nexus(nexus不建议使用root用户执行)

浏览器放问nexus
http://192.168.29.141:8081/
启动较缓慢,需要等待一段时间才能连上
相关操作
登录
进入nexus的web管理页面后,所有的配置都是只读的,需要登录才能操作
点击Sign In 进行登录
默认用户名:admin
默认密码:在 /home/nexus/sonatype-work/nexus3/admin.password 文件中
旧版本Nexus没有该密码文件,默认密码为:admin123
首次登录需要修改密码,例如将密码改为:admin
修改密码后,admin.password文件会被自动删除
配置是否允许匿名访问
启用匿名访问意味着,用户可以在没有凭据的情况下从仓库搜索、浏览和下载组件。
使用管理员登录后,便可以在nexus的web页面中管理nexus。
可以配置仓库(仓库的创建等)、安全(用户、角色、域、权限、SSL、匿名账户等配置)、IQ Server、Support(日志查看、服务器状态、指标统计、系统信息、日志文件压缩、JVM堆存储压缩等)、系统(API、Email服务、定时任务等)
点击右上角的用户账户,进入用户详情页面,可以修改用户的密码。
忘记密码
如果更改完密码,把密码忘记了,密码不能找回,只能重新设置。
重置密码:参考官方文档
旧版本的密码存在配置文件中,3.x存储在数据库中。
nexus内置了一个图数据库OrientDB,密码信息存储在图数据库中。图数据库的数据文件位于 sonaptype/nexus3/db 文件夹中
关闭nexus,备份 sonaptype/nexus3/db 文件夹
登录OrientDB数据库控制台
连接数据库
使用下列语句重置密码为:admin123
如果 nexus中不存在admin用户:
OrientDB使用的是类SQL语言,不是SQL。
重启nexus服务器生效
仓库配置
自带的仓库配置:
maven-central:maven的中央仓库,,format为“maven2" , type为“proxy”(代理),Remote storage配置的代理的 远程maven仓库路径。如果要使用该仓库,只需拷贝该仓库的 URL 到自己的maven setting配置文件中。
maven-releases:jar包的正式发行版,type 为"hosted"(本地仓)。如果要使用该仓库,只需拷贝该仓库的 URL 到自己的maven setting配置文件中。
maven-snapshots:jar包的快照版,type 为"hosted",默认创建的maven的jar包即为快照版。
maven-public:聚合分组仓库。type为“group"(组),提供了聚合分组的功能。Member repositories配置的是该组包含的仓库成员。可以将需要配置的多个仓库都加入这个分组中,最终在maven setting配置文件中配置这个组的URL即可。
nuget-group、nuget-hosted、nuget.org-proxy 是 format 为“nuget" 的仓库示例。
创建仓库:
选择 Create repository
选择要创建的仓库类型,例如 maven2(proxy)(代理远程maven仓库)
设置仓库名称、代理的远程仓库地址 阿里云maven )
本地仓设置成允许重复提交:
默认情况下,创建的仓库只允许提交一次,需要设置成可重复提交。(如果禁止重复提交模式下,多次提交会报405错误)
进入需要配置的仓库,例如 maven-releases 、maven-snapshots
在 Hosted ---> Deployment policy ,选择 Allow redeploy
在maven中使用Nexus中的仓库
方式1:通过mirrors配置
在maven的settings.xml中进行配置:
如果用户名/密码错误,将会返回 401 错误(即没有权限)
方式2:通过profiles配置
在maven的settings.xml中进行配置
两种方式对比:
如果使用mirrors方式配置,当私服宕机时,maven项目的依赖便无法下载。
如果使用profile方式配置,当私服宕机时,maven项目的依赖会到自动切换到Maven远程仓库进行下载。
方式3:在项目中配置:
上传项目到nexus仓库
在maven的settings文件中添加配置:
上传不需要mirrors和profiles,仓库路径在项目的pom.xml中进行定义
在需要上传的资源的项目 pom.xml 中添加配置:
此处的地址不可以配置成 maven-public 的地址,因为maven-public是一个聚合仓库,此处需要指明要上传的仓库
在项目中执行 maven 的 deploy 命令。
如果项目的版本是 xxx-SNAPSHOTS,会上传到快照仓库,但是上传上去的jar包的名称后面会加上时间戳。
如果项目的版本是 xxx-RELEASE,会上传到发行版仓库,上传上去的jar包名称就是项目中的名称
使用Docker安装
安装方式1:使用docker部署
安装docker环境
从dockerHub上拉取nexus3的镜像
该镜像位于dockerHub上,但不是docker官方镜像,在网易数帆、阿里云等镜像中心都搜索不到。

从dockerHub上拉取时网络比较卡顿,如果网络超时就多试几次。
镜像拉取完成之后,使用docker进行运行
nexus3的web默认绑定的端口为8081
使用浏览器访问:http://192.168.29.131:8081
启动较慢,可能需要等待一会儿才能访问到
为了避免以后再次拉取nexus镜像较慢问题,在拉取镜像成功之后,将镜像导出成一个tar包。以后重新部署时直接将tar包作为镜像导入docker即可。
关闭docker容器时,确保有足够的时间使nexus的数据库关闭:
安装方式2:使用Docker file进行构建
有3个参数:

NEXUS_VERSION:Nexus Repository Manager的版本
NEXUS_DOWNLOAD_URL:Nexus Repository的下载路径,用于NEXUS_VERSION的替代方式
NEXUS_DOWNLOAD_SHA256_HASH:下载的Nexus Repository Manager的sha256校验。如果提供了NEXUS_VERSION或NEXUS_DOWNLOAD_URL,则sha256参数必需

使用rspec测试Dockerfile:
Docker相关配置
默认用户是 admin,第一次启动时,为其生成的一串UUID密码位于 /nexus-data/admin.password 中。
查看密码:
服务在新容器中可能需要2-3分钟才能启动,可以通过日志查看是否就绪:
nexus的安装方式为:/opt/sonatype/nexus
/nexus-data为永久目录,该目录用于配置、日志和存储,Nexus进程必需可写该目录。
可以通过 INSTALL4J_ADD_VM_PARAMS 环境变量,将JVM参数传递给启动脚本,默认为:-Xms2703m -Xmx2703m -XX:MaxDirectMemorySize=2703m -Djava.util.prefs.userRoot=${NEXUS_DATA}/javaprefs。
例如:
其中 -Djava.util.prefs.userRoot可以指定永久目录的路径。
可以通过 NEXUS_CONTEXT 环境变量来控制Nexus上下文路径,默认为 /。
例如:
数据持久化
因为永久目录默认为/nexus-data,所以需要对永久目录进行持久化。
方式1:使用docker volume卷。
docker volume卷是持久性的因为可以专门为此创建一个卷。官方推荐做法
方式2:使用主机目录。
因为主机目录中的数据本身不会清空,所以可以将主机目录作为docker中的/nexus-data目录进行挂载
创建npm私仓注意事项
正常创建好一个 npm 私仓后,通过 npm publish向私仓上传npm资源:
配置nexus,nexus默认npm是失效的。
使用管理员用户登录nexus的web管理页面
找到:security --> Realms
将npm Bearer Token Realm配置成 Active

将本地npm的仓库地址配置为私仓地址:
配置登录npm私仓的用户名、密码、邮箱
进入到package.json的同级目录,进行发布
此处需要注意,如果package.json中publishConfig配置了其他的registry,需要将其改为我们的私仓地址,或者去掉该配置。

否则会报错:-4048(即用户未登录的错误)
如果用户名密码有问题,可以找到.npmrc文件进行修改:
使用命令查看 .npmrc文件的路径
打开该文件,删除_authToken 的那一行
重新使用 npm login登录即可
仓库分文件夹存储
在Web管理页面:Repository --> Blob Stores
Create blob store
选择存储类型:File或者S3
例如选择 File 文件存储;
起一个Blob名称;
填写文件保存路径,默认为:/home/nexus/sonatype-work/nexus3/blobs/Blob名称
创建新的仓库时,便可以在 Storage --> Blob store 选择我们自定义的文件夹进行存储。
Maven
使用命令方式上传到私仓
命令:
整个资源库上传到私仓
将整个本地的资源库上传到nexus私仓:
先将本地repository仓库文件夹打成一个完整的zip压缩包
上传到nexus服务器上
解压zip
进入repository目录
清理*.lastUpdated、_remote.repositories文件
将本地仓库里面所有的maven-metadata-alimaven.xml改名为maven-metadata.xml(alimaven是本地maven的settings文件中设置的镜像仓库名)
编写 mvnimport.sh 脚本,内容如下
将私仓文件、sh脚本授权
执行shell脚本并传入参数
等全部导入完毕后,在nexus控制台页面刷新即可看到已导入的jar
Npm
将依赖使用命令上传
登录资源库
Shell
运行代码
复制代码
1
npm login
进入package.json页面,进行上传
Shell
运行代码
复制代码
1
npm push
Docker
使用命令上传镜像
登录资源库
Shell
运行代码
复制代码
1
docker login 资源库地址 -u 用户名
将要上传的镜像复制一个tag
Shell
运行代码
复制代码
1
docker tag mysql:8 192.168.xxx.xxx:8881/mysql:8
上传镜像
Shell
运行代码
复制代码
1
docker push 192.168.xxx.xxx:8881/mysql

相关文章
|
1天前
|
负载均衡 安全 数据库
异常重试:在约定时间内安全可靠地重试
本节讲解RPC框架中的异常重试机制,重点探讨如何在超时控制、节点避让和异常判定的基础上实现安全可靠的重试。需确保业务逻辑幂等,设置重试白名单,并在每次重试前重置超时时间,避免耗时超标,提升系统容错性与稳定性。(239字)
|
1天前
|
存储 算法 Java
时间空间复杂度入门
本文介绍时间与空间复杂度入门知识,使用Big O表示法(如O(1)、O(n)、O(n²)),强调估算而非精确计算,保留最高次项。时间复杂度常由循环嵌套层数决定,空间复杂度看额外内存占用。分析以最坏情况为主,越小越好。结合多个代码示例,帮助初学者理解复杂度分析的基本方法与常见误区。
|
Kubernetes Linux Docker
极简的配置单节点Kubernetes(k8s)集群
在传统的概念当中,Docker是简单易用的,Kubernetes是复杂强大的。 深入了解之后会发现Docker的简单是因为用户可以从基本功能开始用起, 只需要一台Linux主机,运行一下apt-get install docker-engine 或者yum install docker-engine,立马就可以用docker run启动一个新的容器, 整个过程与用户之前积累的Linux软件使用体验高度一致。
6510 0
|
机器学习/深度学习 人工智能 算法
【AI系统】内存分配算法
本文探讨了AI编译器前端优化中的内存分配问题,涵盖模型与硬件内存的发展、内存划分及其优化算法。文章首先分析了神经网络模型对NPU内存需求的增长趋势,随后详细介绍了静态与动态内存的概念及其实现方式,最后重点讨论了几种节省内存的算法,如空间换内存、计算换内存、模型压缩和内存复用等,旨在提高内存使用效率,减少碎片化,提升模型训练和推理的性能。
571 1
|
人工智能 算法 数据挖掘
编程之美:从代码到艺术
【10月更文挑战第42天】在数字世界的画布上,代码不仅仅是冷冰冰的指令序列,它如同艺术家手中的笔触,能够创作出令人惊叹的作品。本文旨在探索编程的艺术性,揭示如何通过技术实现创意和解决问题的美学。我们将一起走进代码的世界,感受它的结构之美、逻辑之精和创新之力。
191 4
|
JavaScript 前端开发 Go
async 和 defer的作用与区别
async 和 defer的作用与区别
|
机器学习/深度学习 人工智能 安全
人工智能与机器学习在网络安全中的应用
人工智能与机器学习在网络安全中的应用
385 0
|
存储 缓存 安全
Python案例分享:如何实现文件的上传下载
Python案例分享:如何实现文件的上传下载
1039 6
|
存储 安全 Java
图书管理系统的设计与实现
图书管理系统的设计与实现
|
人工智能 JSON 自然语言处理
基于中文金融知识的 LLaMA 系微调模型的智能问答系统:LLaMA大模型训练微调推理等详细教学
基于中文金融知识的 LLaMA 系微调模型的智能问答系统:LLaMA大模型训练微调推理等详细教学
 基于中文金融知识的 LLaMA 系微调模型的智能问答系统:LLaMA大模型训练微调推理等详细教学