App下載

一款現(xiàn)代高效的Java構(gòu)建工具--gradle的優(yōu)點(diǎn)介紹

猿友 2020-08-19 15:25:55 瀏覽數(shù) (4567)
反饋

學(xué)習(xí)Java的同學(xué),相信你們都用過(guò)Maven這個(gè)經(jīng)典實(shí)用的項(xiàng)目構(gòu)建工具。但是假如你經(jīng)常使用Maven的話,你或許會(huì)發(fā)現(xiàn)Maven一些讓人不太舒服的地方:

  • 一來(lái)Maven的配置文件是XML格式的,假如你的項(xiàng)目依賴的包比較多,那么XML文件就會(huì)變得非常非常長(zhǎng);
  • 二來(lái)XML文件不太靈活,假如你需要在構(gòu)建過(guò)程中添加一些自定義邏輯,搞起來(lái)非常麻煩;
  • 第三就是Maven非常的穩(wěn)定,但是相對(duì)的就是對(duì)新版java支持不足,哪怕就是為了編譯java11,也需要更新內(nèi)置的Maven插件。

如果你對(duì)Maven的這些缺點(diǎn)也有所感觸,準(zhǔn)備嘗試其他的構(gòu)建工具,那么你可以試試gradle,這是一個(gè)全新的java構(gòu)建工具,解決了Maven的一些痛點(diǎn)。

安裝gradle

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

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

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

之前相信一些朋友聽(tīng)說(shuō)過(guò)gradle,然后嘗試使用它,結(jié)果因?yàn)樗俣忍?,最后放棄了。之前我也因?yàn)?code>gradle的速度,放棄了它一段時(shí)間。不過(guò)現(xiàn)在使用gradle的話會(huì)方便很多。gradle官方在中國(guó)開(kāi)設(shè)了CDN,使用gradle wrapper的時(shí)候下載速度非??臁?梢哉f(shuō)現(xiàn)在是一個(gè)學(xué)習(xí)使用gradle的好時(shí)候。

使用gradle wrapper

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

gradle項(xiàng)目

IDEA默認(rèn)就會(huì)使用gradle wrapper來(lái)創(chuàng)建項(xiàng)目,所以無(wú)需安裝gradle也可以正常運(yùn)行。這時(shí)候項(xiàng)目結(jié)構(gòu)應(yīng)該類似下圖所示,使用Maven的同學(xué)應(yīng)該比較熟悉,因?yàn)檫@和Maven的項(xiàng)目結(jié)構(gòu)幾乎完全一致。gradle文件夾和gradlew那幾個(gè)文件就是gradle wrapper的文件,而.gradle后綴名的文件正是gradle的配置文件,對(duì)應(yīng)于Mavenpom.xml

gradle項(xiàng)目結(jié)構(gòu)

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

gradle腳本

依賴管理

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

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

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

(推薦教程:Java教程

package search網(wǎng)站

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

  • implementation,默認(rèn)的scope。implementation的作用域會(huì)讓依賴在編譯和運(yùn)行時(shí)均包含在內(nèi),但是不會(huì)暴露在類庫(kù)使用者的編譯時(shí)。舉例,如果我們的類庫(kù)包含了gson,那么其他人使用我們的類庫(kù)時(shí),編譯時(shí)不會(huì)出現(xiàn)gson的依賴。
  • api,和implementation類似,都是編譯和運(yùn)行時(shí)都可見(jiàn)的依賴。但是api允許我們將自己類庫(kù)的依賴暴露給我們類庫(kù)的使用者。
  • compileOnlyruntimeOnly,這兩種顧名思義,一種只在編譯時(shí)可見(jiàn),一種只在運(yùn)行時(shí)可見(jiàn)。而runtimeOnlyMavenprovided比較接近。
  • testImplementation,這種依賴在測(cè)試編譯時(shí)和運(yùn)行時(shí)可見(jiàn),類似于Maventest作用域。
  • testCompileOnlytestRuntimeOnly,這兩種類似于compileOnlyruntimeOnly,但是作用于測(cè)試編譯時(shí)和運(yùn)行時(shí)。

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

gradle的任務(wù)和插件

gradle的配置文件是一個(gè)groovy腳本文件,在其中我們可以以編程方式自定義一些構(gòu)建任務(wù)。因?yàn)槭褂昧司幊谭绞?,所以這帶給了我們極大的靈活性和便捷性。打個(gè)比方,現(xiàn)在有個(gè)需求,要在打包出jar的時(shí)候順便看看jar文件的大小。在gradle中僅需在構(gòu)建腳本中編寫(xiě)幾行代碼即可。而在Maven中則需要編寫(xiě)Maven插件,復(fù)雜程度完全不在一個(gè)水平。

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

