setting.xml主要用于配置maven的运行环境等一系列通用的属性,是全局级别的配置文件;而pom.xml主要描述了项目的maven坐标,依赖关系,开发者须要遵循的规则,缺陷管理系统,组织和licenses,以及其余全部的项目相关因素,是项目级别的配置文件。html
一个典型的pom.xml文件配置以下:java
通常来讲,上面的几个配置项对任何项目都是必不可少的,定义了项目的基本属性。web
这里有必要对一个不太经常使用的属性classifier作一下解释,由于有时候引用某个jar包,classifier不写的话会报错。spring
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的用途在于:apache
1. maven download javadoc / sources jar包的时候,须要借助classifier指明要下载那个附属构件json
2. 引入依赖的时候,有时候仅凭groupId、artifactId、version没法惟一的肯定某个构件,须要借助classifier来进一步明确目标。好比JSON-lib,有时候会同一个版本会提供多个jar包,在JDK1.5环境下是一套,在JDK1.3环境下是一套:windows
引用它的时候就要注明JDK版本,不然maven不知道你到底须要哪一套jar包:api
pom里面的仓库与setting.xml里的仓库功能是同样的。主要的区别在于,pom里的仓库是个性化的。好比一家大公司里的setting文件是公用的,全部项目都用一个setting文件,但各个子项目却会引用不一样的第三方库,因此就须要在pom里设置本身须要的仓库地址。服务器
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,若是第一个条件知足了,那么后面就不会在进行匹配。