溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

你的安卓項目編譯要花 10 分鐘,如何縮短到 1 分鐘?

發(fā)布時間:2020-07-25 20:51:37 來源:網(wǎng)絡(luò) 閱讀:502 作者:JFrog中國 欄目:編程語言

痛點
如果項目的代碼庫較大,例如大型的安卓開發(fā)項目,在構(gòu)建的時候耗時較長,達到數(shù)十分鐘甚至更長,分析其原因,其中一部分時間是花在構(gòu)建上。在大規(guī)模開發(fā)團隊中,例如上百人的開發(fā)團隊,如果每個人構(gòu)建一次需要花費數(shù)十分鐘,那么團隊每天浪費的時間是非常驚人的。
除了構(gòu)建時間,執(zhí)行 Gradle Build 的時候很大一部分時間是花在單元測試用例的執(zhí)行上,這樣的問題也困擾著大規(guī)模 Gradle 的用戶。

方案
為了讓構(gòu)建提升速度,Gradle 4.0 以上版本提供了Build Cache 的功能,也就是構(gòu)建緩存。注意,這里的構(gòu)建指的不是構(gòu)建產(chǎn)出物,例如 war,jar 文件,而是 Java 構(gòu)建的字節(jié)碼 .class文件。通過緩存每次構(gòu)建產(chǎn)生的.class 文件,實現(xiàn) Java 項目的增量編譯。Gradle 項目能夠在第一次構(gòu)建之后,創(chuàng)建一個 Key-value 的鍵值對數(shù)據(jù),將每個.class 文件通過一個 key 索引起來。而這些鍵值對以及.class 文件會上傳到一個中央服務(wù)器(例如 Nginx 或者 JFrog Artifactory),當用戶再次構(gòu)建,或者其他成員構(gòu)建時,會先將中央服務(wù)器的緩存文件下載到本地,再進行打包,這樣就能大大減少編譯構(gòu)建時間,實現(xiàn)增量編譯。

注意,這里不僅僅能夠緩存軟件程序的.class 文件,對應(yīng)單元測試用例編譯產(chǎn)生的.class 文件同樣能夠緩存。

這里以開源版 Artifactory 為例,結(jié)合 Gradle 實現(xiàn)增量編譯:
你的安卓項目編譯要花 10 分鐘,如何縮短到 1 分鐘?

?創(chuàng)建一個示例項目“gradle-cache-example”
在這個 Java 工程里只需要創(chuàng)建一些普通的 Java 類即可,后面我們將驗證如何將這段代碼對應(yīng)的 class 緩存起來,節(jié)約構(gòu)建時間。
為設(shè)置構(gòu)建緩存前執(zhí)行構(gòu)建:./gradlew clean build
BUILD SUCCESSFUL in 11s
13 actionable tasks: 12 executed, 1 up-to-date

可以看到構(gòu)建耗時 12 秒。

?在本地搭建開源版 Artifactory 作為構(gòu)建緩存中央服務(wù)器。搭建開源版 Artifactory 最方便的方式是用容器啟動:

docker run --name artifactory -d -p 8081:8081 docker.bintray.io/jfrog/artifactory-oss:latest

?設(shè)置構(gòu)建緩存
在開發(fā)本地的工程文件中的 gradle.properties中設(shè)置如下配置,將構(gòu)建緩存指向 Artifactory。

gradle.properties
artifactory_user=admin
artifactory_password=password
artifactory_url=http://localhost:8081/artifactory
org.gradle.caching=true
gradle.cache.push=false

設(shè)置 CI 服務(wù)器上的settings.gradle,下面是 Jenkins 的腳本:
include "shared", "api", "services:webservice"
ext.isPush = getProperty('gradle.cache.push')
buildCache {
local {
enabled = false
}
remote(HttpBuildCache) {
url = "${artifactory_url}/gradle-cache-example/"
credentials {
username = "${artifactory_user}"
password = "${artifactory_password}"
}
push = isPush
}
}

在CI 服務(wù)器上執(zhí)行 ./gradlew clean build -Pgradle.cache.push=true。通過設(shè)置gradle.cache.push=true,實現(xiàn)本地構(gòu)建緩存向中央服務(wù)器的推送。
BUILD SUCCESSFUL in 1s
13 actionable tasks: 7 executed, 5 from cache, 1 up-to-date
可以看到構(gòu)建時間從 12 秒縮短到 1 秒,其中 5 個任務(wù)是來自緩存。

來確認下我們的構(gòu)建加速并不是來自本地緩存,可以查看 Artifactory 的訪問日志:

20170526153341|3|REQUEST|127.0.0.1|admin|GET|/gradle-cache-example/6dc9bb4c16381e32ca1f600b3060616f|HTTP/1.1|200|1146
20170526153341|4|REQUEST|127.0.0.1|admin|GET|/gradle-cache-example/e5a67dca52dfaea60efd28654eb8ec97|HTTP/1.1|200|1296

可以看到本地緩存,均來自 Artifactory 的統(tǒng)一倉庫。

?跨部門,地域共享構(gòu)建緩存

在大型分布式研發(fā)團隊里,構(gòu)建環(huán)境往往分布在各個地域,例如北京,上海。在這種情況下,構(gòu)建緩存上傳到本地的 Artifactory 之后,并不能夠被遠程的構(gòu)建服務(wù)器使用。這是需要用到 Artifactory 企業(yè)版的文件實時復(fù)制功能實現(xiàn)。
你的安卓項目編譯要花 10 分鐘,如何縮短到 1 分鐘?

如上圖所示:當本地開發(fā)者或者 CI 服務(wù)器執(zhí)行第一次構(gòu)建時,Artifactory 會通過 Push Replication(推送復(fù)制)的方式將本地的緩存推送到遠程的 Artifactory,當遠程的用戶在執(zhí)行 Gradle 構(gòu)建時,能夠受益于已有的構(gòu)建緩存,從而大大加速構(gòu)建的速度。

總結(jié)
本文展示并說明了如何使用 Gradle和 Artifactory 開源版進行構(gòu)建緩存的實現(xiàn),提升構(gòu)建速度。使用 Artifactory 企業(yè)版,能夠?qū)崿F(xiàn)跨地域的構(gòu)建緩存共享,優(yōu)化公司級別的構(gòu)建速度。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI