服务器:CentsOS 6.9
nexus版本:nexus-3.15.2-01
JDk: 1.8.0_181
maven: apache-maven-3.6.0 maven的安装请参考:https://www.cnblogs.com/jimisun/p/8054819.html
1、下载nexus
nexus分为两个版本分别是:Nexus Repository Pro和Nexus Repository OSS版本,Pro版本是企业收费版本,一般我们都下载oss版本。下载nexus OSS3.X unix版本,下载路径:https://www.sonatype.com/download-oss-sonatype,如下图所示:
2、nexus安装
在服务器新建目录用于存放nexus安装包,并将安装文件上传服务器对应目录,解压缩。
mkdir /usr/local/nexus
cd /usr/local/nexus
tar -vxf nexus-3.15.2-01-unix.tar.gz
解压缩完成会生成两个目录文件,如下图所示:
其中:sonatype-work为仓库资源文件,nexus-3.15.2-01 即为nexus的核心文件。
2、启动nexus服务
启动nexus之前,请确定环境变量中已经配置好了java和maven,如下图所示:
在nexus安装目录下执行如下命令启动nexus服务,如下图所示:
./bin/nexus start
这里的警告信息提示我们不能通过root账户来启动nexus服务,这对我们正常使用nexus没有影响,想要解决有以下办法:
nexus中,用户自建包的上传有三种方式,分别为:
nexus-releases
admin
admin123
nexus-snapshots
admin
admin123
B:在mirrors标签下增加miirror信息,指定到我们nexus仓库
nexus-public
*
http://192.168.254.129:8081/repository/maven-public/
nexus
local-nexus-public
http://192.168.254.129:8081/repository/maven-public/
true
true
local-nexus-public
http://192.168.254.129:8081/repository/maven-public/
true
true
nexus
至此,我们setting.xml配置完毕。
下面我们更改pom.xml,完成distributionManagement的配置,链接起项目和客户端maven,
pom的project标签下加入distributionManagement配置。
nexus-releases
Nexus Release Repository
http://192.168.254.129:8081/repository/maven-releases/
nexus-snapshots
Nexus Snapshots Repository
http://192.168.254.129:8081/repository/maven-snapshots/
至此,所有的配置完成,我们通过idea的maven工具完成deploy操作,如下图所示:
编译提交成功后,即可以在nexus中找到我们提交的包,如下图所示
附加一些nexus中的一下概念说明,此处引用 http://www.cnblogs.com/kevingrace/p/6201984.html。
注意下面几点说明:
1.component name的一些说明:
1)maven-central:maven中央库,默认从https://repo1.maven.org/maven2/拉取jar
2)maven-releases:私库发行版jar
3)maven-snapshots:私库快照(调试版本)jar
4)maven-public:仓库分组,把上面三个仓库组合在一起对外提供服务,在本地maven基础配置settings.xml中使用。
2.Nexus默认的仓库类型有以下四种:
1)group(仓库组类型):又叫组仓库,用于方便开发人员自己设定的仓库;
2)hosted(宿主类型):内部项目的发布仓库(内部开发人员,发布上去存放的仓库);
3)proxy(代理类型):从远程中央仓库中寻找数据的仓库(可以点击对应的仓库的Configuration页签下Remote Storage Location属性的值即被代理的远程仓库的路径);
4)virtual(虚拟类型):虚拟仓库(这个基本用不到,重点关注上面三个仓库的使用);
3.Policy(策略):表示该仓库为发布(Release)版本仓库还是快照(Snapshot)版本仓库;
4.Public Repositories下的仓库 1)3rd party: 无法从公共仓库获得的第三方发布版本的构件仓库,即第三方依赖的仓库,这个数据通常是由内部人员自行下载之后发布上去; 2)Apache
Snapshots: 用了代理ApacheMaven仓库快照版本的构件仓库 3)Central:
用来代理maven中央仓库中发布版本构件的仓库 4)Central M1 shadow:
用于提供中央仓库中M1格式的发布版本的构件镜像仓库 5)Codehaus Snapshots: 用来代理CodehausMaven
仓库的快照版本构件的仓库 6)Releases:
内部的模块中release模块的发布仓库,用来部署管理内部的发布版本构件的宿主类型仓库;release是发布版本;
7)Snapshots:发布内部的SNAPSHOT模块的仓库,用来部署管理内部的快照版本构件的宿主类型仓库;snapshots是快照版本,也就是不稳定版本
所以自定义构建的仓库组代理仓库的顺序为:Releases,Snapshots,3rd
party,Central。也可以使用oschina放到Central前面,下载包会更快。
5.Nexus默认的端口是8081,可以在etc/nexus-default.properties配置中修改。
6.Nexus默认的用户名密码是admin/admin123
7.当遇到奇怪问题时,重启nexus,重启后web界面要1分钟左右后才能访问。
8.Nexus的工作目录是sonatype-work(路径一般在nexus同级目录下) [root@master-node local]# pwd /usr/local [root@master-node local]# ls nexus/ bin deploy etc lib
LICENSE.txt NOTICE.txt public system [root@master-node local]# ls
sonatype-work/ nexus3 [root@master-node local]# ls
sonatype-work/nexus3/ backup blobs cache db elasticsearch etc
generated-bundles health-check instances keystores lock log orient
port tmpNexus仓库分类的概念: 1)Maven可直接从宿主仓库下载构件,也可以从代理仓库下载构件,而代理仓库间接的从远程仓库下载并缓存构件
2)为了方便,Maven可以从仓库组下载构件,而仓库组并没有时间的内容(下图中用虚线表示,它会转向包含的宿主仓库或者代理仓库获得实际构件的内容).
------------------------------------没有梦想,无异咸鱼。不思学习,迟早咸鱼。------------------------------------