在Maven中,任何一個依賴、插件或者項目構建的輸出,均可以稱之爲構件。apache
Maven在某個統一的位置存儲全部項目的共享的構件,這個統一的位置,咱們就稱之爲倉庫。(倉庫就是存放依賴和插件的地方)瀏覽器
任何的構件都有惟一的座標,Maven根據這個座標定義了構件在倉庫中的惟一存儲路徑,緩存
解讀Maven在倉庫中的存儲路徑:安全
1.基於groupId準備路徑,將句點分隔符轉成路徑分隔符,就是將 "." 轉換成 "/" ; example: org.testng --->org/testngmaven
2.基於artifactId準備路徑,將artifactId鏈接到後面:org/testng/testng佈局
3.使用version準備路徑,將version鏈接到後面:org/testng/testng/5.8測試
4.將artifactId於version以分隔符連字號鏈接到後面:org/testng/testng/5.8/tesng-5.8ui
5.判斷若是構件有classifier,就要在 第4項 後增長 分隔符連字號 再加上 classifier,org/testng/testng/5.8/tesng-5.8-jdk5this
6.檢查構件的extension,若是extension存在,則加上句點分隔符和extension,而extension是由packing決定的,org/testng/testng/5.8/tesng-5.8-jdk5.jarurl
到這裏咱們就明白了Maven 對於構件存儲的細節。
maven的倉庫只有兩大類:
1.本地倉庫
2.遠程倉庫,在遠程倉庫中又分紅了3種:
2.1 中央倉庫
2.2 私服
2.3 其它公共庫
顧名思義,就是Maven在本地存儲構件的地方。
注:maven的本地倉庫,在安裝maven後並不會建立,它是在第一次執行maven命令的時候才被建立
maven本地倉庫的默認位置:不管是Windows仍是Linux,在用戶的目錄下都有一個.m2/repository/的倉庫目錄,這就是Maven倉庫的默認位置
如何更改maven默認的本地倉庫的位置:這裏要引入一個新的元素:localRepository,它是存在於maven的settings.xml文件中
1.1 更改配置用戶範圍的本地倉庫:
先在/.m2/目錄下建立settings.xml文件,而後在~/.m2/settings.xml,設置localRepository元素的值爲想要的倉庫地址
<settings xmlns="http://maven.apache.org/SETTINGS/1.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/SETTINGS/1.0.0 http://maven.apache.org/xsd/settings-1.0.0.xsd"> <!-- localRepository | The path to the local repository maven will use to store artifacts. | | Default: ${user.home}/.m2/repository--> <localRepository>D:/myworkspace/maven_repository</localRepository> <!-- interactiveMode | This will determine whether maven prompts you when it needs input. If set to false, | maven will use a sensible default value, perhaps based on some other setting, for | the parameter in question. | | Default: true <interactiveMode>true</interactiveMode> --> ... ...
1.2 更改配置全局範圍的本地倉庫:
在M2_HOME/conf/settings.xml(D:\soft\maven\apache-maven-3.3.3\confsettings.xml\settings.xml)中更改配置,更改配置的方法同上
注:此時更改後,全部的用戶都會受到影響,並且若是maven進行升級,那麼全部的配置都會被清除,因此要提早複製和備份M2_HOME/conf/settings.xml文件
故:通常狀況下不推薦配置全局的settings.xml
這個確實是有個優先級的,應該是pom>用戶級別>全局級別
例:若是pom中不配置,就取用戶級別,若是用戶級別也沒有配置,就取全局級別
2.1 說到遠程倉庫先從 最核心的中央倉庫開始,中央倉庫是默認的遠程倉庫,maven在安裝的時候,自帶的就是中央倉庫的配置
在maven的聚合與繼承中咱們說過,全部的maven項目都會繼承超級pom,具體的說,包含了下面配置的pom咱們就稱之爲超級pom
<repositories> <repository> <id>central</id> <name>Central Repository</name> <url>http://repo.maven.apache.org/maven2</url> <layout>default</layout> <snapshots> <enabled>false</enabled> </snapshots> </repository> </repositories>
中央倉庫包含了絕大多數流行的開源Java構件,以及源碼、做者信息、SCM、信息、許可證信息等。通常來講,簡單的Java項目依賴的構件均可以在這裏下載獲得。
私服是一種特殊的遠程倉庫,它是架設在局域網內的倉庫服務,私服代理廣域網上的遠程倉庫,供局域網內的Maven用戶使用。當Maven須要下載構件的時候,它從私服請求,若是私服上不存在該構件,則從外部的遠程倉庫下載,緩存在私服上以後,再爲Maven的下載請求提供服務。咱們還能夠把一些沒法從外部倉庫下載到的構件上傳到私服上。
Maven私服的 個特性:
1.節省本身的外網帶寬:減小重複請求形成的外網帶寬消耗
2.加速Maven構件:若是項目配置了不少外部遠程倉庫的時候,構建速度就會大大下降
3.部署第三方構件:有些構件沒法從外部倉庫得到的時候,咱們能夠把這些構件部署到內部倉庫(私服)中,供內部maven項目使用
4.提升穩定性,加強控制:Internet不穩定的時候,maven構建也會變的不穩定,一些私服軟件還提供了其餘的功能
5.下降中央倉庫的負荷:maven中央倉庫被請求的數量是巨大的,配置私服也能夠大大下降中央倉庫的壓力
當前主流的maven私服:
1.Apache的Archiva
2.JFrog的Artifactory
3.Sonatype的Nexus
配置遠程倉庫將引入新的配置元素:<repositories> <repository>
在<repositories>元素下,可使用 <repository>子元素聲明一個或者多個遠程倉庫。
例子:
<repositories> <repository> <id>jboss</id> <name>JBoss Repository</name> <url>http://repository.jboss.com/maven2/</url> <releases> <updatePolicy>daily</updatePolicy><!-- never,always,interval n --> <enabled>true</enabled> <checksumPolicy>warn</checksumPolicy><!-- fail,ignore --> </releases> <snapshots> <enabled>false</enabled> </snapshots> <layout>default</layout> </repository> </repositories>
<updatePolicy>元素:表示更新的頻率,值有:never, always,interval,daily, daily 爲默認值
<checksumPolicy>元素:表示maven檢查和檢驗文件的策略,warn爲默認值
出於安全方面的考慮,有時咱們要對遠程倉庫的訪問進行認證,通常將認證信息配置在settings.xml中:
<servers> <server> <id>same with repository id in pom</id> <username>username</username> <password>pwd</password> </server> </servers>
注:這裏的id必須與POM中須要認證的repository元素的Id一致。
如何將生成的項目部署到遠程倉庫
完成這項工做,也須要在POM中進行配置,這裏有新引入了一個元素:<distributionManagement>
distributionManagement包含了2個子元素:repository和snapshotRepository, 前者表示發佈版本構件的倉庫,後者表示快照版本的倉庫
這兩個元素都須要配置 id(該遠程倉庫的惟一標識),name,url(表示該倉庫的地址)
向遠程倉庫中部署構件,須要進行認證。配置同上
配置正確後運行: mvn clean deploy
正確的看待快照
以前咱們在配置pom的時候,對於快照的配置都很謹慎,或者說不多用快照的版本,緣由是它還很不穩定,極容易給咱們的系統帶來未知的錯誤,讓咱們很難查找。其實快照版本也並非一無可取,快照最大的用途是用在開發的過程當中,尤爲是有模塊依賴的時候,好比說AB兩個模塊同時開發,A依賴於B,開發過程當中AB都是持續集成的開發,不斷的修改POM文件和構建工程,這時候版本同步就成了一個很大的問題。使用快照就能夠達到這一目的。
其實在快照版本在發佈的過程當中,Maven會自動爲構件以當前時間戳作標記,有了這個時間戳,咱們就能夠隨時找到最新的快照版本,這樣也就解決剛纔說的 協做開發的問題。
至於A如何檢查B的更新,剛剛在講配置的時候說過,快照配置中有一個元素能夠控制檢查更新的頻率------updatePolicy
咱們也可使用命令行加參數的形式強制執行讓maven檢查更新:
mvn clean install-U
maven究竟是如何從倉庫中解析構件的呢?----maven從倉庫解析依賴的機制
1. 當依賴的範圍是system的時候,Maven直接從本地文件系統解析構件
2. 根據依賴座標計算倉庫路徑後,嘗試直接從本地倉庫尋找構件,若是發現相應構件,則解析成功
3. 在本地倉庫不存在相應的構件狀況下,若是依賴的版本是顯示的發佈版本構件,則遍歷全部的遠程倉庫,發現後下載使用
4. 若是依賴的版本是RELEASE或LATEST, 則基於更新策略讀取全部遠程倉庫的元數據,將其於本地倉庫的對應元數據合併後,計算出RELEASE或者LATEST的真實值,而後基於這個真實值檢查本地倉庫
5. 若是依賴的版本是SNAPSHOT, 則基於更新策略讀取全部遠程倉庫的元數據, 將其與本地倉庫的對應元數據合併後,獲得最新快照版本的值,而後基於該值檢查本地倉庫或從遠程倉庫下載
6. 若是最後解析到的構件版本是時間戳格式的快照,則複製其時間戳格式的文件 至 非時間戳格式,並使用該非時間戳格式的構件
注:必定要記得<release> <enabled> & <snapshot> <enabled> ,對於快照也是同樣
在POM的依賴聲明的時候不推薦使用LATEST & RELEASE, 在Maven3中也再也不支持在插件配置中使用LATEST & RELEASE, 若是不設置插件版本,那麼最終版本和release同樣,
maven只會解析最新的發佈版本構建。
1.遠程倉庫的配置
在平時的開發中,咱們每每不會使用默認的中央倉庫,默認的中央倉庫訪問的速度比較慢,訪問的人或許不少,有時候也沒法知足咱們項目的需求,可能項目須要的某些構件中央倉庫中是沒有的,而在其餘遠程倉庫中有,如JBoss Maven倉庫。這時,能夠在pom.xml中配置該倉庫,代碼以下:
1 <!-- 配置遠程倉庫 --> 2 <repositories> 3 <repository> 4 <id>jboss</id> 5 <name>JBoss Repository</name> 6 <url>http://repository.jboss.com/maven2/</url> 7 <releases> 8 <enabled>true</enabled> 9 <updatePolicy>daily</updatePolicy> 10 </releases> 11 <snapshots> 12 <enabled>false</enabled> 13 <checksumPolicy>warn</checksumPolicy> 14 </snapshots> 15 <layout>default</layout> 16 </repository> 17 </repositories>
repository:在repositories元素下,可使用repository子元素聲明一個或者多個遠程倉庫。
id:倉庫聲明的惟一id,尤爲須要注意的是,Maven自帶的中央倉庫使用的id爲central,若是其餘倉庫聲明也使用該id,就會覆蓋中央倉庫的配置。
name:倉庫的名稱,讓咱們直觀方便的知道倉庫是哪一個,暫時沒發現其餘太大的含義。
url:指向了倉庫的地址,通常來講,該地址都基於http協議,Maven用戶均可以在瀏覽器中打開倉庫地址瀏覽構件。
releases和snapshots:用來控制Maven對於發佈版構件和快照版構件的下載權限。須要注意的是enabled子元素,該例中releases的enabled值爲true,表示開啓JBoss倉庫的發佈版本下載支持,而snapshots的enabled值爲false,表示關閉JBoss倉庫的快照版本的下載支持。根據該配置,Maven只會從JBoss倉庫下載發佈版的構件,而不會下載快照版的構件。
layout:元素值default表示倉庫的佈局是Maven2及Maven3的默認佈局,而不是Maven1的佈局。基本不會用到Maven1的佈局。
其餘:對於releases和snapshots來講,除了enabled,它們還包含另外兩個子元素updatePolicy和checksumPolicy。
元素updatePolicy用來配置Maven從遠處倉庫檢查更新的頻率,默認值是daily,表示Maven天天檢查一次。其餘可用的值包括:never-從不檢查更新;always-每次構建都檢查更新;interval:X-每隔X分鐘檢查一次更新(X爲任意整數)。
元素checksumPolicy用來配置Maven檢查校驗和文件的策略。當構建被部署到Maven倉庫中時,會同時部署對應的檢驗和文件。在下載構件的時候,Maven會驗證校驗和文件,若是校驗和驗證失敗,當checksumPolicy的值爲默認的warn時,Maven會在執行構建時輸出警告信息,其餘可用的值包括:fail-Maven遇到校驗和錯誤就讓構建失敗;ignore-使Maven徹底忽略校驗和錯誤。
2.遠程倉庫的認證
大部分公共的遠程倉庫無須認證就能夠直接訪問,但咱們在平時的開發中每每會架設本身的Maven遠程倉庫,出於安全方面的考慮,咱們須要提供認證信息才能訪問這樣的遠程倉庫。配置認證信息和配置遠程倉庫不一樣,遠程倉庫能夠直接在pom.xml中配置,可是認證信息必須配置在settings.xml文件中。這是由於pom每每是被提交到代碼倉庫中供全部成員訪問的,而settings.xml通常只存在於本機。所以,在settings.xml中配置認證信息更爲安全。
1 <settings> 2 2 ... 3 3 <!--配置遠程倉庫認證信息--> 4 4 <servers> 5 5 <server> 6 6 <id>releases</id> 7 7 <username>admin</username> 8 8 <password>admin123</password> 9 9 </server> 10 10 </servers> 11 11 ... 12 12 </settings>
上面代碼咱們配置了一個id爲releases的遠程倉庫認證信息。Maven使用settings.xml文件中的servers元素及其子元素server配置倉庫認證信息。認證用戶名爲admin,認證密碼爲admin123。這裏的關鍵是id元素,settings.xml中server元素的id必須與pom.xml中須要認證的repository元素的id徹底一致。正是這個id將認證信息與倉庫配置聯繫在了一塊兒。
3.部署構件至遠程倉庫
咱們使用本身的遠程倉庫的目的就是在遠程倉庫中部署咱們本身項目的構件以及一些沒法從外部倉庫直接獲取的構件。這樣才能在開發時,供其餘對團隊成員使用。
Maven除了能對項目進行編譯、測試、打包以外,還能將項目生成的構件部署到遠程倉庫中。首先,須要編輯項目的pom.xml文件。配置distributionManagement元素,代碼以下:
1 <distributionManagement> 2 <repository> 3 <id>releases</id> 4 <name>public</name> 5 <url>http://59.50.95.66:8081/nexus/content/repositories/releases</url> 6 </repository> 7 <snapshotRepository> 8 <id>snapshots</id> 9 <name>Snapshots</name> 10 <url>http://59.50.95.66:8081/nexus/content/repositories/snapshots</url> 11 </snapshotRepository> 12 </distributionManagement>
distributionManagement包含repository和snapshotRepository子元素,前者表示發佈版本(穩定版本)構件的倉庫,後者表示快照版本(開發測試版本)的倉庫。這兩個元素都須要配置id、name和url,id爲遠程倉庫的惟一標識,name是爲了方便人閱讀,關鍵的url表示該倉庫的地址。
往遠程倉庫部署構件的時候,每每須要認證,配置認證的方式同上。
配置正確後,運行命令mvn clean deploy,Maven就會將項目構建輸出的構件部署到配置對應的遠程倉庫,若是項目當前的版本是快照版本,則部署到快照版本的倉庫地址,不然就部署到發佈版本的倉庫地址。
快照版本和發佈版本的區別請自行上百度查閱資料。
4.配置遠程倉庫的鏡像
若是倉庫X能夠提供倉庫Y存儲的全部內容,那麼就能夠認爲X是Y的一個鏡像。換句話說,任何一個能夠從倉庫Y得到的構件,都可以從它的鏡像中獲取。舉個例子,http://maven.oschina.net/content/groups/public/ 是中央倉庫http://repo1.maven.org/maven2/ 在中國的鏡像,因爲地理位置的因素,該鏡像每每可以提供比中央倉庫更快的服務。所以,能夠配置Maven使用該鏡像來替代中央倉庫。編輯settings.xml,代碼以下:
1 <mirrors> 2 <mirror> 3 <id>maven.oschina.net</id> 4 <name>maven mirror in China</name> 5 <url>http://maven.oschina.net/content/groups/public/</url> 6 <mirrorOf>central</mirrorOf> 7 </mirror> 8 </mirrors>
該例中,mirrorOf的值爲central,表示該配置爲中央倉庫的鏡像,任何對於中央倉庫的請求都會轉至該鏡像,用戶也可使用一樣的方法配置其餘倉庫的鏡像。id表示鏡像的惟一標識符,name表示鏡像的名稱,url表示鏡像的地址。
關於鏡像的一個更爲常見的用法是結合私服。因爲私服能夠代理任何外部的公共倉庫(包括中央倉庫),所以,對於組織內部的Maven用戶來講,使用一個私服地址就等於使用了全部須要的外部倉庫,這能夠將配置集中到私服,從而簡化Maven自己的配置。在這種狀況下,任何須要的構件均可以從私服得到,私服就是全部倉庫的鏡像。這時,能夠配置這樣的一個鏡像:
1 <!--配置私服鏡像--> 2 <mirrors> 3 <mirror> 4 <id>nexus</id> 5 <name>internal nexus repository</name> 6 <url>http://183.238.2.182:8081/nexus/content/groups/public/</url> 7 <mirrorOf>*</mirrorOf> 8 </mirror> 9 </mirrors>
該例中<mirrorOf>的值爲星號,表示該配置是全部Maven倉庫的鏡像,任何對於遠程倉庫的請求都會被轉至http://183.238.2.182:8081/nexus/content/groups/public/。若是該鏡像倉庫須要認證,則配置一個id爲nexus的認證信息便可。
須要注意的是,因爲鏡像倉庫徹底屏蔽了被鏡像倉庫,當鏡像倉庫不穩定或者中止服務的時候,Maven仍將沒法訪問被鏡像倉庫,於是將沒法下載構件。
5.可用的Maven鏡像倉庫
1 <mirror> 2 <id>repo2</id> 3 <mirrorOf>central</mirrorOf> 4 <name>Human Readable Name for this Mirror.</name> 5 <url>http://repo2.maven.org/maven2/</url> 6 </mirror> 7 8 <mirror> 9 <id>ui</id> 10 <mirrorOf>central</mirrorOf> 11 <name>Human Readable Name for this Mirror.</name> 12 <url>http://uk.maven.org/maven2/</url> 13 </mirror> 14 15 16 <mirror> 17 <id>ibiblio</id> 18 <mirrorOf>central</mirrorOf> 19 <name>Human Readable Name for this Mirror.</name> 20 <url>http://mirrors.ibiblio.org/pub/mirrors/maven2/</url> 21 </mirror> 22 23 <mirror> 24 <id>jboss-public-repository-group</id> 25 <mirrorOf>central</mirrorOf> 26 <name>JBoss Public Repository Group</name> 27 <url>http://repository.jboss.org/nexus/content/groups/public</url> 28 </mirror> 29 30 <mirror> 31 <id>JBossJBPM</id> 32 <mirrorOf>central</mirrorOf> 33 <name>JBossJBPM Repository</name> 34 <url>https://repository.jboss.org/nexus/content/repositories/releases/</url> 35 </mirror>
上面的倉庫通過測試是能夠訪問的。
6.倉庫搜索服務地址
Sonatype Nexus:https://repository.sonatype.org/
MVNrepository:http://mvnrepository.com/
關於依賴的搜索,我的以爲這兩個是最好用的。
結束語:要獲得你必需要付出,要付出你還要學會堅持,若是你真的以爲很難,那你就放棄,可是你放棄了就不要抱怨,世界真的是平衡的,我以爲人生就是這樣,每一個人都是經過本身的努力,去決定本身生活的樣子。