Maven讲解之 仓库
概念
Maven在某个统一的位置存储所有项目的共享的构件,这个统一的位置,我们就称之为仓库。(仓库就是存放依赖和插件的地方)。
分类
maven的仓库只有两大类:1.本地仓库 2.远程仓库,在远程仓库中又分成了3种:中央仓库、 私服、其它公共库
本地仓库:为当前本机电脑上的所有 Maven 工程服务。.
Default:默认在用户下 C:{user}.m2\repository
Cusomized:自定义可通过修改setting.xml配置文件。如我自定义的setting.xml中对repository的Cusomized。
<localRepository>E:\WorkSpace\IDEs\Maven\MavenRepository</localRepository>
远程仓库
私服
私服是一种特殊的远程仓库,它是架设在局域网内的仓库服务,私服代理广域网上的远程仓库,供局域网内的Maven用户使用。当Maven需要下载构件的时候,它从私服请求,如果私服上不存在该构件,则从外部的远程仓库下载,缓存在私服上之后,再为Maven的下载请求提供服务。我们还可以把一些无法从外部仓库下载到的构件上传到私服上。- 节省自己的外网带宽:减少重复请求造成的外网带宽消耗。
- 加速Maven构件:如果项目配置了很多外部远程仓库的时候,构建速度就会大大降低。
- 部署第三方构件:有些构件无法从外部仓库获得的时候,我们可以把这些构件部署到内部仓库(私服)中,供内部maven项目使用。
- 提高稳定性,增强控制:Internet不稳定的时候,maven构建也会变的不稳定,一些私服软件还提供了其他的功能。
- 常用的私服
- Apache的Archiva
- JFrog的Artifactory
- Sonatype的Nexus
中央仓库
架设在 Internet 上,为全世界所有 Maven 工程服务。若要使用中央仓库(此处特质远程仓库)需要在setting.xml配置文件中添加新的Node:repositories 和 repository。<repositories> <repository> <id>jboss</id> <name>JBoss Repository</name> <url>http://repository.jboss.com/maven2/</url> <releases> <updatePolicy>daily</updatePolicy><!-- never,always,interval n --> <enabled>true</enabled> <checksumPolicy>warn</checksumPolicy><!-- fail,ignore --> </releases> <snapshots> <enabled>false</enabled> </snapshots> <layout>default</layout> </repository> </repositories>
updatePolicy Node解读
与远程仓库同步频率。never
- 从不同步
always
- 经常Sync
interval
- 间歇性地Sync
daily
- 每天Sync
checksumPolicy
表示maven检查和检验文件的策略。warn为默认值。安全认证
一般我们在使用远程仓库的时候,主仓库都会有权限认证这一环节。简而言之我们在使用远程仓库的时候需要身份认证即 Username + Password。<servers> <server> <id>deploymentRepo</id> <username>Username</username> <password>Password</password> </server> </servers>
如果我们需要链接远程仓库,需在我们的Maven setting.xml文件中配置如上信息,其中id需要和远程仓库的Repository一致。
中央仓库的镜像
架设在各个大洲,为中央仓库分担流量。减轻中央仓库的压力,同时更 响应用户请求。``` <mirrors> <mirror> <id>nexus-aliyun</id> <mirrorOf>*,!jeecg,!jeecg-snapshots</mirrorOf> <name>Nexus aliyun</name> <url>http://maven.aliyun.com/nexus/content/groups/public</url> </mirror> </mirrors> ```
我自定已的中央仓库镜像为Aliyun,这样在国内使用该镜像时 下载jar的速度非常快。
仓库中的文件
- Maven 的插件
- 我们自己开发的项目的模块
第三方框架或工具的 jar 包
不管是什么样的 jar 包,在仓库中都是按照坐标生成目录结构,所以可以通过统一的方式查询或依赖。