如何利用 Docker 环境加速 Android 应用的构建

如何利用 Docker 环境加速 Android 应用的构建

意义

  1. 极大的缩短安卓开发到测试到产品到渠道的距离。
  2. 给安卓程序员减轻负担。
  3. Google做的环境已经特别到位了,放到docker里面明显不会有多大的坑(误,逃)。

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构建,不然要等很长时间。

构建变量


  1. ENV JAVA_HOME /jdk1.8.0_65
  2. ENV ANDROID_HOME /opt/android-sdk-linux/
  3. ENV ANDROID_SDK_FILENAME android-sdk_r24.4.1-linux.tgz
  4. ENV ANDROID_SDK_URL http://dl.google.com/android/${ANDROID_SDK_FILENAME}
  5. ENV PATH ${PATH}:${ANDROID_HOME}/tools:${ANDROID_HOME}/platform-tools:${JAVA_HOME}/bin/

底层依赖

gcc一类的,注意我们需要安装32位编译环境,以及git wget。


  1. 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


  1. 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 &&\
  2. tar xf jdk-8u65-linux-x64.tar.gz \
  3. && rm -rf $JAVA_HOME/src.zip $JAVA_HOME/javafx-src.zip $JAVA_HOME/man /jdk-8u65-linux-x64.tar.gz

这里使用Cookie来确定同意协议。

安装SDK


  1. RUN cd /opt && \
  2. wget -q ${ANDROID_SDK_URL} && \
  3. tar -xzf ${ANDROID_SDK_FILENAME} && \
  4. rm ${ANDROID_SDK_FILENAME} &&\
  5. echo y | android update sdk --no-ui --all --filter tools,platform-tools,extra-android-m2repository,android-21
  6. 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节点下面加入如下代码:


  1. signingConfigs {
  2. release{
  3. storeFile file("../xxxxxxx.keystore")
  4. storePassword "xxxxxx"
  5. keyAlias "xxxxx"
  6. keyPassword "xxxxx"
  7. }}

在buildTypes 下面的release下面加入如下选项:


  1. signingConfig signingConfigs.release

对齐方面根据安卓官方文档说明按照上面两步代码修改之后已经对齐。可以准备安装了。

混淆(proguard),在buildTypes 下面的 release 下面加入如下选项:


  1. 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

本文来自合作伙伴“Linux中国”

原文发布时间为:2013-04-02.

时间: 2024-09-03 17:40:12

如何利用 Docker 环境加速 Android 应用的构建的相关文章

利用adt-bundle轻松搭建Android开发环境与Hello world(Linux)_Android

本文与<利用adt-bundle轻松搭建Android开发环境与Hello world(Windows) >是姊妹篇,只是这次操作换成了Linux .拿Ubuntu做例子.还是与Windows一样.由于JDK+Eclipse+ADT+SDK或者JDK+Android Studio在安装的过程中非得联网不可.因此也选用了JDK1.7+解压即用的官方绿色版Android开发环境adt-bundle20131030去安装. 一.基本准备 首先还是与<Debian配置JDK1.7 与Linux

利用docker搭建LAMP运行环境教程详解_docker

LAMP介绍 LAMP 指的 Linux(操作系统).ApacheHTTP 服务器,MySQL(有时也指MariaDB,数据库软件) 和 PHP(有时也是指 Perl 或 Python) 的第一个字母,一般用来建立 web 服务器. 虽然这些开放源代码程序本身并不是专门设计成同另几个程序一起工作的,但由于它们的免费和开源,这个组合开始流行(大多数Linux发行版本***了这些软件).当一起使用的时候,它们表现的像一个具有活力的解决方案包. 下面介绍如何使用docker来搭建一个包含lamp组件的

利用adt-bundle轻松搭建Android开发环境与Hello world(Linux)

本文与<利用adt-bundle轻松搭建Android开发环境与Hello world(Windows) >是姊妹篇,只是这次操作换成了Linux .拿Ubuntu做例子.还是与Windows一样.由于JDK+Eclipse+ADT+SDK或者JDK+Android Studio在安装的过程中非得联网不可.因此也选用了JDK1.7+解压即用的官方绿色版Android开发环境adt-bundle20131030去安装. 一.基本准备 首先还是与<Debian配置JDK1.7 与Linux

如何利用Docker、AWS和深度学习伪装成一个艺术家

本文讲的是如何利用Docker.AWS和深度学习伪装成一个艺术家[编者的话]本篇文章描述了如何利用Docker.AWS和深度学习将一张普通的图片转换成艺术家的作品. "能工摹形,巧匠窃意(Good artists copy, great artists steal)" -- 毕加索 在英国第四频道纪录片系列之"Faking it"中,Paul O'Hare(一名来自利物浦的画家和室内装潢师)需要在四个星期的时间内,将自己伪装成一个艺术家,并且尝试着去欺骗伦敦美术馆的

利用Docker和阿里云容器服务部署高可用Ghost博客集群

简介 Ghost是一个流行的开源博客平台(Open source blogging platform),基于 Node.js 构建,博客内容默认采用 Markdown 语法书写,给用户提供一种更加纯粹的内容写作与发布平台. Ghost的部署和运维需要一定的Web开发基础,利用Docker技术可以大大简化Ghost的部署和更新.Docker Hub上面也提供了Ghost官方镜像 使用Docker镜像,不懂得Node.Js的同学也可以分分钟在本地或阿里云容器服务上搭建起一个单节点的Ghost博客,但

利用Docker和阿里云容器服务轻松搭建TensorFlow Serving集群

本系列将利用Docker和阿里云容器服务,帮助您上手TensorFlow的机器学习方案 第一篇:打造TensorFlow的实验环境 第二篇:轻松搭建TensorFlow Serving集群 - 本文 第三篇 打通TensorFlow持续训练链路 第四篇 利用Neural Style的TensorFlow实现,像梵高一样作画 第五篇 轻松搭建分布式TensorFlow训练集群(上) 本文是系列中的第二篇文章,将带您快速了解Tensorflow Serving的原理和使用,并利用阿里云容器服务轻松在

利用Docker和阿里云容器服务轻松搭建分布式TensorFlow训练集群(上)

本系列将利用Docker技术在阿里云HPC和容器服务上,帮助您上手TensorFlow的机器学习方案 第一篇:打造TensorFlow的实验环境 第二篇:轻松搭建TensorFlow Serving集群 第三篇:打通TensorFlow持续训练链路 第四篇:利用Neural Style的TensorFlow实现,像梵高一样作画 第五篇:轻松搭建分布式TensorFlow训练集群(上) 本文是该系列中的第五篇文章, 将为您介绍如何在本机以及HPC和阿里云容器服务上快速部署和使用分布式TensorF

利用Docker轻松实现云原生应用 - 高可用架构设计

本文为利用Docker和容器服务轻松实现云原生应用系列的第一篇 高可用架构设计(本文) Spring Boot + Redis分布式会话 最近对应用迁云的讨论很多,很多用户对云环境中的应用架构和运维方式还不了解.直接利用云服务器替换自有物理机并不是使用云的正确姿势. Cloud Native Application(云原生应用)是当下一个热门名词,简单而言就是针对云计算的特性,来设计应用架构,并优化应用的交付.运维流程.Linux基金会旗下的云原生计算基金会 CNCF(Cloud Native

ActiveMQ私有云、公有云以及Docker环境高可用集群方案汇总

原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任.http://dgd2010.blog.51cto.com/1539422/1749983 ActiveMQ软件概述 ActiveMQ提供消息队列服务. ActiveMQ高可用原理 ActiveMQ高可用由三部分组成. 1.ActiveMQ的master-slave 两个运行的ActiveMQ instance如果同时使用一套持久化存储,那么这两个ActiveMQ instance就会构成ma