什么是 Nexus

概述

Nexus 是一个强大的仓库管理器,极大地简化了内部仓库的维护和外部仓库的访问。

2016 年 4 月 6 日 Nexus 3.0 版本发布,相较 2.x 版本有了很大的改变:

  • 对低层代码进行了大规模重构,提升性能,增加可扩展性以及改善用户体验。
  • 升级界面,极大的简化了用户界面的操作和管理。
  • 提供新的安装包,让部署更加简单。
  • 增加对 Docker, NeGet, npm, Bower 的支持。
  • 提供新的管理接口,以及增强对自动任务的管理。

克隆镜像注意(必看)

可以看到nexus服务已经使用了接近1.3G的内存,所以为了能运行nexus我们应该分配>2G的内存,启服务会快些

基于 Docker 安装 Nexus

我们使用 Docker 来安装和运行 Nexus 中文版,通过pull命令获取镜像,我们使用latest稳定版本,注意:这一步可以省略,配置了docker-compose.yml文件,启动项目docker-compose up发现没有images会自动去官服下载镜像

1
docker pull sonatype/nexus3

在/usr/local/docker/路劲新建目录mkdir nexus,新建文件touch docker-compose.yml

docker-compose.yml 配置如下:

1
2
3
4
5
6
7
8
9
10
version: '3.1'
services:
nexus:
restart: always
image: sonatype/nexus3
container_name: nexus
ports:
- 8081:8081
volumes:
- /usr/local/docker/nexus/data:/nexus-data

启动服务

1
2
3
4
docker-compose up -d 

docker-compose 命令必须在docker-compose.yml文件目录执行
-d 以守护态(后台运行)启动nexus服务

注: 启动时如果出现权限问题

1
Unable to create directory /nexus-data/instances

可以使用:chmod 777 /usr/local/docker/nexus/data 赋予数据卷目录可读可写的权限

登录控制台验证安装

地址:http://ip:port/

用户名:admin

密码:根据提示在容器目录的/nexus-data/admin.password文件内

这里注意你使用的版本是否和我的一致,其中oss 3.1.0-04,默认密码为admin123

Maven 仓库介绍

代理仓库(Proxy Repository)

意为第三方仓库,如:

  • maven-central
  • nuget.org-proxy

版本策略(Version Policy):

  • Release: 正式版本
  • Snapshot: 快照版本
  • Mixed: 混合模式

布局策略(Layout Policy):

  • Strict:严格
  • Permissive:宽松

宿主仓库(Hosted Repository)

存储本地上传的组件和资源的,如:

  • maven-releases
  • maven-snapshots
  • nuget-hosted

部署策略(Deployment Policy)

  • Allow Redeploy:允许重新部署
  • Disable Redeploy:禁止重新部署
  • Read-Only:只读

仓库组(Repository Group)

通常包含了多个代理仓库和宿主仓库,在项目中只要引入仓库组就可以下载到代理仓库和宿主仓库中的包,如:

  • maven-public
  • nuget-group

在项目中使用 Maven 私服

配置认证信息

Maven settings.xml 中添加 Nexus 认证信息(servers 节点下):

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
<server>
<id>nexus</id>
<username>admin</username>
<password>123456</password>
</server>

<server>
<id>nexus-releases</id>
<username>admin</username>
<password>123456</password>
</server>

<server>
<id>nexus-snapshots</id>
<username>admin</username>
<password>123456</password>
</server>

Snapshots 与 Releases 的区别

  • nexus-releases: 用于发布 Release 版本 (发行版)
  • nexus-snapshots: 用于发布 Snapshot 版本(快照版)

Release 版本与 Snapshot 定义如下:

1
2
Release: 1.0.0/1.0.0-RELEASE
Snapshot: 1.0.0-SNAPSHOT

在项目 pom.xml 中设置的版本号添加 SNAPSHOT 标识的都会发布为 SNAPSHOT 版本,没有 SNAPSHOT 标识的都会发布为 RELEASE 版本。 SNAPSHOT 版本会自动加一个时间作为标识,如:1.0.0-SNAPSHOT 发布后为变成 1.0.0-SNAPSHOT-20180522.123456-1.jar

配置自动化部署

pom.xml 中添加如下代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
<!--打包上传到私服的依赖-->
<distributionManagement>
<repository>
<id>nexus-releases</id>
<name>Nexus Release Repository</name>
<url>http://192.168.40.138:8081/repository/maven-releases/</url>
</repository>
<snapshotRepository>
<id>nexus-snapshots</id>
<name>Nexus Snapshot Repository</name>
<url>http://192.168.40.138:8081/repository/maven-snapshots/</url>
</snapshotRepository>
</distributionManagement>

注意事项:

ID 名称必须要与Maven安装目录的conf/ settings.xmlServers 配置的 ID 名称保持一致。 项目版本号中有 SNAPSHOT 标识的,会发布到 Nexus Snapshots Repository, 否则发布到 Nexus Release Repository,并根据 ID 去匹配授权账号。

部署到仓库

1
2
3
mvn deploy -Dmaven.test.skip=true

部署不测试(跳过测试)

上传第三方 JAR 包

使用 maven 命令:

1
2
3
4
5
6
7
8
mvn deploy:deploy-file   
-DgroupId=com.google.code.kaptcha
-DartifactId=kaptcha
-Dversion=2.3
-Dpackaging=jar
-Dfile=G:\kaptcha-2.3.jar
-Durl=http://192.168.40.138:8081/repository/maven-releases/
-DrepositoryId=nexus-releases

注意事项:

建议在上传第三方 JAR 包时,创建单独的第三方 JAR 包管理仓库,便于管理有维护。(maven-3rd) -DrepositoryId=nexus-releases 对应的是Maven安装目录的conf/ settings.xmlServers 配置的 ID 名称。(授权)

配置代理仓库

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
<repositories>
<repository>
<id>nexus</id>
<name>Nexus Repository</name>
<url>http://192.168.40.138:8081/repository/maven-public/</url>
<snapshots>
<enabled>true</enabled>
</snapshots>
<releases>
<enabled>true</enabled>
</releases>
</repository>
</repositories>
<pluginRepositories>
<pluginRepository>
<id>nexus</id>
<name>Nexus Plugin Repository</name>
<url>http://192.168.40.138:8081/repository/maven-public/</url>
<snapshots>
<enabled>true</enabled>
</snapshots>
<releases>
<enabled>true</enabled>
</releases>
</pluginRepository>
</pluginRepositories>

注意事项:

id 对应的是Maven安装目录的conf/ settings.xmlServers 配置的 ID 名称。(授权)

查看是否生效

使用打包命令,jar包是否会从搭建的nexus(私服)上下载jar

1
mvn package -Dmaven.test.skip=true

查看内存使用

1
free -h

查看cpu利用率

1
apt-get install htop