這是我參與更文挑戰的第12天,活動詳情查看: 更文挑戰html
[TOC]linux
maven是一個項目構建和管理的工具,提供了幫助管理 構建、文檔、報告、依賴、scms、發佈、分發的方法。能夠方便的編譯代碼、進行依賴管理、管理二進制庫等等。 maven的好處在於能夠將項目過程規範化、自動化、高效化以及強大的可擴展性 利用maven自身及其插件還能夠得到代碼檢查報告、單元測試覆蓋率、實現持續集成等等。spring
用於指定存儲jar包的路徑,換句話說就是本地倉庫地址,若是不設置默認是${user.home}/.m2/repository
。${user.home}是系統環境變量apache
<localRepository>E:/.m2</localRepository>
複製代碼
表示是否使用交互模式,默認是true;若是設爲false,那麼當Maven須要用戶進行輸入的時候,它會使用一個默認值。windows
<interactiveMode>true</interactiveMode>
複製代碼
表示Maven是否須要在離線模式下運行。若是構建系統須要在離線模式下運行,則爲true,默認爲false。當因爲網絡設置緣由或者安全因素,構建服務器不能鏈接遠程倉庫的時候,咱們就能夠設置成false,這樣安全安全
<offline>false</offline>
複製代碼
pluginGroup
列表。默認maven中有org.apache.maven.plugins
和org.codehaus.mojo
兩個pluginGroup
。表示當經過plugin的前綴來解析plugin的時候到哪裏尋找。pluginGroup元素指定的是plugin的groupIdpluginGroups
裏pluginGroup
列表和配置中artifactId進行一一匹配。匹配到下載。這裏若是出現重複也不要緊,咱們使用的時候使用對了就好了。<plugins>
<plugin>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<source>1.7</source>
<target>1.7</target>
</configuration>
</plugin>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
複製代碼
其下面能夠定義一系列的proxy子元素,表示Maven在進行聯網時須要使用到的代理。當設置了多個代理的時候第一個標記active爲true的代理將會被使用服務器
<proxies>
<!--代理元素包含配置代理時須要的信息-->
<proxy>
<!--代理的惟必定義符,用來區分不一樣的代理元素。-->
<id>myproxy</id>
<!--該代理是不是激活的那個。true則激活代理。當咱們聲明瞭一組代理,而某個時候只須要激活一個代理的時候,該元素就能夠派上用處。 -->
<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>
複製代碼
<servers>
<!--服務器元素包含配置服務器時須要的信息 -->
<server>
<!--這是server的id(注意不是用戶登錄的id),該id與distributionManagement中repository元素的id相匹配。-->
<id>server001</id>
<!--鑑權用戶名。鑑權用戶名和鑑權密碼錶示服務器認證所須要的登陸名和密碼。 -->
<username>my_login</username>
<!--鑑權密碼 。鑑權用戶名和鑑權密碼錶示服務器認證所須要的登陸名和密碼。密碼加密功能已被添加到2.1.0 +。詳情請訪問密碼加密頁面-->
<password>my_password</password>
<!--鑑權時使用的私鑰位置。和前兩個元素相似,私鑰位置和私鑰密碼指定了一個私鑰的路徑(默認是${user.home}/.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>
</server>
</servers>
複製代碼
<distributionManagement>
<repository>
<id>release-repository</id>
<name>Release Repository</name>
<url>http://www.myrepository.com/repositories/releases</url>
</repository>
<snapshotRepository>
<id>snapshot-repository</id>
<name>Snapshot Repository</name>
<url>http://www.myrepository.com/repositories/snapshots</url>
</snapshotRepository>
</distributionManagement>
複製代碼
上面配置了SNAPSHOT包的上傳路徑和RELEASE包的上傳遠程地址,可是咱們的這個遠程地址有權限,最基本的就是須要帳號和密碼。這個時候咱們不能暴露在項目中,咱們就能夠在maven的setting中設置了,就是經過servers標籤實現,markdown
<servers>
<server>
<id>snapshot-repository</id>
<username>snapshot</username>
<password>123456</password>
</server>
<server>
<id>release-repository</id>
<username>release</username>
<password>123456</password>
</server>
</servers>
複製代碼
注意一點兩邊的id必須匹配才能夠。 maven對密碼進行加密處理網絡
id:是用來區別mirror的,全部的mirror不能有相同的idssh
mirrorOf:用來表示該mirror是關聯的哪個倉庫,其值爲其關聯倉庫的id。當要同時關聯多個倉庫時,這多個倉庫之間能夠用逗號隔開;當要關聯全部的倉庫時,可使用「」表示;當要關聯除某一個倉庫之外的其餘全部倉庫時,能夠表示爲「,!repositoryId」;當要關聯不是localhost或用file請求的倉庫時,能夠表示爲「external:*」。
url:表示該鏡像的url。當Maven在創建系統的時候就會使用這個url來鏈接到咱們的遠程倉庫。
<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://repo.maven.apache.org/maven2/)的鏡像,就須要將該元素設置成central。這必須和中央倉庫的id central徹底一致。-->
<mirrorOf>central</mirrorOf>
</mirror>
</mirrors>
複製代碼
針對於特定項目的profile配置咱們能夠定義在該項目的pom.xml中。
針對於特定用戶的profile配置,咱們能夠在用戶的settings.xml文件中定義profile。該文件在用戶家目錄下的「.m2」目錄下。
全局的profile配置。全局的profile是定義在Maven安裝目錄下的「conf/settings.xml」文件中的
```
<profiles>
<profile>
<id>zxh1</id>
<properties>
<zxhtom>single</zxhtom>
</properties>
</profile>
<profile>
<id>zxh2</id>
<properties>
<zxhtom>double</zxhtom>
</properties>
</profile>
<profiles>
```
+ 環境激活
在部署是符合這些環境要求的電腦則會獲取到該profile的配置。這樣咱們windows上配置和Linux上就不一樣了。
```
<activation>
<os>
<!--激活profile的操做系統的名字 -->
<name>Windows 7</name>
<!--激活profile的操做系統所屬家族(如 'windows') -->
<family>Windows</family>
<!--激活profile的操做系統體系結構 -->
<arch>x64</arch>
<!--激活profile的操做系統版本-->
<version>x.x.x..</version>
</os>
</activation>
```
+ 默認激活
* activeByDefault激活
下面的配置在咱們部署是沒有指定profile時,zxh1這個profile就會成爲默認的profile,若是咱們指定了那麼zxh1就不會被啓用。這裏要注意這裏是不啓用。和後面的activeProfiles激活不一樣。
```
<profiles>
<profile>
<id>zxh1</id>
<properties>
<zxhtom>single</zxhtom>
</properties>
<activation>
<activeByDefault>true</activeByDefault>
</activation>
</profile>
<profile>
<id>zxh2</id>
<properties>
<zxhtom>double</zxhtom>
</properties>
</profile>
</profiles>
```
* activeProfiles激活
以下圖中咱們定義zxh1爲激活狀態,另外咱們若是在經過參數或者其餘條件激活了zxh2,這裏zxh1和zxh2都是出於激活的,並不像activeByDefault激活那樣直接中止了。而是二者的覆蓋值合併。
```
<profiles>
<profile>
<id>zxh1</id>
<properties>
<zxhtom>single</zxhtom>
</properties>
</profile>
<profile>
<id>zxh2</id>
<properties>
<zxhtom>double</zxhtom>
</properties>
</profile>
<profiles>
<activeProfiles>
<activeProfile>zxh1</activeProfile>
</activeProfiles>
```
檔以下在activeProfiles中配置了多個profile是,maven選擇的是後者覆蓋合併前者的方式,也就是將zxh1和zxh2合併,相同值去後者的值。
```
<profiles>
<profile>
<id>zxh1</id>
<properties>
<zxhtom>single</zxhtom>
</properties>
</profile>
<profile>
<id>zxh2</id>
<properties>
<zxhtom>double</zxhtom>
</properties>
</profile>
<profiles>
<activeProfiles>
<activeProfile>zxh1</activeProfile>
<activeProfile>zxh2</activeProfile>
</activeProfiles>
```
+ 文件激活
```
<activation>
<file>
<!--若是指定的文件存在,則激活profile。 -->
<exists>${basedir}/file2.properties</exists>
<!--若是指定的文件不存在,則激活profile。-->
<missing>${basedir}/file1.properties</missing>
</file>
</activation>
```
複製代碼