
https://github.com/mingchen/docker-android-build-box/actions/workflows/docker-image.yml/badge.svg](https://github.com/mingchen/docker-android-build-box/actions/workflows/docker-image.yml)
一个优化的Docker镜像,包含Android SDK和Flutter SDK,旨在为Android和Flutter项目提供完整的构建环境。
latest镜像始终安装最新软件,包括最近8个Android SDK平台及其关联构建工具。Dockerhub描述(点击上方Docker徽章可访问)提供latest镜像中已安装软件的实时列表。有关标记版本和latest镜像中安装的各种软件详情,请参见https://github.com/mingchen/docker-android-build-box/blob/master/COMPATIBILITY.md%E3%80%82
最新标记版本包含以下组件:
该Docker镜像基于本仓库的Dockerfile通过Github Action自动公开构建,无隐藏内容。
拉取最新镜像:
shdocker pull mingc/android-build-box:latest
提示:建议使用特定稳定版本的标签而非latest,以避免构建中断。例如mingc/android-build-box:1.25.0。
查看https://github.com/mingchen/docker-android-build-box/tags%E8%8E%B7%E5%8F%96%E6%89%80%E6%9C%89%E5%8F%AF%E7%94%A8%E6%A0%87%E7%AD%BE%EF%BC%8Chttps://github.com/mingchen/docker-android-build-box/blob/master/CHANGELOG.md%E4%BA%86%E8%A7%A3%E6%A0%87%E7%AD%BE%E9%97%B4%E5%B7%AE%E5%BC%82%EF%BC%8Chttps://github.com/mingchen/docker-android-build-box/blob/master/COMPATIBILITY.md%E6%9F%A5%E7%9C%8B%E5%90%84%E6%A0%87%E7%AD%BE%E5%AF%B9%E5%BA%94%E7%9A%84%E8%BD%AF%E4%BB%B6%E7%89%88%E6%9C%AC%EF%BC%88%E5%A6%82%E6%A0%87%E7%AD%BE%601.2.0%60%E5%8C%85%E5%90%ABSDK x、y、z等)。
缓存使用方法请参见https://github.com/mingchen/docker-android-build-box/blob/master/README.md#caches%E3%80%82
通过以下命令使用该镜像构建Android项目:
shcd <android项目目录> # 切换到项目根目录 docker run --rm -v `pwd`:/project mingc/android-build-box bash -c 'cd /project; ./gradlew build'
构建.aab格式发布包:
shcd <android项目目录> # 切换到项目根目录 docker run --rm -v `pwd`:/project mingc/android-build-box bash -c 'cd /project; ./gradlew bundleRelease'
以交互式bash shell运行容器:
shdocker run -v `pwd`:/project -it mingc/android-build-box bash -l
缓存不会减少总磁盘空间需求,反而可能增加(例如Android SDK缓存可能使空间翻倍)。需注意镜像本身约占16.2GB,缓存可能额外占用6GB。
jEnv缓存
为缓存全局Java设置(/root/.jenv/version),需缓存整个jEnv文件夹/root/.jenv/:
在主机创建缓存目录:
shmkdir ~/.dockercache/jenv
创建命名卷jenv-cache:
shdocker volume create --driver local --opt type=none --opt device=~/.dockercache/jenv/ --opt o=bind jenv-cache
运行容器时挂载该卷:
shdocker run --rm -v jenv-cache:"/root/.jenv/" mingc/android-build-box bash -l `echo "Hello World"`
Gradle缓存
添加以下参数以缓存Gradle主目录:
sh-v "$HOME/.dockercache/gradle":"/root/.gradle"
示例:
shdocker run --rm -v `pwd`:/project -v "$HOME/.dockercache/gradle":"/root/.gradle" mingc/android-build-box bash -c 'cd /project; ./gradlew build'
在gradle.properties中启用缓存:
shorg.gradle.caching=true
Android SDK缓存
缓存SDK可灵活更新/移除平台/构建工具。1.25.0版本中/opt/android-sdk/约需6GB空间。
在主机创建缓存目录:
shmkdir ~/.dockercache/android-sdk
创建命名卷android-sdk-cache:
shdocker volume create --driver local --opt type=none --opt device=~/.dockercache/android-sdk/ --opt o=bind android-sdk-cache
运行容器时挂载该卷:
shdocker run --rm -v android-sdk-cache:"/opt/android-sdk/" mingc/android-build-box bash -l
使用sdkmanager管理SDK组件:
sdkmanager --list_installedsdkmanager --uninstall 'platforms;android-26'sdkmanager --install 'platforms;android-26'完整文档参见sdkmanager官方文档。
推荐设置以下JVM参数:
shorg.gradle.jvmargs=-Xmx8192m -XX:MaxMetaspaceSize=1024m -XX:+UseContainerSupport -XX:MaxRAMPercentage=97.5
参数说明:
-Xmx8192m:JVM最大内存(支持g为单位)-XX:MaxMetaspaceSize=1024m:元空间最大大小(修复Gradle bug gradle/gradle#***)-XX:+UseContainerSupport:允许JVM感知容器环境(默认启用)-XX:MaxRAMPercentage=97.5:JVM最大使用容器内存的97.5%容器总内存应大于Xmx + MaxMetaspaceSize + 预留空间(如10GB容器可分配8GB Xmx + 1GB MaxMetaspaceSize + 1GB预留)。
在Bitbucket仓库的bitbucket-pipelines.yml中指定该镜像:
ymlimage: mingc/android-build-box:latest pipelines: default: - step: caches: - gradle - gradle-wrapper - android-emulator script: - . ~/.bash_profile - jenv global 11 # 切换Java版本 - bash ./gradlew assemble definitions: caches: gradle-wrapper: ~/.gradle/wrapper android-emulator: $ANDROID_HOME/system-images/android-21
示例.github/workflows/main.yml:
ymlname: CI on: [push] jobs: build: runs-on: ubuntu-20.04 container: mingc/android-build-box:latest steps: - uses: actions/checkout@v3 - uses: actions/cache@v3 with: path: /root/.gradle/caches key: ${{ runner.os }}-gradle-${{ hashFiles('**/*.gradle') }} restore-keys: | ${{ runner.os }}-gradle- - name: Build run: | echo "Work dir: $(pwd)" echo "User: $(whoami)" flutter --version flutter analyze flutter build apk - name: Archive apk uses: actions/upload-artifact@v3 with: name: apk path: build/app/outputs/apk - name: Test run: flutter test - name: Clean build to avoid action/cache error run: rm -fr build
以下脚本创建并启动ARM模拟器(用于集成测试/ instrumentation测试):
sh#!/bin/bash export ADB_INSTALL_TIMEOUT=30 # 增加ADB超时时间 # 下载ARM系统镜像 sdkmanager "system-images;android-22;default;armeabi-v7a" # 创建AVD模拟器(100MB SD卡) echo "no" | avdmanager create avd \ -n Android_5.1_API_22 \ -k "system-images;android-22;default;armeabi-v7a" \ -c 100M \ --force # 后台启动模拟器 $ANDROID_HOME/emulator/emulator -avd Android_5.1_API_22 -no-skin -no-audio -no-window -no-boot-anim -gpu off & # 需添加延迟等待模拟器启动
注意:暂不支持x86_64模拟器,详见https://github.com/mingchen/docker-android-build-box/issues/18%E3%80%82
1.23.0及以上版本使用jEnv管理Java版本(旧版本使用update-alternatives,文档见https://github.com/mingchen/docker-android-build-box/tree/95fde4a765cecf6d43b084190394fd43bef5bfd1#choose-the-system-java-version%EF%BC%89%E3%80%82
使用jEnv前需加载环境:
sh. ~/.bash_profile
查看可用Java版本:
shjenv versions
设置全局Java 8:
shjenv global 1.8
设置当前目录Java版本(会创建.java-version文件):
shjenv local 11
构建前确保有足够磁盘空间(镜像大小约10-16GB)。需Docker Engine 19.03+(支持buildx)。
shdocker buildx build -t android-build-box .
支持三种构建目标(默认complete-flutter):
| 构建目标 | SDK CLI工具 | jEnv | platform-tools | 平台/构建工具 | bundletool | NDK | Fastlane/Rake | Node等 | Flutter |
|---|---|---|---|---|---|---|---|---|---|
| minimal | ✅ | ✅ | ✅ | ❌ | ❌ | ❌ | ❌ | ❌ | ❌ |
| complete | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ❌ |
| complete-flutter | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ |
默认安装最新软件,可通过构建参数指定版本(需设置_TAGGED=tagged):
shdocker buildx build --target minimal \ --build-arg ANDROID_SDK_TOOLS_TAGGED="tagged" \ --build-arg ANDROID_SDK_TOOLS_VERSION="4333796" \ --build-arg JENV_TAGGED="tagged" \ --build-arg JENV_RELEASE="0.5.6" .
详见https://github.com/mingchen/docker-android-build-box/blob/master/CHANGELOG.md%E3%80%82
详见https://github.com/mingchen/docker-android-build-box/blob/master/COMPATIBILITY.md%E3%80%82
欢迎通过https://github.com/mingchen/docker-android-build-box/pull/new/master%E6%94%B9%E8%BF%9B%E9%95%9C%E5%83%8F%E3%80%82%E6%96%87%E6%A1%A3%E4%BF%AE%E6%94%B9%E8%AF%B7%E4%BB%A5%60DOCS:%60%E4%B8%BA%E6%8F%90%E4%BA%A4%E5%89%8D%E7%BC%80%EF%BC%8CCI%E9%85%8D%E7%BD%AE%E4%BF%AE%E6%94%B9%E4%BB%A5%60CI:%60%E4%B8%BA%E5%89%8D%E7%BC%80%E3%80%82
您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。
探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式
通过 Docker 登录认证访问私有仓库
无需登录使用专属域名
Kubernetes 集群配置 Containerd
K3s 轻量级 Kubernetes 镜像加速
VS Code Dev Containers 配置
Podman 容器引擎配置
HPC 科学计算容器配置
ghcr、Quay、nvcr 等镜像仓库
Harbor Proxy Repository 对接专属域名
Portainer Registries 加速拉取
Nexus3 Docker Proxy 内网缓存
需要其他帮助?请查看我们的 常见问题Docker 镜像访问常见问题解答 或 提交工单
docker search 限制
站内搜不到镜像
离线 save/load
插件要用 plugin install
WSL 拉取慢
安全与 digest
新手拉取配置
镜像合规机制
manifest unknown
no matching manifest(架构)
invalid tar header(解压)
TLS 证书失败
DNS 超时
域名连通性排查
410 Gone 排查
402 与流量用尽
401 认证失败
429 限流
D-Bus 凭证提示
413 与超大单层
来自真实用户的反馈,见证轩辕镜像的优质服务