最美情侣中文字幕电影,在线麻豆精品传媒,在线网站高清黄,久久黄色视频

歡迎光臨散文網(wǎng) 會員登陸 & 注冊

Maven的拉包原理

2023-04-05 07:20 作者:Cpp程序員  | 我要投稿

業(yè)務(wù)需求開發(fā)的時候,我們總是會遇到拉不到依賴包的情況。此時如果不清楚 Maven 拉取依賴包的原理,那么很可能找不到問題所在。今天樹哥就帶大家了解下 Maven 拉包的原理,讓你在遇到問題的時候能快速解決!

三種倉庫

在 Maven 中,倉庫指的是存放代碼構(gòu)建的一個位置。從分類上來說,Maven 倉庫有兩種類型,分別是:

  • 本地倉庫(Local)

  • 遠(yuǎn)程倉庫(Remote)

本地倉庫,是存在于本地的一個倉庫,它用來緩存下載的依賴包。這樣就不用每次都通過網(wǎng)絡(luò)去拉取依賴包了,提高了依賴?yán)∷俣?,減輕了倉庫服務(wù)器的壓力。

遠(yuǎn)程倉庫,如其名字所述,其實(shí)位于遠(yuǎn)程服務(wù)器的一個倉庫。例如有些公司自己對外開放了一些 API,需要將這些 API 的依賴開放出去,這時候就可以將 API 的 Jar 包放到公司自己的遠(yuǎn)程倉庫中。公司的客戶可以通過連接該倉庫下載 Jar 包。例如你們公司開發(fā)了自己的基礎(chǔ)工具類,并將其打成了一個 Jar 包。此時你可以將該 Jar 包部署到公司自己的遠(yuǎn)程倉庫中,公司其他開發(fā)伙伴配置該遠(yuǎn)程倉庫,從而可以拉取到該 Jar 包依賴。

在網(wǎng)上其他資料中,還會提到 Maven 倉庫有另一個類型 —— 中央倉庫(Central)。但在我看來,中央倉庫其實(shí)是一個特殊的遠(yuǎn)程倉庫。?它的特殊之處在于,它是 Maven 官方提供的,其中包括了大量常用的庫,基本上大多數(shù)的依賴包都可以在這里找到。另外一個特殊之處在于,中央倉庫的地址是內(nèi)置在 Maven 源碼中的,即默認(rèn)會向中央倉庫拉取依賴,這個在后續(xù)的依賴搜索順序中會講到。

而我們經(jīng)常說的私服,其實(shí)也是一個特殊的遠(yuǎn)程倉庫,其特殊之處在于:它只對公司內(nèi)部開放,方便存放一些本團(tuán)隊(duì)創(chuàng)建的開發(fā)庫。我們經(jīng)常說的阿里云 Maven 庫,其實(shí)就是一個遠(yuǎn)程倉庫,只不過其是對所有人開放罷了。

依賴搜索順序

弄懂了倉庫的類型,我們繼續(xù)來了解下依賴的搜索順序。

我們在開發(fā)過程中找不到依賴包,有多種原因,例如:

  • 依賴包確實(shí)沒有放到遠(yuǎn)程倉庫

  • 倉庫配置有問題

  • 等等

為了弄清楚到底是什么原因?qū)е乱蕾囌也坏剑覀冃枰私?Maven 是如何找一個依賴的。簡單來說,Maven 搜索依賴的算法如下:

  1. 首先,在本地倉庫搜索,如果找不到則繼續(xù)下一步。

  2. 接著,在中央倉庫搜索,如果找不到則繼續(xù)下一步。

  3. 最后,在遠(yuǎn)程倉庫中搜索,如果找不到則拋出錯誤。如果沒有設(shè)置遠(yuǎn)程倉庫,那么拋出錯誤。如果找到了依賴,那么就下載到本地倉庫緩存。

簡單地說,Maven 搜索遵循簡單的順序 ——?本地倉庫 -> 中央倉庫 -> 遠(yuǎn)程倉庫。弄明白了這個依賴搜索順序,可以幫助我們更好地排查問題。但這可能還不夠,我們還需要搞清楚 Maven?setting.xml?中的一些配置信息,從而可以排查是否是配置出現(xiàn)了問題。例如:有時候我們配置了 mirror 鏡像,會把對某個倉庫的請求轉(zhuǎn)發(fā)到另一個倉庫,這時候你要是不懂 mirror 配置,你就找不到問題所在了。

配置信息

關(guān)于倉庫的一些常見的配置項(xiàng)有:

  • repositories

  • mirror

  • server

  • 等等

下面我們將一個個講解他們的作用。

repositories 標(biāo)簽

repositories 標(biāo)簽用于定義遠(yuǎn)程倉庫,其配置范例如下所示:

<repositories> <repository> ? ? ? ?<!--公司鏡像的唯一標(biāo)識,這個配置要注意,不能與mirrorOf配置的相同,不然會被攔截,重定向到外網(wǎng)的鏡像倉庫 --> ? ? ? ?<id>nexus</id> ? ? ? ?<!--倉庫描述,隨意寫 --> ? ? ? ?<name>xxxx</name> ? ? ? ?<!-- 公司私有倉庫地址,這個很重要不能錯--> ? ? ? ?<url>http://xxx:8081/nexus/content/groups/public</url> ? ? ? ?<!-- 是否開啟 releases 包的下載及更新策略 --> ? ? ? ?<releases> ? ? ? ? ? ?<enabled>true</enabled> ? ? ? ? ? ?<updatePolicy>daily</updatePolicy> ? ? ? ?</releases> ? ? ? ?<!-- 是否開啟 snapshots 包的下載及更新策略 --> ? ? ? ?<snapshots> ? ? ? ? ? ?<enabled>false</enabled> ? ? ? ? ? ?<checksumPolicy>warn</checksumPolicy> ? ? ? ?</snapshots> ? ? ? ?<layout>default</layout> </repository> </repositories>

