#业务场景
最近项目要交付给客户了,之前项目开发和测试一直都是使用公司内部的一套环境,项目交付后客户购置了大量服务器,也要将整套测试环境迁移至客户的服务器上,后续的需求变更以及新需求的开发都会在客户服务器上进行开发和测试。当应用服务器环境、SVN等全部准备好之后,我发现项目引用了大量我们公司封装的jar包,而这些jar包还是要从我们公司的Maven私服仓库下载,而客户这边则要求要在客户服务器上重新搭建一个Maven的私服仓库来管理jar包,不允许在使用我们公司的maven私服,所以我就开始协助客户使用Nexus这个仓库管理器来搭建Maven私服。下面就简单说一下在使用Nexus搭建Maven私服时碰到一些问题。
#搭建步骤
不多说了,网上大把教程,各个选项各个参数都有较为详细的介绍,这里推荐两个:
- maven-nexus中添加本地仓库:http://blog.csdn.net/zwc0910/article/details/17349111
- Maven三种仓库的配置:https://www.cnblogs.com/jack1995/p/6925879.html
#搭建中的一些小问题
Nexus 2.x版本和3.x版本差别很大,网上搜到的教程大多都是2.x版本的,3.x的较少,由于之前没有搭建仓库的相关经验,这3.x版本上折腾了一番硬是没成功,根据工程学理论,所以我们选择了2.x版本在windows server上进行搭建。
理解maven各个仓库之间的关系
在项目中我们真正会用到的有三个maven仓库,本地仓库、私服仓库和*仓库。
- 本地仓库:即本地的maven仓库,也就是在安装maven的时候指定的本地仓库路径,配置在maven的settings.xml当中
- 私服仓库:使用Nexus搭建好私服后配置的仓库,首先需要在搭建Nexus时进行配置在服务上的仓库地址,通常是在sonatype-work\nexus\storage下,也可以自定义路径覆盖默认路径。反映在本地的settings.xml当中则是配置的标签内 和当中。
- *仓库,在项目中如果未使用Maven私服且都是用到的一些公用的jar包,那么本地工程Maven的默认配置都是从*仓库进行下载。如果有用到私服,那么请求就是先从私服下载,如果私服仓库没有则去*仓库进行检索下载。
三者之间的关系是,当我们在项目中依赖一个jar包时,Maven程序会先去本地仓库中找,如果没找到就回去私服找,如果还是没有,最后就回去*仓库找。如下图:
第三方jar包批量上传
这是碰到的一个头疼的问题,因为当时项目依赖了大量的我们公司自己封装的jar包,这些jar包在*仓库里肯定是没有的,需要上传到maven私服当中。但是网上搜到的上传方法大都是一个个的上传到thirdparty这个仓库当中,如果照这种方式来不知要上传多久,我看更是有人祭出了自己写的脚本来做批量的上传,这就涉及到了Maven仓库的迁移。后面在网上找到一种相对简单的方法,即将原来用的依赖上传到Nexus所在服务器,然后在新建仓库时制定仓库路径来覆盖默认路径。具体操作如下:
- 新建host类型的仓库
- 在 Override Local Storage Location选项上填入你上传的maven仓库的路径并覆盖默认路径。
最好把 Deployment Policy 选项下勾选为 Allow Redeploy 方便后面jar修改后打包到私服仓库。
这样下来就可以了,我这边顺便把上传的jar包夜丢到了thirdparty的默认仓库下了。
本地maven仓库配置好之后部分jar包无法下载
配置完毕之后改了一下maven的settings.xml配置文件,在里面新增了两个profile,一个是私服地址,一个是*仓库地址。但是测试了几次,总是有几个包无法下载,其中就包括oralce的ojdbc驱动。我们都知道,oracle官方没有把这个驱动jar包放到maven的*仓库,所以几个用的比较广泛的*仓库都是找不到这个jar的,但是这个jar包明明在我私服仓库里面是有的,问题可能就是在下载jar包的过程中请求*仓库下载这些jar包没有成功。但是公司自己封装的jar包也都下载成功了。万分不解,后来*仓库的地址配置似乎有问题,之前我是配置的默认的http://repo1.maven.org/maven2/ ,后面修改成了Nexus一个默认的group类型的Public Repositories仓库,即http://197.55.xx.xxx:8081/nexus/content/groups/public/jar, 包就能全部下载成功了,:’(
#总结
暂时到这里,里面还有一些我也没搞明白的地方,有机会再补充吧