Maven中settings.xml与pom.xml文件的理解

一.settings.xml

maven的配置文件settings.xml存在于两个地方:

1.安装的地方:${M2_HOME}/conf/settings.xml         全局配置

2.用户的目录:${user.home}/.m2/settings.xml          用户配置

全局配置:对操作系统的所有使用者生效

用户配置:对当前用户有效

如果两者都存在,则内容会合并,并且用户范围的settings会覆盖全局。

 

在这里我们只谈经常使用的<localRepository >,< servers >,< mirrors >,< profiles >几个节点。

  1. localRepository :本地仓库。默认为${user.home}/.m2/repository,一个构件只有在本地仓库存放之后,才能由Maven项目使用

  2. servers

   <servers>    

 <!--服务器元素包含配置服务器时需要的信息  --> 

        <server>     

   <!--这是server的id(注意不是用户登陆的id),该id与distributionManagement中repository元素的id相匹配。 --> 

            <id>server001</id>       

   <!--鉴权用户名。鉴权用户名和鉴权密码表示服务器认证所需要的登录名和密码。  --> 

            <username>my_login</username> 

   <!--鉴权密码 。鉴权用户名和鉴权密码表示服务器认证所需要的登录名和密码。  --> 

            <password>my_password</password>    

 <!--鉴权时使用的私钥位置。和前两个元素类似,私钥位置和私钥密码指定了一个私钥的路径(默认是/home/hudson/.ssh/id_dsa)以及如果需要的话,一个密钥 -->

 <!--将来passphrase和password元素可能会被提取到外部,但目前它们必须在settings.xml文件以纯文本的形式声明。  --> 

           <privateKey>${usr.home}/.ssh/id_dsa</privateKey> 

   <!--鉴权时使用的私钥密码。 --> 

            <passphrase>some_passphrase</passphrase> 

   <!--文件被创建时的权限。如果在部署的时候会创建一个仓库文件或者目录,这时候就可以使用权限(permission)。--> 

   <!--这两个元素合法的值是一个三位数字,其对应了unix文件系统的权限,如664,或者775。  --> 

            <filePermissions>664</filePermissions> 

   <!--目录被创建时的权限。  --> 

            <directoryPermissions>775</directoryPermissions>

   <!--传输层额外的配置项  --> 

            <configuration></configuration>         

        </server> 

3.mirror

<!--为仓库列表配置的下载镜像列表。  --> 

    <mirrors>

        <!--给定仓库的下载镜像。  --> 

        <mirror>     

            <!--该镜像的唯一标识符。id用来区分不同的mirror元素。  --> 

            <id>planetmirror.com</id>     

            <!--镜像名称  --> 

            <name>PlanetMirror Australia</name> 

            <!--该镜像的URL。构建系统会优先考虑使用该URL,而非使用默认的服务器URL。  --> 

            <url>http://downloads.planetmirror.com/pub/maven2</url>      

            <!--被镜像的服务器的id。例如,如果我们要设置了一个Maven中央仓库(http://repo1.maven.org/maven2)的镜像,--> 

            <!--就需要将该元素设置成central。这必须和中央仓库的id central完全一致。 --> 

            <mirrorOf>central</mirrorOf>           

        </mirror>    

    </mirrors>  

4.profiles节点

 <profiles>        

        <!--根据环境参数来调整的构件的配置 --> 

        <profile>          

            <!--该配置的唯一标识符。  --> 

            <id>test</id>       

            <!--自动触发profile的条件逻辑。Activation是profile的开启钥匙。--> 

            <!--如POM中的profile一样,profile的力量来自于它能够在某些特定的环境中自动使用某些特定的值;这些环境通过activation元素指定。--> 

            <!--activation元素并不是激活profile的唯一方式。settings.xml文件中的activeProfile元素可以包含profile的id。--> 

            <!--profile也可以通过在命令行,使用-P标记和逗号分隔的列表来显式的激活(如,-P test)。 --> 

            <activation>         

                <!--profile默认是否激活的标识 --> 

                <activeByDefault>false</activeByDefault>         

                <!--activation有一个内建的java版本检测,如果检测到jdk版本与期待的一样,profile被激活。 --> 

                <jdk>1.7</jdk>           

                <!--当匹配的操作系统属性被检测到,profile被激活。os元素可以定义一些操作系统相关的属性。 --> 

                <os>    

                    <!--激活profile的操作系统的名字  --> 

                    <name>Windows XP</name>               

                    <!--激活profile的操作系统所属家族(如 'windows')   --> 

                    <family>Windows</family> 

                    <!--激活profile的操作系统体系结构   --> 

                    <arch>x86</arch>    

                    <!--激活profile的操作系统版本 --> 

                    <version>5.1.2600</version>       

                </os> 

       <!--如果Maven检测到某一个属性(其值可以在POM中通过${名称}引用),其拥有对应的名称和值,Profile就会被激活。--> 

                <!--如果值字段是空的,那么存在属性名称字段就会激活profile,否则按区分大小写方式匹配属性值字段 --> 

                <property>   

                    <!--激活profile的属性的名称 --> 

                    <name>mavenVersion</name>         

                    <!--激活profile的属性的值  --> 

                    <value>2.0.3</value>       

                </property>    

                <!--提供一个文件名,通过检测该文件的存在或不存在来激活profile。missing检查文件是否存在,如果不存在则激活profile。--> 

                <!--另一方面,exists则会检查文件是否存在,如果存在则激活profile。 --> 

                <file>      

                    <!--如果指定的文件存在,则激活profile。  --> 

                    <exists>/usr/local/hudson/hudson-home/jobs/maven-guide-zh-to-production/workspace/</exists>     

                    <!--如果指定的文件不存在,则激活profile。 --> 

                    <missing>/usr/local/hudson/hudson-home/jobs/maven-guide-zh-to-production/workspace/</missing> 

                </file>     

            </activation> 

             <!--对应profile的扩展属性列表。Maven属性和Ant中的属性一样,可以用来存放一些值。这些值可以在POM中的任何地方使用标记${X}来使用,这里X是指属性的名称。--> 

            <!--属性有五种不同的形式,并且都能在settings.xml文件中访问。   --> 

            <!--1. env.X: 在一个变量前加上"env."的前缀,会返回一个shell环境变量。例如,"env.PATH"指代了$path环境变量(在Windows上是%PATH%)。  -->  

            <!--2. project.x:指代了POM中对应的元素值。      --> 

            <!--3. settings.x: 指代了settings.xml中对应元素的值。   --> 

            <!--4. Java System Properties: 所有可通过java.lang.System.getProperties()访问的属性都能在POM中使用该形式访问,   --> 

            <!--   如/usr/lib/jvm/java-1.6.0-openjdk-1.6.0.0/jre。      --> 

            <!--5. x: 在<properties/>元素中,或者外部文件中设置,以${someVar}的形式使用。  --> 

            <properties> 

                <!-- 如果这个profile被激活,那么属性${user.install}就可以被访问了 --> 

                <user.install>usr/local/winner/jobs/maven-guide</user.install> 

            </properties> 

            <!--远程仓库列表,它是Maven用来填充构建系统本地仓库所使用的一组远程项目。  --> 

            <repositories>   

                <!--包含需要连接到远程仓库的信息  --> 

                <repository> 

                    <!--远程仓库唯一标识 --> 

                    <id>codehausSnapshots</id> 

                    <!--远程仓库名称  --> 

                    <name>Codehaus Snapshots</name> 

                    <!--如何处理远程仓库里发布版本的下载 --> 

                    <releases>   

                        <!--true或者false表示该仓库是否为下载某种类型构件(发布版,快照版)开启。   --> 

                        <enabled>false</enabled> 

                        <!--该元素指定更新发生的频率。Maven会比较本地POM和远程POM的时间戳。这里的选项是:--> 

                        <!--always(一直),daily(默认,每日),interval:X(这里X是以分钟为单位的时间间隔),或者never(从不)。  --> 

                        <updatePolicy>always</updatePolicy>   

                        <!--当Maven验证构件校验文件失败时该怎么做:--> 

                        <!--ignore(忽略),fail(失败),或者warn(警告)。 --> 

                        <checksumPolicy>warn</checksumPolicy>        

                    </releases> 

                    <!--如何处理远程仓库里快照版本的下载。有了releases和snapshots这两组配置,POM就可以在每个单独的仓库中,为每种类型的构件采取不同的策略。--> 

                    <!--例如,可能有人会决定只为开发目的开启对快照版本下载的支持。参见repositories/repository/releases元素 --> 

                    <snapshots> 

                        <enabled /> 

                        <updatePolicy /> 

                        <checksumPolicy /> 

                    </snapshots> 

                    <!--远程仓库URL,按protocol://hostname/path形式  --> 

                    <url>http://snapshots.maven.codehaus.org/maven2</url>        

                    <!--用于定位和排序构件的仓库布局类型-可以是default(默认)或者legacy(遗留)。--> 

                    <!--Maven 2为其仓库提供了一个默认的布局;然而,Maven 1.x有一种不同的布局。我们可以使用该元素指定布局是default(默认)还是legacy(遗留)。  --> 

                    <layout>default</layout>       

                </repository>    

            </repositories> 

            <!--发现插件的远程仓库列表。仓库是两种主要构件的家。第一种构件被用作其它构件的依赖。这是中央仓库中存储的大部分构件类型。另外一种构件类型是插件。--> 

            <!--Maven插件是一种特殊类型的构件。由于这个原因,插件仓库独立于其它仓库。pluginRepositories元素的结构和repositories元素的结构类似。--> 

            <!--每个pluginRepository元素指定一个Maven可以用来寻找新插件的远程地址。 --> 

            <pluginRepositories>     

                <!--包含需要连接到远程插件仓库的信息.参见profiles/profile/repositories/repository元素的说明 --> 

                <pluginRepository> 

                    <releases> 

                        <enabled /> 

                        <updatePolicy /> 

                        <checksumPolicy /> 

                    </releases>    

                    <snapshots> 

                        <enabled /> 

                        <updatePolicy /> 

                        <checksumPolicy /> 

                    </snapshots> 

                    <id /> 

                    <name /> 

                    <url /> 

                    <layout /> 

                </pluginRepository> 

            </pluginRepositories> 

            <!--手动激活profiles的列表,按照profile被应用的顺序定义activeProfile。 该元素包含了一组activeProfile元素,每个activeProfile都含有一个profile id。--> 

            <!--任何在activeProfile中定义的profile id,不论环境设置如何,其对应的 profile都会被激活。--> 

            <!--如果没有匹配的profile,则什么都不会发生。例如,env-test是一个activeProfile,则在pom.xml(或者profile.xml)中对应id的profile会被激活。--> 

            <!--如果运行过程中找不到这样一个profile,Maven则会像往常一样运行。  --> 

            <activeProfiles>       

                <activeProfile>env-test</activeProfile>        

            </activeProfiles>    

        </profile> 

    </profiles> 

 

二.pox.xml

<?xml version="1.0" encoding="UTF-8"?>

<project xmlns="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.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">

<modelVersion>4.0.0</modelVersion> //pom版本模型(maven2/3只能为4.0.0)

   //基本配置

        <groupId>com.example</groupId> //组ID,用于定位

       <artifactId>mavendemo02</artifactId> //组中唯一ID用于定位

       <version>1.0-SNAPSHOT</version> //项目版本

<packaging>war</packaging> //项目打包方式

  //项目信息

<name>mavendemo02 Maven Webapp</name> //项目名

<!-- FIXME change it to the project's website -->

<url>http://www.example.com</url> // 主页url

//用于定义pom常量

<properties>

         <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>

         <maven.compiler.source>1.7</maven.compiler.source>

        <maven.compiler.target>1.7</maven.compiler.target>

</properties>

//依赖配置

<dependencies>

        <dependency>

               <groupId>junit</groupId>

              <artifactId>junit</artifactId>

              <version>4.11</version>

              <scope>test</scope>

        </dependency>

</dependencies>

//构建配置

<build>

               <finalName>mavendemo02</finalName>

<pluginManagement><!-- lock down plugins versions to avoid using Maven defaults (may be moved to parent pom) -->

//使用插件列表

<plugins>

             <plugin>

                         <artifactId>maven-clean-plugin</artifactId>

                        <version>3.0.0</version>

            </plugin>

<!-- see http://maven.apache.org/ref/current/maven-core/default-bindings.html#Plugin_bindings_for_war_packaging -->

             <plugin>

                       <artifactId>maven-resources-plugin</artifactId>

                       <version>3.0.2</version>

             </plugin>

            <plugin>

                      <artifactId>maven-compiler-plugin</artifactId>

                     <version>3.7.0</version>

           </plugin>

           <plugin>

                     <artifactId>maven-surefire-plugin</artifactId>

                    <version>2.20.1</version>

          </plugin>

          <plugin>

                    <artifactId>maven-war-plugin</artifactId>

                   <version>3.2.0</version>

         </plugin>

          <plugin>

                   <artifactId>maven-install-plugin</artifactId>

                   <version>2.5.2</version>

         </plugin>

         <plugin>

                    <artifactId>maven-deploy-plugin</artifactId>

                   <version>2.8.2</version>

         </plugin>

</plugins>

</pluginManagement>

</build>

</project>

 

猜你喜欢

转载自blog.csdn.net/xiaojinsanMM/article/details/81112739