如何利用 Docker 環境加速 Android 應用的構建

philo發表於2016-01-09

意義

  1. 極大的縮短安卓開發到測試到產品到渠道的距離。
  2. 給安卓程式設計師減輕負擔。
  3. Google做的環境已經特別到位了,放到docker裡面明顯不會有多大的坑(誤,逃)。

如何利用 Docker 環境加速 Android 應用的構建

Dockerfile

https://github.com/lijianying10/FixLinux/blob/master/dockerfiles/androidautobuild/Dockerfile

團隊協作的故事

在敏捷開發的站立會議上,我作為一個後端程式設計師發現安卓程式設計師釋出的時間大概是半個小時左右的時間,我覺得時間太長了應該縮短一些,成為了研發這個東西的目的。 但是研究了一段時間之後發現了很多需要解決的問題:

  1. 很多東西是被牆的。
  2. 很多依賴不能夠複用(各種pom包)。
  3. gradlew怎麼能快速安裝不需要從網上下載。
  4. 自動對齊。
  5. 自動簽名。
  6. 自動混淆。

考慮範圍

  1. 系統底層依賴
  2. JDK
  3. Andorid-SDK
  4. Gradlew
  5. 專案依賴

構建解釋

建議:使用國外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
  1. 因為最好每一個layer控制在1G以內所以這裡切割用了兩個run。
  2. 注意SDK用您專案中需要的最高的版本安裝到image裡面然後向下安裝,不然會出現tool這個資料夾無法執行工具的情況。
  3. 注意上面的SDK plateform等都是根據我們的專案來的,詳細的摸索一下專案程式碼就知道依賴什麼了。

準備專案

  1. 使用git clone 同步專案目錄。
  2. 進行第一次手動構建編譯。 命令為:gradlew assembleDebug

第二點中目的有三個:

  1. 檢視專案是否缺少依賴,使用android update sdk 命令來增加安卓sdk依賴包。
  2. 自動下載專案中所有的依賴。
  3. 安裝gradlew。

需要備份的點有兩個

  1. /root/.gradle 備份這個目錄可以在以後自動化構建的時候不需要重複安裝gradlew。
  2. $PROJDIR/.gradle專案依賴的備份,備份了。($PROJDIR 為您的專案根目錄位置)

都備份之後下次編譯就不需要網路了(容器就不需要梯子了,這點對提升速度很重要)。

根據專案構建 Image

因為每個專案的依賴不盡相同所以需要針對專案定製化。大概執行目標如下:

  1. 建立容器。
  2. 找個方法同步程式碼git,FTP,NFS等等方法。
  3. 把上面兩個備份點放到指定位置等待使用。
  4. 執行構建輸出。
  5. 銷燬容器。

其實只要能做到上面這一點,加一個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

相關文章