Maven仓库
仓库中jar包定位
在maven世界中任何一个依赖、插件或者项目构建的输出都可以称为构件,任何一个构件都有一个坐标作为唯一
的标识。
这个坐标就是:group、artifactId、version;根据这个坐标就可以定义其在仓库的唯一存储路径,那么就可以
在项目中引用。
Maven仓库原理
Maven仓库是基于简单文件系统存储的,只要在文件系统中没有发现相关的文件,说明这依赖并不存在,因
此,我们很容易在本地仓库查找具体的依赖是否存在。
在Maven中,任何一个依赖、插件或者项目构建的输出,都可以称之为构件。Maven在某个统一的位置存储所有
项目的共享的构件,这个统一的位置,我们就称之为仓库(仓库就是存放依赖和插件的地方)。
任何的构件都有唯一的坐标,Maven根据这个坐标定义了构件在仓库中的唯一存储路径。
解读Maven在仓库中的存储路径:
1.基于groupId准备路径,将句点分隔符转成路径分隔符,就是将 "." 转换成 "/" ; example: org.testng ---
>org/testng
2.基于artifactId准备路径,将artifactId连接到后面:org/testng/testng
3.使用version准备路径,将version连接到后面:org/testng/testng/5.8
4.将artifactId于version以分隔符连字号连接到后面:org/testng/testng/5.8/tesng-5.8
5.判断如果构件有classifier,就要在第4项后增加分隔符连字号 再加classifier,org/testng/testng/5.8/tesng-
5.8-jdk5
6.检查构件的extension,如果extension存在,则加上句点分隔符和extension,而extension是由packing决定
的,org/testng/testng/5.8/tesng-5.8-jdk5.jar
到这里我们就明白了Maven 对于构件存储的细节。
Maven 仓库的分类
Maven的仓库只有两大类:本地仓库和远程仓库
本地仓库就是我们自己机器上的文件系统,所以他是唯一的,项目构建时首先在本地仓库查找依赖,如果本地没
有依赖时才会去寻找远程仓库。
远程仓库指的是非本地的其他所有仓库,中央仓库、私服等都是远程仓库的一种。如果本地仓库没有项目构建需
要的构件,你们就会从远程仓库下载,可是远程仓库如果也没有的话,你们就会项目报错。
本地仓库设置
maven的本地仓库,在安装maven后并不会创建,它是在第一次执行maven命令的时候才被创建。
maven本地仓库的默认位置:无论是Windows还是Linux,在用户的目录下都有一个.m2/repository/的仓库目
录,这就是Maven仓库的默认位置。
更改maven默认的本地仓库的位置:这里要引入一个新的元素:localRepository,它是存在于maven的
settings.xml文件中,更改配置用户范围的本地仓库:先在/.m2/目录下创建settings.xml文件,然后在
~/.m2/settings.xml,设置localRepository元素的值为想要的仓库地址。
这时候,maven的本地仓库地址就变成了 E:/Java/develop/maven/m2/repository,此时配置的maven的本地
仓库是属于用户范围的。
更改配置全局范围的本地仓库:在M2_HOME/conf/settings.xml中更改配置,更改配置的方法同上。此时更
改后,所有的用户都会受到影响,而且如果maven进行升级,那么所有的配置都会被清除,所以要提前复制和备份
M2_HOME/conf/settings.xml文件。这时候需要复制一份setting.xml配置文件到E:/Java/develop/maven/m2/
下。
远程仓库
中央仓库
说到远程仓库先从 最核心的中央仓库开始,中央仓库是默认的远程仓库,maven在安装的时候,自带的就是中央
仓库的配置,Maven必须知道至少一个可用的远程仓库,才能执行Maven命令的时候下载到需要的构件。中央仓库
就是这样一个默认的远程仓库,Maven安装文件自带远程仓库的位置是:http://repo.maven.apache.org/maven2
所有的maven项目都会继承超级pom,具体的说,包含了下面配置的pom我们就称之为超级pom,在Maven的
安装目录下的lib目录下有一个maven-model-builder-3.3.9.jar,用解压软件打开,org\apache\maven\model下
有个pom-4.0.0.xml文件:
我们可以复制出来一份打开,具体中央仓库在settings.xml文件的配置如下:
中央仓库包含了绝大多数流行的开源Java构件,以及源码、作者信息、SCM、信息、许可证信息等。一般来说,
简单的Java项目依赖的构件都可以在这里下载到。
私服
私服是一种特殊的远程仓库,他是架设在局域网内的仓库服务,私服代理广域网上的远程仓库,供局域网内的
Maven用户使用。当Maven需要下载构件的时候,它从私服请求,如果私服上不存在改构件,则从外部的远程仓库
下载,同时缓存在私服之上,然后为Maven下载请求提供服务,另外,对于第三方的jar无法从仓库下载(JDBC驱
动)可以从本地上传到私服供客户端下载。
优点主要有:
1)节省外网宽带
2)加速Maven构建
3)部署第三方构件
4)提高稳定性、增强控制:原因是外网不稳定
5)降低中央仓库的负荷:原因是中央仓库访问量太大
当前主流的maven私服:
1.Apache的Archiva
2.JFrog的Artifactory
3.Sonatype的Nexus
远程仓库配置
配置远程仓库将引入新的配置元素:<repositories> <repository>
在<repositories>元素下,可以使用 <repository>子元素声明一个或者多个远程仓库。例子:
<updatePolicy>元素:表示更新的频率,值有:never, always,interval,daily, daily 为默认值
<checksumPolicy>元素:表示maven检查和检验文件的策略,warn为默认值
有时候登录一个远程仓库需要用户名和密码进行身份验证,所以,需要远程仓库认证。配置认证信息和配置仓库
信息不同,仓库信息可以直接配置POM文件中,但是认证信息必须配置在settings.xml文件中,目的就是安全性。当
然,我们可以把仓库信息配置在settings.xml 中,这样的缺点就是好动态控制仓库,但是一般情况下不会改变仓库,
我们本地私服一般都是唯一的。
值得注意的是,ID代表的是某个repository元素配置的ID。
镜像
如果仓库X可以提供仓库Y存储的所有内容,那么就可以认为X是Y的一个镜像,某些情况下使用镜像可以提高项
目构建效率。
settings.xml 中配置镜像:
镜像的意思是,当你访问mirrorOf的仓库时,就会转到对应的镜像url中请求对应的资源。一般镜像都是和私服结
合使用。由于私服可以代理任何外部的公共仓库(包括中央仓库),因此,对于组织内部的Maven用户来说,使用一
个私服地址就等于使用了所有需要的外部仓库,这个可以将配置集中到私服,从而简化Maven本身的配置。在这种情
况下,任何需要的构件都可以从私服中获得,私服就是所有仓库的镜像。我使用的阿里镜像如下配置:
仓库中jar包搜索
1)仓库搜索:
使用到最多的就是:http://search.maven.org/
其他的仓库
2)中央仓库
http://repo1.maven.org/maven2/
http://repository.jboss.com/maven2/
http://repository.sonatype.org/content/groups/public/