當前位置:首頁 > 公眾號精選 > 架構師社區(qū)
[導讀]作者 :樂百川 本文:toutiao.com/i6824937779193971207 相信使用Java的同學都用過Maven,這是一個非常經(jīng)典好用的項目構建工具。但是如果你經(jīng)常使用Maven,可能會發(fā)現(xiàn)Maven有一些地方用的讓人不太舒服: 1. Maven的配置文件是XML格式的,假如你的項目依賴的包


作者 :樂百川

本文:toutiao.com/i6824937779193971207

相信使用Java的同學都用過Maven,這是一個非常經(jīng)典好用的項目構建工具。但是如果你經(jīng)常使用Maven,可能會發(fā)現(xiàn)Maven有一些地方用的讓人不太舒服:

1. Maven的配置文件是XML格式的,假如你的項目依賴的包比較多,那么XML文件就會變得非常非常長;

2. XML文件不太靈活,假如你需要在構建過程中添加一些自定義邏輯,搞起來非常麻煩;

3. Maven非常的穩(wěn)定,但是相對的就是對新版java支持不足,哪怕就是為了編譯java11,也需要更新內置的Maven插件。

如果你對Maven的這些缺點也有所感觸,準備嘗試其他的構建工具,那么你可以試試gradle,這是一個全新的java構建工具,解決了Maven的一些痛點。

下一代構建工具 Gradle ,比 Maven 強在哪里!

一、安裝Gradle

最傳統(tǒng)的安裝方法就是去gradle官網(wǎng)下載二進制包,解壓,然后將路徑添加到環(huán)境變量中。如果你沒什么其他需求,可以使用這種安裝方式。但是,gradle是一個非常新潮的項目,每隔幾個月就會發(fā)布一個新版本,這種方式可能跟不上gradle的更新速度。

所以我更加推薦使用包管理器來安裝gradle。如果你使用linux系統(tǒng),那么不必多說。如果你使用Windows系統(tǒng),我推薦使用scoop包管理器來安裝gradle。它安裝方便,而且使用SHIM目錄來管理環(huán)境變量,在各種工具中配置gradle也很方便。

當然,如果你完全不喜歡安裝這么多亂七八糟的東西,那也可以使用gradle。gradle提供了一個名為gradle wrapper的工具,可以在沒有安裝gradle的情況下使用gradle。好吧,其實它就是個腳本文件,當你運行wrapper腳本的時候,如果腳本發(fā)現(xiàn)你電腦里沒有gradle,就會自動替你下載安裝一個?,F(xiàn)在甚至還出現(xiàn)了Maven wrapper,也是個腳本文件,可以自動安裝Maven。

之前相信一些朋友聽說過gradle,然后嘗試使用它,結果因為速度太慢,最后放棄了。之前我也因為gradle的速度,放棄了它一段時間。不過現(xiàn)在使用gradle的話會方便很多。gradle官方在中國開設了,CDN,使用gradle wrapper的時候下載速度非??臁?梢哉f現(xiàn)在是一個學習使用gradle的好時候。

二、使用gradle wrapper

這里我使用的IDEA來創(chuàng)建和使用gradle項目。

下一代構建工具 Gradle ,比 Maven 強在哪里!

IDEA默認就會使用gradle wrapper來創(chuàng)建項目,所以無需安裝gradle也可以正常運行。這時候項目結構應該類似下圖所示,使用Maven的同學應該比較熟悉,因為這和Maven的項目結構幾乎完全一致。gradle文件夾和gradlew那幾個文件就是gradle wrapper的文件,而.gradle后綴名的文件正是gradle的配置文件,對應于Maven的pom.xml。

下一代構建工具 Gradle ,比 Maven 強在哪里!

gradle wrapper的優(yōu)點之一就是可以自定義下載的gradle的版本,如果是團隊協(xié)作的話,這個功能就非常方便,簡單設置即可統(tǒng)一團隊的構建工具版本。這里我就設定成目前最新的gradle 6.4.默認下載安裝的是bin版,僅包含二進制。如果你使用IDEA的話,它會推薦下載all版,包含源代碼,這樣IDEA就可以分析源代碼,提供更加精確的gradle腳本支持。

下一代構建工具 Gradle ,比 Maven 強在哪里!

三、依賴管理

下面來看看gradle的依賴管理功能,這也算是我們使用構建工具的主要目的之一了。這點也是gradle相較maven的優(yōu)勢之一了。相較于maven一大串的XML配置,gradle的依賴項僅需一行。

dependencies {
    testImplementation 'junit:junit:4.13'
    implementation 'com.google.code.gson:gson:2.8.6'
}