repositories 標(biāo)簽既可以在?setting.xml?文件配置,也可以在?pom.xml?文件中配置。Maven 在拉取依賴的時候,是按照聲明的順序從上到下去對應(yīng)的遠(yuǎn)程倉庫拉取依賴的。

mirror 標(biāo)簽

mirror 標(biāo)簽用于定義倉庫鏡像,其相當(dāng)于一個攔截器。當(dāng) mirror 的?mirrorOf?值與 repository 的?id?相同時,repository 定義的倉庫會被攔截,轉(zhuǎn)而使用 mirror 中定義的倉庫地址。配置范例如下:

<!--使用xx公司私有倉庫替換Maven默認(rèn)的中央倉庫 --><mirrors> ? ?<mirror> ? ? ? ?<!--自己公司的鏡像的唯一標(biāo)識,在mirror標(biāo)簽中,其實(shí)沒啥用:如xiaoyaziyun --> ? ? ? ?<id>xiaoyaziyun</id> ? ? ? ? ?<!--倉庫描述,隨意寫 --> ? ? ? ?<name>xx公司私有倉庫地址</name> ? ? ? ?<!--xx公司私有倉庫地址,這個很重要不能錯--> ? ? ? ?<url>http://maven.aliyun.com/nexus/content/groups/public/</url> ? ? ? ?<!--`central`為Maven中央倉庫的標(biāo)識,替換Maven源碼內(nèi)默認(rèn)的是中央倉庫地址--> ? ? ? ?<mirrorOf>central</mirrorOf> ? ?</mirror></mirrors>

如上圖配置所示,Maven 會用?http://maven.aliyun.com/nexus/content/groups/public/?這個倉庫鏡像替換 Maven 中央倉庫,其中?central?是 Maven 中央倉庫的 ID 標(biāo)識。我們經(jīng)常說用阿里云的 Maven 倉庫可以提速,其實(shí)就是使用這種方法實(shí)現(xiàn)的。

server 標(biāo)簽

大部分遠(yuǎn)程倉庫無須認(rèn)證就可以訪問,但我們自己搭建的 Maven 倉庫,處于安全方面的考慮,我們會設(shè)置訪問權(quán)限。此時,我們需要在?setting.xml?文件中配置 server標(biāo)簽。配置示例如下代碼所示:

<settings> ? ?<!--配置遠(yuǎn)程倉庫認(rèn)證信息--> ? ? <servers> ? ? ? ?<server> ? ? ? ? ? ? <id>shuyi-tech-repo</id> ? ? ? ? ? ? <username>admin</username> ? ? ? ? ? ? <password>admin123</password> ? ? ? ? </server> ? ? </servers></settings>

上面的配置為 repository id 為?shuyi-tech-repo?的遠(yuǎn)程倉庫配置了用戶名和密碼,其中用戶名為?admin,密碼為?admin123。這里通過?server.id?與?reposiroty.id?標(biāo)簽將認(rèn)證信息與倉庫綁定在一起,因此在配置的時候需要保持這兩個信息一致,否則可能導(dǎo)致訪問失敗。

其他標(biāo)簽

  • proxy?標(biāo)簽:服務(wù)器不能直接訪問外網(wǎng)時需要設(shè)置的代理服務(wù),不常用。

  • profiles?標(biāo)簽:上面提到mirror,配置多個只會一個有效,如果需要多倉庫配置,可以在profiles節(jié)點(diǎn)下配置多個profile,但是配置需要激活,特別麻煩,也不常用。

配置文件優(yōu)先級

對于 Maven 來說,我們會看到有多個配置文件:

  • 項(xiàng)目 pom.xml 文件

  • .m2/settings.xml?文件

  • Maven 安裝目錄?/conf/settings.xml?文件

如果一個配置同時存在于多個位置,那么到底以哪個為準(zhǔn)呢?簡單地說,這幾個配置文件的優(yōu)先級是怎樣的呢?如果沒搞懂這個問題,那么我們排查問題的時候可能會一團(tuán)糟。

其實(shí)三者的優(yōu)先級是?pom.xml?>/用戶/.m2/settings.xml>/maven安裝目錄/conf/settings.xml。如果要設(shè)置全局 Maven 倉庫配置,需要在 Maven 安裝目錄?/conf?下找到?settings.xml?來修改。


Maven的拉包原理的評論 (共 條)

分享到微博請遵守國家法律
米脂县| 锦州市| 白玉县| 界首市| 汶上县| 富裕县| 浠水县| 甘南县| 喀喇沁旗| 织金县| 花莲市| 石河子市| 常熟市| 思茅市| 赣州市| 和静县| 奇台县| 龙江县| 宜城市| 襄樊市| 江门市| 嘉义市| 贡嘎县| 方城县| 无棣县| 黑水县| 扶风县| 祁东县| 即墨市| 莱西市| 麻江县| 辽中县| 平江县| 苍溪县| 武乡县| 墨竹工卡县| 瓦房店市| 衡阳市| 太仆寺旗| 洪泽县| 东宁县|