雖然gradle可以非常靈活的編寫(xiě)自定義腳本任務(wù),但是其實(shí)一般情況下我們不需要編寫(xiě)構(gòu)建腳本,利用現(xiàn)有的插件和任務(wù)即可完成相關(guān)功能。在IDEA里,也可以輕松的查看當(dāng)前gradle項(xiàng)目中有多少任務(wù),基本任務(wù)如buildtestMavenGradle都是相通的。

gretty插件的任務(wù)

配置鏡像

Maven官方倉(cāng)庫(kù)的下載速度非常慢,所以一般我們要配置國(guó)內(nèi)的鏡像源。gradle在這方面和Maven完全兼容,因此只需稍微配置一下鏡像源,即可使用Maven的鏡像。如果你用gradle構(gòu)建過(guò)項(xiàng)目,應(yīng)該就可以在用戶目錄的.gradle文件夾下看到gradle的相關(guān)配置和緩存。

(推薦微課:Java微課

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

wrapper下載的gradle保存位置

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

wrapper下載的gradle保存位置

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

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"
       }
   }
}

當(dāng)然,如果你有代理的話,其實(shí)我推薦你直接為gradle設(shè)置全局代理。因?yàn)?code>gradle腳本實(shí)在是太靈活了,有些腳本中可能依賴了github或者其他地方的遠(yuǎn)程腳本。這時(shí)候上面設(shè)置的下載鏡像源就不管用了。

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

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?

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

1.速度

gradle使用構(gòu)建緩存、守護(hù)進(jìn)程等方式提高編譯速度。結(jié)果就是gradle的編譯速度要遠(yuǎn)超maven,平均編譯速度比Maven快好幾倍,而且項(xiàng)目越大,這個(gè)差距就越明顯。

大型多模塊項(xiàng)目Maven和Gradle編譯時(shí)間的對(duì)比

2.靈活性

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

3.簡(jiǎn)潔性

完成同樣的功能,gradle腳本的長(zhǎng)度要遠(yuǎn)遠(yuǎn)短于maven配置文件的長(zhǎng)度。雖然很多人都說(shuō)XML維護(hù)起來(lái)不麻煩,但是我覺(jué)得,維護(hù)一個(gè)光是依賴就有幾百行的XML文件,不見(jiàn)得就比gradle腳本簡(jiǎn)單。

也許是因?yàn)槲疑厦嬲f(shuō)的原因,也許有其他原因,不得不承認(rèn)的一件事情就是gradle作為一個(gè)新興的工具已經(jīng)有了廣泛的應(yīng)用。spring等項(xiàng)目已經(jīng)從Maven切換到了gradle。開(kāi)發(fā)安卓程序也只支持gradle了。因此不管是否現(xiàn)在需要將項(xiàng)目從maven切換到gradle,但是至少學(xué)習(xí)gradle是一件必要的事情。

(推薦教程:Gradle 教程

以上就是關(guān)于一款現(xiàn)代高效的 Java 構(gòu)建工具-- gradle 的優(yōu)點(diǎn)介紹了,希望對(duì)大家所有幫助。

作者:百樂(lè)川

文章來(lái)源:www.toutiao.com/i6824937779193971207

0 人點(diǎn)贊