這里推薦一下Jetbrains的package search網(wǎng)站,是尋找maven和gradle依賴包的最佳網(wǎng)站,可以非常輕松的搜索和使用依賴項。

下一代構建工具 Gradle ,比 Maven 強在哪里!

gradle依賴的粒度控制相較于Maven也更加精細,maven只有compile、provided、test、runtime四種scope,而gradle有以下幾種scope:

1.implementation,默認的scope。implementation的作用域會讓依賴在編譯和運行時均包含在內,但是不會暴露在類庫使用者的編譯時。舉例,如果我們的類庫包含了gson,那么其他人使用我們的類庫時,編譯時不會出現(xiàn)gson的依賴。

2.api,和implementation類似,都是編譯和運行時都可見的依賴。但是api允許我們將自己類庫的依賴暴露給我們類庫的使用者。

3.compileOnly和runtimeOnly,這兩種顧名思義,一種只在編譯時可見,一種只在運行時可見。而runtimeOnly和Maven的provided比較接近。

4.testImplementation,這種依賴在測試編譯時和運行時可見,類似于Maven的test作用域。

5.testCompileOnly和testRuntimeOnly,這兩種類似于compileOnly和runtimeOnly,但是作用于測試編譯時和運行時。

通過簡短精悍的依賴配置和多種多樣的作用與選擇,Gradle可以為我們提供比Maven更加優(yōu)秀的依賴管理功能。

四、gradle的任務和插件

gradle的配置文件是一個groovy腳本文件,在其中我們可以以編程方式自定義一些構建任務。因為使用了編程方式,所以這帶給了我們極大的靈活性和便捷性。打個比方,現(xiàn)在有個需求,要在打包出jar的時候順便看看jar文件的大小。在gradle中僅需在構建腳本中編寫幾行代碼即可。而在Maven中則需要編寫Maven插件,復雜程度完全不在一個水平。

當然,Maven發(fā)展到現(xiàn)在,已經(jīng)存在了大量的插件,提供了各式各樣的功能可以使用。但是在靈活性方面還是無法和Gradle相比。而且Gradle也有插件功能,現(xiàn)在發(fā)展也十分迅猛,存在了大量非常好用的插件,例如gretty插件。gretty原來是社區(qū)插件,后來被官方吸收為官方插件,可以在Tomcat和jetty服務器上運行web項目,比Maven的相關插件功能都強大。

雖然gradle可以非常靈活的編寫自定義腳本任務,但是其實一般情況下我們不需要編寫構建腳本,利用現(xiàn)有的插件和任務即可完成相關功能。在IDEA里,也可以輕松的查看當前gradle項目中有多少任務,基本任務如build、test等Maven和Gradle都是相通的。

下一代構建工具 Gradle ,比 Maven 強在哪里!

五、配置鏡像

Maven官方倉庫的下載速度非常慢,所以一般我們要配置國內的鏡像源。gradle在這方面和Maven完全兼容,因此只需稍微配置一下鏡像源,即可使用Maven的鏡像。如果你用gradle構建過項目,應該就可以在用戶目錄的.gradle文件夾下看到gradle的相關配置和緩存。

之前wrapper下載的gradle也存放在該文件夾下,位置是wrapper/dists。

下一代構建工具 Gradle ,比 Maven 強在哪里!

而依賴的本地緩存在caches\modules-2\files-2.1文件夾下。目錄結構和Maven的本地緩存類似,都是包名+版本號的方式,但是gradle的目錄結構最后一層和Maven不同,這導致它們無法共用本地緩存。

下一代構建工具 Gradle ,比 Maven 強在哪里!

言歸正傳,在gradle中配置下載鏡像需要在.gradle文件夾中直接新建一個init.gradle初始化腳本,腳本文件內容如下。這樣一來,gradle下載鏡像的時候就會使用這里配置的鏡像源下載,速度會快很多。再加上gradle wrapper在中國設置了CDN,現(xiàn)在使用gradle的速度應該會很快。

allprojects {
   repositories {
       maven {
           url "https://maven.aliyun.com/repository/public"
       }
       maven {
           url "https://maven.aliyun.com/repository/jcenter"
       }
       maven {
           url "https://maven.aliyun.com/repository/spring"
       }
       maven {
           url "https://maven.aliyun.com/repository/spring-plugin"
       }
       maven {
           url "https://maven.aliyun.com/repository/gradle-plugin"
       }
       maven {
           url "https://maven.aliyun.com/repository/google"
       }
       maven {
           url "https://maven.aliyun.com/repository/grails-core"
       }
       maven {
           url "https://maven.aliyun.com/repository/apache-snapshots"
       }
   }
}

