Maven默认中央仓库(l配置详解)
Maven的安装
安装Maven之前要确保已经安装好了jdk,并且配置好了环境变量JAVA_HOME。具体安装步骤如下:
2. 将下载后的压缩包解压到Maven的安装⽬录,⽐如说是D:\\develop,那么解压后就是D:\\develop\\apache-maven-
3.0.4。
3. 添加环境变量M2_HOME,其值为Maven的家⽬录,如D:\\develop\\apache-maven-3.0.4。
4.添加环境变量M2,其值将为maven安装⽬录的bin⽬录,即D:\\develop\\apache-maven-3.0.4\\bin,对于windows系统也可以使⽤%M2_HOME%\\bin,对于linux系统也可以使⽤$M2_HOME/bin。
5.将环境变量M2加⼊到PATH变量中,对于windows系统,可以在PATH变量的值后⾯加上“;%M2%”,对于linux系统,可以使⽤“export path=$path:$M2”
6.还有⼀个可选的环境变量MAVEN_OPTS,该环境变量主要是配置Maven在使⽤jdk的时候指定JVM属性的。如指定其值为“-Xms256m -Xmx512m”。
经过以上⼏步之后Maven就安装成功了。接下来我们可以在命令窗⼝使⽤mvn --version来验证⼀下Maven是否安装成功。如能正确输出Maven的安装版本,则表⽰它安装成功了。
当我们创建⼀个简单的Maven项⽬后(只需要在l配置好依赖),运⾏mvn clean install就可以把项⽬构建好,不需要我们⼿⼯下载任何jar,这全靠中央仓库的存在,它会⾃动从仓库下载。这个仓库的定义是在${M2_HOME}/lib/maven-2.0.10-uber.jar ⾥⾯。你可以在⾥⾯到\org\apache\maven\project\pom-4.l 这个⽂件,在这个⽂件⾥⾯定义了默认中央仓库的地址:
<repositories>
<repository>
<id> central</id>
<name> Maven Repository Switchboard</name>
<layout> default</layout>
<url> /maven2</url>
<snapshots>
<enabled> false</enabled>
</snapshots>
</repository>
</repositories>
如果你想覆盖中央仓库的默认地址,那么这⾥我们就会使⽤的镜像了,还在l⾥⾯配置:
<settings>
<mirrors>
<mirror>
<id> maven-net-cn</id>
<name> Maven China Mirror</name>
<url> maven/content/groups/public/</url>
<mirrorOf> central</mirrorOf>
</mirror>
</mirrors>
</settings>
,表⽰只为central仓库做镜像,如果想为所有的仓库做镜像那么可以改为: *
Maven配置详解
maven2 ⽐起maven1 来说,需要配置的⽂件少多了,主要集中在l和l中。
先来说说l,l对于maven来说相当于全局性的配置,⽤于所有的项⽬。在maven2中存在两个l,⼀个位于maven2的安装⽬录conf下⾯,作为全局性配置。对于团队设置,保持⼀致的定义是关键,所以maven2/conf下⾯的l就作为团队共同的配置⽂件。保证所有的团
队成员都拥有相同的配置。当然对于每个成员,都需要特殊的⾃定义设置,如⽤户信息,所以另外⼀个l就作为本地配置。默认的位置为:user.dir/.l⽬录中({user.dir} 指windows 中的⽤户⽬录)。
<settings xmlns="/POM/4.0.0"
xmlns:xsi="/2001/XMLSchema-instance"
xsi:schemaLocation="/POM/4.0.0
/xsd/settings-1.0.0.xsd">
<localRepository/>
<interactiveMode/>
<usePluginRegistry/>
<offline/>
<pluginGroups/>
<servers/>
<mirrors/>
<proxies/>
<profiles/>
<activeProfiles/>
</settings>
简单介绍⼀下⼏个主要的配置因素:
localRepository
表⽰本地库的保存位置,也就是maven2主要的jar保存位置,默认在${user.dir}/.m2/repository,如果需要另外设置,就换成其他的路径。
offline
如果不想每次编译,都去查远程中⼼库,那就设置为true。当然前提是你已经下载了必须的依赖包。
Servers
在POM中的 distributionManagement元素定义了开发库。然⽽,特定的username和pwd不能使⽤于l,所以通过此配置来保存server信息
<servers>
<server>
<id>server001</id>
<username>my_login</username>
<password>my_password</password>
<privateKey>${usr.home}/.ssh/id_dsa</privateKey>
<passphrase>some_passphrase</passphrase>
<filePermissions>664</filePermissions>
<directoryPermissions>775</directoryPermissions>
<configuration></configuration>
</server>
</servers>
1. id:server 的id,⽤于匹配distributionManagement库id,⽐较重要。
2. username, password:⽤于登陆此服务器的⽤户名和密码
3. privateKey, passphrase:设置private key,以及passphrase
4. filePermissions, directoryPermissions:当库⽂件或者⽬录创建后,需要使⽤权限进⾏访问。参照unix⽂件许可,如664
和775
Mirrors
表⽰镜像库,指定库的镜像,⽤于增加其他库
<mirrors>
<mirror>
<id>planetmirror</id>
<name>PlanetMirror Australia</name>
<url>downloads.planetmirror/pub/maven2</url>
<mirrorOf>central</mirrorOf>
</mirror>
</mirrors>
1. id,name:唯⼀的标志,⽤于区别镜像
2. url:镜像的url
3. mirrorOf:此镜像指向的服务id
Proxies
此设置,主要⽤于⽆法直接访问中⼼的库⽤户配置。
<proxies>
<proxy>
<id>myproxy</id>
<active>true</active>
<protocol>http</protocol>
<host>proxy.somewhere</host>
<port>8080</port>
<username>proxyuser</username>
<password>somepassword</password>
<nonProxyHosts>*.</nonProxyHosts>
</proxy>
</proxies>
1. id:代理的标志
2. active:是否激活代理
3. protocol, host, port:protocol://host:port 代理
4. username, password:⽤户名和密码
5. nonProxyHosts: 不需要代理的host
Profiles
类似于l中的profile元素,主要包括activation,repositories,pluginRepositories 和properties元素
刚开始接触的时候,可能会⽐较迷惑,其实这是maven2中⽐较强⼤的功能。从字⾯上来说,就是个性配置。
单独定义profile后,并不会⽣效,需要通过满⾜条件来激活。
repositories 和pluginRepositories
定义其他开发库和插件开发库。对于团队来说,肯定有⾃⼰的开发库。可以通过此配置来定义。
如下的配置,定义了本地开发库,⽤于release 发布。
<repositories>
<repository>
<id>repo-local</id>
<name>Internal 开发库</name>
<url>192.168.0.2:8082/repo-local</url>
<releases>
<enabled>true</enabled>
<updatePolicy>never</updatePolicy>
<checksumPolicy>warn</checksumPolicy>
</releases>
<snapshots>
<enabled>false</enabled>
</snapshots>
<layout>default</layout>
</repository>
</repositories>
<pluginRepositories>
<pluginRepository>
<id>repo-local</id>
<name>Internal 开发库</name>
<url>192.168.0.2:8082/repo-local</url>
<releases>
<enabled>true</enabled>
<updatePolicy>never</updatePolicy>
<checksumPolicy>warn</checksumPolicy>
</releases>
<snapshots>
<enabled>false</enabled>
</snapshots>
<layout>default</layout>
</pluginRepository>
</pluginRepositories>
releases, snapshots:每个产品的版本的Release或者snapshot(注:release和snapshot的区别,release⼀般是⽐较稳定的版本,⽽snapshot基本上不稳定,只是作为快照)
properties
maven 的properties作为placeholder值,如ant的properties。
包括以下的5种类型值:
1. env.X,返回当前的环境变量
如何配置maven环境变量2. project.x:返回pom中定义的元素值,如project.version
3. settings.x:返回l中定义的元素
4. java 系统属性:所有经过java.Properties()返回的值
5. x:⽤户⾃⼰设定的值
Activation
⽤于激活此profile
<activation>
<activeByDefault>false</activeByDefault>
<jdk>1.5</jdk>
<os>
<name>Windows XP</name>
<family>Windows</family>
<arch>x86</arch>
<version>5.1.2600</version>
</os>
<property>
<name>mavenVersion</name>
<value>2.0.3</value>
</property>
<file>
<exists>${basedir}/file2.properties</exists>
<missing>${basedir}/file1.properties</missing>
</file>
</activation>
1. jdk:如果匹配指定的jdk版本,将会激活
2. os:操作系统
3. property:如果maven能检测到相应的属性
4. file: ⽤于判断⽂件是否存在或者不存在
除了使⽤activation来激活profile,同样可以通过activeProfiles来激活
Active Profiles
表⽰激活的profile,通过profile id来指定。
<activeProfiles>
<activeProfile>env-test</activeProfile> 指定的profile id
</activeProfiles>
以上就是本⽂的全部内容,希望对⼤家的学习有所帮助,也希望⼤家多多⽀持。