setting.xml主要用于配置maven的运行环境等一系列通用的属性,是全局级别的配置文件;而pom.xml主要描述了项目的maven坐标,依赖关系,开发者需要遵循的规则,缺陷管理系统,组织和licenses,以及其他所有的项目相关因素,是项目级别的配置文件。
一个典型的pom.xml文件配置如下:
"http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0http://maven.apache.org/xsd/maven-4.0.0.xsd">
4.0.0</modelVersion>
com.winner.trade</groupId>
trade-coreId>
1.0.0-SNAPSHOT</version>
jar >
...</classifier>
com.winner.tradeId>
trade-test</artifactId>
1.0.0-SNAPSHOT >
test</scope>
false >
org.slf4j</groupId>
slf4j-apiId>
</exclusion>
>
</dependency>
>
UTF-8</file.encoding>
1.5.source.version>
1.5</java.target.version>
>
...
</project>
一般来说,上面的几个配置项对任何项目都是必不可少的,定义了项目的基本属性。
这里有必要对一个不太常用的属性classifier做一下解释,因为有时候引用某个jar包,classifier不写的话会报错。
classifier元素用来帮助定义构件输出的一些附属构件。附属构件与主构件对应,比如主构件是 kimi-app-2.0.0.jar,该项目可能还会通过使用一些插件生成 如kimi-app-2.0.0-javadoc.jar (Java文档)、 kimi-app-2.0.0-sources.jar(Java源代码) 这样两个附属构件。这时候,javadoc、sources就是这两个附属构件的classifier,这样附属构件也就拥有了自己唯一的坐标。
classifier的用途在于:
maven download javadoc / sources jar包的时候,需要借助classifier指明要下载那个附属构件
引入依赖的时候,有时候仅凭groupId、artifactId、version无法唯一的确定某个构件,需要借助classifier来进一步明确目标。比如JSON-lib,有时候会同一个版本会提供多个jar包,在JDK1.5环境下是一套,在JDK1.3环境下是一套:
引用它的时候就要注明JDK版本,否则maven不知道你到底需要哪一套jar包:
net.sf.json-lib</groupId>
json-libId>
2.4</version>
jdk15 >
</dependency>
myPorjectName</finalName>
${basedir}/target</directory>
installGoal>
../filter.properties</filter>
>
resources</targetPath>
true >
src/main/resources</directory>
**/ *.properties</include>
**/ *.xml</include>
>
jdbc.properties</exclude>
>
</resource>
>
</testResource>
Resources>
${basedir}\src\main\java</sourceDirectory>
${basedir}\src\main\scripts
SourceDirectory>
${basedir}\src\test\java</testSourceDirectory>
${basedir}\target\classesDirectory>
${basedir}\target\test-classes
</testOutputDirectory>
org.apache.maven.wagonId>
wagon-ssh</artifactId>
2.8 >
</extension>
>
</groupId>
maven-assembly-pluginId>
2.5.5</version>
assembly >
package</phase>
single >
</goals>
false >
</execution>
>
${finalName}</finalName>
falseAssemblyId>
assembly.xml</descriptor>
>
false</extensions>
... >
</dependencies>
true >
</plugin>
>
...</plugins>
Management>
</build>
pom里面的仓库与setting.xml里的仓库功能是一样的。主要的区别在于,pom里的仓库是个性化的。比如一家大公司里的setting文件是公用的,所有项目都用一个setting文件,但各个子项目却会引用不同的第三方库,所以就需要在pom里设置自己需要的仓库地址。
true</uniqueVersion>
repo-id >
repo-name</name>
file:/ /${basedir}/target/deploy >
</repository>
>
</snapshotRepository>
site-id >
site-name</name>
scp://svn.baidu.com/banseon:/var/www/localhost/banseon-web </url>
>
</relocation>
>
</distributionManagement>
</releases>
>
</snapshots>
repo-id >
repo-name</name>
http://192.168.1.169:9999/repository/ >
default</layout>
>
</repositories>
</pluginRepositories>
false</activeByDefault>
1.7 >
Windows XP</name>
Windows >
x86</arch>
5.1.2600 >
</os>
mavenVersion >
2.0.3</value>
>
/usr/local/hudson/hudson-home/jobs/maven-guide-zh-to-production/workspace/</exists>
/usr /local/hudson/hudson-home/jobs/maven-guide-zh-to-production/workspace/>
</file>
>
</profile>
profile配置项在setting.xml中也有,是pom.xml中profile元素的裁剪版本,包含了id,activation, repositories, pluginRepositories和 properties元素。这里的profile元素只包含这五个子元素是因为setting.xml只关心构建系统这个整体(这正是settings.xml文件的角色定位),而非单独的项目对象模型设置。如果一个settings中的profile被激活,它的值会覆盖任何其它定义在POM中或者profile.xml中的带有相同id的profile。
pom.xml中的profile可以看做pom.xml的副本,拥有与pom.xml相同的子元素与配置方法。它包含可选的activation(profile的触发器)和一系列的changes。例如test过程可能会指向不同的数据库(相对最终的deployment)或者不同的dependencies或者不同的repositories,并且是根据不同的JDK来改变的。只需要其中一个成立就可以激活profile,如果第一个条件满足了,那么后面就不会在进行匹配。
http://java.sun.com/j2se/1.5.0/docs/api/</link>
>
</configuration>
sunlink >
javadoc</report>
>
</reportSet>
Sets>
</plugin>
>
</reporting>
jira </system>
http:/ /jira.clf.com/</url>
Management>
</notifier>
>
</ciManagement>
banseon-maven </name>
http:/ /www.clf.com/ </url>
A maven project to study maven. >
</prerequisites>
>
Demo </name>
[email protected] >
clf@126.com</subscribe>
[email protected] >
http:/hi.clf.com/</archive>
List>
</mailingLists>
HELLO WORLD >
banseon </name>
[email protected] >
Project Manager</role>
Architect >
</roles>
demo >
http://hi.clf.com/ </organizationUrl>
No >
</properties>
-5 >
</developer>
>
</contributor>
>
Apache 2 </name>
http:/ /www.clf.com/LICENSE-2.0.txt </url>
repo >
Abusiness-friendly OSS license </comments>
>
</licenses>
scm:svn:http:/ /svn.baidu.com/banseon/maven/</connection>
scm:svn:http:/ /svn.baidu.com/banseon/maven/
</developerConnection>
>
http://svn.baidu.com/banseon</url>
>
demo </name>
http:/ /www.clf.com/</url>
>