當然,如果你有代理的話,其實我推薦你直接為gradle設置全局代理。因為gradle腳本實在是太靈活了,有些腳本中可能依賴了github或者其他地方的遠程腳本。這時候上面設置的下載鏡像源就不管用了。

所以有條件還是干脆直接使用全局代理比較好。設置方式很簡單,在.gradle文件夾中新建gradle.properties文件,內容如下。中間幾行即是設置代理的配置項。當然其他幾行我也建議你設置一下,把gradle運行時的文件編碼設置為UTF8,增加跨平臺兼容性。

org.gradle.jvmargs=-Xmx4g -XX:MaxPermSize=512m -XX:+HeapDumpOnOutOfMemoryError -Dfile.encoding=UTF-8
systemProp.http.proxyHost=127.0.0.1
systemProp.http.proxyPort=10800
systemProp.https.proxyHost=127.0.0.1
systemProp.https.proxyPort=10800
systemProp.file.encoding=UTF-8
org.gradle.warning.mode=all

六、為什么使用gradle?

看到這里,你應該對gradle有了基本的了解, 也可以將其用于你的項目之中。但是如果你Maven已經(jīng)非常熟悉了,可能不太愿意使用gradle,因為貌似沒有必要。但是既然gradle出現(xiàn)了,就說明有很多人對Maven還是有一定的意見。因此在這里我來總結一下gradle相比maven的優(yōu)勢。

1. 速度,gradle使用構建緩存、守護進程等方式提高編譯速度。結果就是gradle的編譯速度要遠超maven,平均編譯速度比Maven快好幾倍,而且項目越大,這個差距就越明顯。

下一代構建工具 Gradle ,比 Maven 強在哪里!

2. 靈活性,gradle要比Maven靈活太多,雖然有時候靈活并不是一件好事情。但是大部分情況下,靈活一點可以極大的方便我們。Maven死板的XML文件方式做起事情來非常麻煩。很多Maven項目都通過執(zhí)行外部腳本的方式來完成一些需要靈活性的工作。而在gradle中配置文件就是構建腳本,構建腳本就是編程語言(groovy編程語言),完全可以自給自足,無需外部腳本。


3. 簡潔性,完成同樣的功能,gradle腳本的長度要遠遠短于maven配置文件的長度。雖然很多人都說XML維護起來不麻煩,但是我覺得,維護一個光是依賴就有幾百行的XML文件,不見得就比gradle腳本簡單。


也許是因為我上面說的原因,也許有其他原因,不得不承認的一件事情就是gradle作為一個新興的工具已經(jīng)有了廣泛的應用。spring等項目已經(jīng)從Maven切換到了gradle。開發(fā)安卓程序也只支持gradle了。因此不管是否現(xiàn)在需要將項目從maven切換到gradle,但是至少學習gradle是一件必要的事情。

特別推薦一個分享架構+算法的優(yōu)質內容,還沒關注的小伙伴,可以長按關注一下:

下一代構建工具 Gradle ,比 Maven 強在哪里!

下一代構建工具 Gradle ,比 Maven 強在哪里!

下一代構建工具 Gradle ,比 Maven 強在哪里!

長按訂閱更多精彩▼

下一代構建工具 Gradle ,比 Maven 強在哪里!

如有收獲,點個在看,誠摯感謝

免責聲明:本文內容由21ic獲得授權后發(fā)布,版權歸原作者所有,本平臺僅提供信息存儲服務。文章僅代表作者個人觀點,不代表本平臺立場,如有問題,請聯(lián)系我們,謝謝!

本站聲明: 本文章由作者或相關機構授權發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內容真實性等。需要轉載請聯(lián)系該專欄作者,如若文章內容侵犯您的權益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或將催生出更大的獨角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉型技術解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關鍵字: 汽車 人工智能 智能驅動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務中斷的風險,如企業(yè)系統(tǒng)復雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務連續(xù)性,提升韌性,成...

關鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質量流程IT總裁陶景文發(fā)表了演講。

關鍵字: 華為 12nm EDA 半導體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權最終是由生態(tài)的繁榮決定的。

關鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務引領增長 以科技創(chuàng)新為引領,提升企業(yè)核心競爭力 堅持高質量發(fā)展策略,塑強核心競爭優(yōu)勢...

關鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術學會聯(lián)合牽頭組建的NVI技術創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術創(chuàng)新聯(lián)...

關鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關鍵字: BSP 信息技術
關閉
關閉