如何利用 Docker 環境加速 Android 應用的構建
VERSION:1
警告:此文可能過于嚴肅
意義
- 極大的縮短安卓開發到
測試
到產品
到渠道
的距離。 - 給安卓程序員減輕負擔。
- Google做的環境已經特別到位了,放到docker里面明顯不會有多大的坑(誤,逃)。
Dockerfile
https://github.com/lijianying10/FixLinux/blob/master/dockerfiles/androidautobuild/Dockerfile
團隊協作的故事
在敏捷開發的站立會議上,我作為一個后端程序員發現安卓程序員發布的時間大概是半個小時左右的時間我覺得時間太長了應該縮短一些,成為了研發這個東西的目的。 但是研究了一段時間之后發現了很多需要解決的問題:
- 很多東西是被墻的。
- 很多依賴不能夠復用(各種pom包)。
- gradlew怎么能快速安裝不需要從網上下載。
- 自動對齊。
- 自動簽名。
- 自動混淆。
考慮范圍
- 系統底層依賴
- JDK
- Andorid-SDK
- Gradlew
- 項目依賴
構建解釋
建議:使用國外vps構建,不然要等很長時間
構建變量
ENV JAVA_HOME /jdk1.8.0_65 ENV ANDROID_HOME /opt/android-sdk-linux/ ENV ANDROID_SDK_FILENAME android-sdk_r24.4.1-linux.tgz ENV ANDROID_SDK_URL http://dl.google.com/android/${ANDROID_SDK_FILENAME} ENV PATH ${PATH}:${ANDROID_HOME}/tools:${ANDROID_HOME}/platform-tools:${JAVA_HOME}/bin/
底層依賴
gcc一類的,注意我們需要安裝32位編譯環境,以及git wget。
RUN sudo apt-get update && sudo apt-get install -y gcc-multilib lib32z1 lib32stdc++6 git wget && apt-get clean && rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/*
安裝JDK
RUN cd / && wget --no-check-certificate --no-cookies --header "Cookie: oraclelicense=accept-securebackup-cookie" http://download.oracle.com/otn-pub/java/jdk/8u65-b17/jdk-8u65-linux-x64.tar.gz &&\ tar xf jdk-8u65-linux-x64.tar.gz \ && rm -rf $JAVA_HOME/src.zip $JAVA_HOME/javafx-src.zip $JAVA_HOME/man /jdk-8u65-linux-x64.tar.gz
這里使用Cookie來確定同意協議。
安裝SDK
RUN cd /opt && \ wget -q ${ANDROID_SDK_URL} && \ tar -xzf ${ANDROID_SDK_FILENAME} && \ rm ${ANDROID_SDK_FILENAME} &&\ echo y | android update sdk --no-ui --all --filter tools,platform-tools,extra-android-m2repository,android-21 RUN echo y | android update sdk --no-ui --all --filter android-22,build-tools-21.1.2,build-tools-22.0.1
- 因為最好每一個layer控制在1G以內所以這里切割用了兩個run。
- 注意
SDK用您項目中需要的最高的版本安裝到image里面然后向下安裝,不然會出現tool這個文件夾無法運行工具的情況。
- 注意
上面的SDK plateform等都是根據我們的項目來的,詳細的摸索一下項目代碼就知道依賴什么了。
準備項目
- 使用git clone 同步項目目錄。
- 進行第一次手動構建編譯。 命令為:
gradlew assembleDebug
第二點中目的有三個:
- 查看項目是否缺少依賴,使用android update sdk 命令來增加安卓sdk依賴包。
- 自動下載項目中所有的依賴。
- 安裝gradlew。
需要備份的點有兩個
/root/.gradle
備份這個目錄可以在以后自動化構建的時候不需要重復安裝gradlew。$PROJDIR/.gradle
項目依賴的備份,備份了。($PROJDIR 為您的項目根目錄位置)
都備份之后下次編譯就不需要網絡了(容器就不需要梯子了,這點對提升速度很重要)。
根據項目構建Image
因為每個項目的依賴不盡相同所以需要針對項目定制化。大概運行目標如下:
- 創建容器。
- 找個方法同步代碼git,FTP,NFS等等方法。
- 把上面兩個備份點放到指定位置等待使用。
- 執行構建輸出。
- 銷毀容器。
其實只要能做到上面這一點,加一個git hook 加上簡單的發布就是一個簡單的CI了。
對齊,簽名,混淆
根據下面參考文檔可以對項目的build.gradlew進行調整
簽名是在Android節點下面加入如下代碼:
signingConfigs { release{ storeFile file("../xxxxxxx.keystore") storePassword "xxxxxx" keyAlias "xxxxx" keyPassword "xxxxx" }}
在buildTypes 下面的release下面加入如下選項:
signingConfig signingConfigs.release
對齊方面根據安卓官方文檔說明按照上面兩步代碼修改之后已經對齊。可以準備安裝了。
混淆(proguard)
在buildTypes 下面的release 下面加入如下選項:
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
總結
經過研究以及實戰如果是用普通的筆記本電腦我們的應用30多個渠道大概需要使用31分鐘的時間來進行構建。 如果使用RancherOS服務器Xeon X5675 兩顆CPU 48G內存的刀片服務器構建的時間是1分6秒
。
因為寫文章的時間倉促,很多地方寫的不明白希望大家能夠指出來,方便我改進,另外本人安卓水平非常一般請大神們批評指正。十分感謝。
注:下面的文獻非常具有參考價值。
主要參考文獻:
[1] Building and Running from the Command Line http://developer.android.com/intl/pt-br/tools/building/building-cmdline.html
[2] Configuring ProGuard http://developer.android.com/intl/pt-br/tools/help/proguard.html
[3] Signing Your Applications http://developer.android.com/intl/pt-br/tools/publishing/app-signing.html