`
liu_swei
  • 浏览: 51614 次
  • 性别: Icon_minigender_1
  • 来自: 济南
社区版块
存档分类
最新评论

maven 配置篇 之 settings.xml

阅读更多

maven2 需要配置的文件主要集中在pom.xmlsettings.xml中。
   
settings.xmlmaven相当于全局性的配置,用于所有的目。在maven2中存在两个 settings.xml,一个位于maven2的安装目conf下面,作全局性配置。团队设置,保持一致的定关键,所以 maven2/conf下面的settings.xml就作为团队共同的配置文件。保所有的团队有相同的配置。当然个成,都需要特殊的 自定义设置,如用信息,所以另外一个settings.xml就作本地配置。默的位置:${user.dir} /.m2/settings.xml目中(${user.dir} 指windows 中的用)。
    settings.xml基本
构如下:
    <settings 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/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不能使用于pom.xml,所以通此配置来保存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>

  • id:server id,用于匹配distributionManagementid,比重要。
  • username, password:用于登此服器的用名和密
  • privateKey, passphraseprivate key,以及passphrase
  • filePermissions, directoryPermissions:当文件或者目录创建后,需要使用访问。参照unix文件可,如664775
Mirrors
表示,指定像,用于增加其他
  <mirrors>
    <mirror>
      <id>planetmirror.com</id>
      <name>PlanetMirror Australia</name>
      <url>http://downloads.planetmirror.com/pub/maven2</url>
      <mirrorOf>central</mirrorOf>
    </mirror>
  </mirrors>
  • id,name:唯一的志,用于区别镜
  • url:像的url
  • mirrorOf:此像指向的服id
Proxies
置,主要用于无法直接访问中心的配置。
 
<proxies>
    <proxy>
      <id>myproxy</id>
      <active>true</active>
      <protocol>http</protocol>
      <host>proxy.somewhere.com</host>
      <port>8080</port>
      <username>proxyuser</username>
      <password>somepassword</password>
      <nonProxyHosts>*.google.com|ibiblio.org</nonProxyHosts>
    </proxy>
  </proxies>
  • id:代理的
  • active:是否激活代理
  • protocol, host, port:protocol://host:port 代理
  • username, password:用名和密
  • nonProxyHosts: 不需要代理的host
Profiles
 
似于pom.xml中的profile元素,主要包括activation,repositories,pluginRepositories properties元素
 
刚开始接触的候,可能会比迷惑,其实这maven2中比较强大的功能。从字面上来,就是个性配置。
 
独定profile后,并不会生效,需要通过满足条件来激活。
 
repositories pluginRepositories
 
其他开发库和插件开发库团队,肯定有自己的开发库。可以通此配置来定
 
如下的配置,定了本地开发库,用于release 布。
    <repositories>
        <repository>
          <id>repo-local</id>
       <name>Internal
开发库</name>
       <url>http://58.20.54.58/content/groups/treleases</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>http://58.20.54.58/content/groups/tsnapshots</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(注:releasesnapshot的区release一般是比较稳定的版本,而snapshot基本上不定,只是作快照)

properties
  maven
propertiesplaceholder,如antproperties
包括以下的5种类
1.        env.X,返回当前的
2.        project.x:返回pom中定的元素,如project.version
3.        settings.x:返回settings.xml中定的元素
4.        java 属性:所有经过java.lang.System.getProperties()返回的
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>
  • jdk:如果匹配指定的jdk版本,将会激活
  • os:操作系
  • property:如果maven检测到相的属性
  • file: 用于判断文件是否存在或者不存在

除了使用activation来激活profile,同可以通activeProfiles来激活
Active Profiles
表示激活的profile,profile id来指定。
  <activeProfiles>
    <activeProfile>env-test</activeProfile>
指定的profile id
  </activeProfiles>
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics