项目管理Maven篇(2)-Sonatype Nexus

96
恒骊_任建君
0.2 2017.04.08 23:15* 字数 1513

本文主要讲解Sonatype Nexus私有仓库部分,关于Maven的基础知识请阅读我另一篇文章:项目管理Maven篇(1)-基础详解

介绍

私服的优点:解决中央仓库网络、重复下载、本公司非公开组件多项目依赖等问题。
在团队协作开发中,为了提高开发效率,每个公司会有自己的私有仓库,私服是一种特殊的远程仓库,部署在局域网内,开发人员需要构建提交自己的项目组件至服务器,方便其他同事可以下载下来进行协同开发,如下就是围绕私服进行的团队开发协作流程。

仓库网络拓扑

Sonatype nexus

环境:CentOS 7、 JDK7 、Sonatype Nexus、Maven
服务器IP:192.168.2.102

安装

下载

下载最新版Nexus(本文使用的是nexus-2.11.2-03-bundle.tar.gz)

下载地址:
https://www.sonatype.com/download-oss-sonatype

linux命令:
$wget https://sonatype-download.global.ssl.fastly.net/nexus/oss/
nexus-2.11.2-03-bundle.tar.gz

解压

解压文件至nexus

[grid@h2 ~]$ mkdir nexus
[grid@h2 ~]$ tar -zxvf nexus-2.11.2-03-bundle.tar.gz -C nexus
[grid@h2 ~]$ cd nexus/
[grid@h2 nexus]$ ls
nexus-2.11.2-03  sonatype-work

其中nexus是指nexus服务,sonatype是指私有库目录

查看配置

编辑Nexus的nexus.properties文件,配置端口和work信息

 [grid@h2 nexus]$ vi nexus-2.11.2-03/conf/nexus.properties

查看目录可以看到nexus是集成netty来运行的,原始配置如下

nexus.properties
application-port:默认端口
application-host:默认所有ip都可访问
nexus-webapp:项目运行app
nexus-webapp-context-path:访问根目录
nexus-work:库目录,存放组件

编辑配置

编辑bin/nexus文件,修改RUN_AS_USER参数,指定启动用户


nexus

防火墙配置

使用root用户在防火墙中打开8081端口

[root@h2 ~]# vi /etc/sysconfig/iptables
iptables

保存后重启防火墙

[root@h2 ~]# service iptables restart

启动nexus

[grid@h2 bin]$ ./nexus start
Starting Nexus OSS...
Started Nexus OSS.

浏览器访问http://192.168.2.102:8081/nexus

我这里尝试访问结果访问不了,执行如下命令查看日志,信息如下:

[grid@h2 bin]$ tail -f ../logs/wrapper.log

/home/grid/nexus/sonatype-work/nexus/felix-cache/cache.lock 
(权限不够)

权限不够接下来我们使用root用户来启动,但此时需要重新修改nexus执行文件的参数

[grid@h2 bin]$ vi nexus

使用root用户再次启动

[root@h2 bin]# ./nexus start
****************************************
WARNING - NOT RECOMMENDED TO RUN AS ROOT
****************************************
Starting Nexus OSS...
Started Nexus OSS.

执行jps查看进程,有如下进程则表示启动成功

jps
再次访问

登录,默认用户名admin,默认密码admin123

login

Sonatype nexus的安装就讲到这里,下面我们对其功能及其使用进行详细介绍


Sonatype nexus详解

点击左侧的Repository可以看到Nexus管理很多类型的库,其(type栏)类型和(policy栏)策略,如下图:

repository_index

仓库类型(type-4种)

Hosted

宿主类型:此类型所描述的仓库,主要用于存放内部发布的的项目构件,和外部没有连接关系,是由公司内部用户发布上来的项目(其典型代表为:Release仓库、Snapshots仓库、 3rd party仓库)

proxy

代理类型:此类型所描述的仓库,主要是提供下载缓存构件和插件、比如你请求一个jar,它实际从远程中央仓库中寻找数据的仓库,如果只是从远程仓库下载构件和插件、那么代理仓库完全足够(其典型代表为:Central中央仓库、阿里云仓库、Apache仓库)。

group(非常重要,下节会讲如何使用)

组类型:此类型描述的仓库,把其他的仓库使用同一个地址暴露出去,组仓库用来方便我们开发人员进行设置的仓库,不具有实际的功能,只是一个概念,简单来说就是访问这个group设置的一个地址,其他仓库的jar都能获取到

virtual

虚拟类型:此类型主要是为了兼容maven的版本,maven版本经过大幅度提升,虚拟类型仓库主要是为了兼容maven1


仓库策略(policy-2种)

releases

发布版,稳定版的jar

snapshots

快照版,一般是处于开发中的jar


group组仓库类型(特殊)

group类型的代表为Public Repositories仓库,先看下面这幅图

group

下方的Configuration为代理的库,这里我们将Release、Snapshots、3RD Party、Central库暴露出去,暴露出去的顺序是有关系的,第一行Repository Path为暴露出去的地址,我们通过访问这个地址则可以访问到这4个暴露出去的仓库里的包

直接访问如下:

Repository Path

settings.xml仓库连接配置

Level介绍

settings.xml分为两个level如下图:

level

Servers设置

我们需要把jar包上传到私服供其他项目使用,所以需要配置该server的用户名及密码,如下,这里我们使用默认用户的:

Servers

Mirrors设置

mirrors镜像的意思,指私服地址,可配置多个私服,其中url为私服group组的Repository Path(group组暴露地址)

mirrors

Profiles设置

profiles
激活profile

修改后保存,然后在选中项目点击右键run as ->maven install,你会发现这时已经连接上私服,正在从私服上更新一些东西,其实私服已经去远程服务器拉取坐标索引等相关信息了

install

再次刷新私服的公开地址,可以看到去中央库下载了这些项目中依赖的jar包

再次刷新暴露出的地址

推送本地项目构件至私服

在项目pom.xml中加入

连接私服

运行后出了如下错误,提示认证失败:

Access denied to 
http://192.168.2.102:8081/nexus/content/repositories/snapshots 
/com/edu/parent/demo/edu-core/0.0.1-SNAPSHOT/edu-core- 
0.0.1-20170408.124142-1.jar. Error code 401, Unauthorized -> [Help 1]

原因是未配置snapshots和releases仓库的认证信息,接下来我们继续配置settings.xml文件的server,如下图:

snapshots和releases认证

再次执行,成功,此项目为快照版,将被发布至Snapshots库,如下:

发布成功

这里我再次修改另外一个项目为releases版,再次推送,如下图:

推送releases版本
查看发布成功

上传第3方包至私服

这里我以spring-web 4.3.7.RELEASE做示范

upload3rd
success
上传成功

私服的搭建及使用操作就讲到这里,以上的操作可以满足基本的需求,没覆盖到的知识面大家可以去网上对具体问题进行更具体的分析,后续我再对settings.xml和私有库进行更加详细的讲解

日记本
Web note ad 1