gounthar/docker-adb本仓库包含Android Debug Bridge的Dockerfile。它让你能够使用adb和fastboot等平台工具。
adb -a -P 5037 server nodaemon。不要再使用fork-server参数。.android目录路径问题。感谢@alexislg2发现此问题!/dev/bus/usb挂载到容器中容器预加载了用于认证的RSA密钥,因此无需在每次运行容器时在设备上接受新密钥(通常密钥由adb二进制文件按需生成)。虽然方便,但这意味着拥有该密钥的其他人可通过ADB访问你的设备。你可通过docker run时使用-v /your/key_folder:/root/.android来提供自定义密钥。
若你认为平台工具已过时且无法等待新镜像,可使用以下命令更新平台工具:
shupdate-platform-tools.sh
该脚本位于/usr/local/bin,已添加到$PATH中。
本镜像有多种使用方式,以下列出部分可能的使用模式。根据情况有时可混合使用,也不限于以下模式,若有其他适用方式可自行尝试。
此模式将ADB服务器容器的网络与ADB客户端容器共享。
启动服务器:
docker run -d --privileged -v /dev/bus/usb:/dev/bus/usb --name adbd sorccu/adb
然后在同一机器上:
docker run --rm -ti --net container:adbd sorccu/adb adb devices docker run --rm -i --net container:adbd ubuntu nc localhost 5037 <<<000chost:devices
优点:
adb forward无需额外配置(但转发仅对客户端容器可见)此模式将ADB服务器直接绑定到主机网络。
启动服务器:
docker run -d --privileged --net host -v /dev/bus/usb:/dev/bus/usb --name adbd sorccu/adb
然后在同一机器上:
docker run --rm -ti --net host sorccu/adb adb devices docker run --rm -i --net host ubuntu nc localhost 5037 <<<000chost:devices
或在其他机器上:
docker run --rm -ti sorccu/adb adb -H x.x.x.x -P 5037 devices
优点:
adb forward无需额外配置(转发对其他机器可见)缺点:
此模式将ADB服务器容器的网络与ADB客户端容器共享。
启动服务器:
docker run -d --privileged -v /dev/bus/usb:/dev/bus/usb --name adbd sorccu/adb
然后在同一机器上:
docker run --rm -ti --link adbd:adbd sorccu/adb \ sh -c 'adb -H $ADBD_PORT_5037_TCP_ADDR -P 5037 devices'
优点:
adb forward无需额外配置(转发通过指定IP对客户端容器可见)缺点:
-H $ADBD_PORT_5037_TCP_ADDR向adb传递服务器IP此模式最适合从远程主机访问ADB服务器。
启动服务器:
docker run -d --privileged -v /dev/bus/usb:/dev/bus/usb --name adbd -p 5037:5037 sorccu/adb
然后在客户端主机上:
docker run --rm -ti sorccu/adb adb -H x.x.x.x -P 5037 devices
其中x.x.x.x是服务器主机的IP地址。
优点:
缺点:
adb forward转发的端口)systemd/文件夹中提供了示例systemd单元文件。
| 单元 | 角色 | 用途 |
|---|---|---|
| adb-image.service | 支持 | 从Docker Hub拉取镜像 |
| adbd-container.service | 支持 | 基于adb镜像创建ADB守护进程容器,但不运行 |
| adbd.service | 主要 | 运行已准备好的ADB守护进程容器并确保其持续运行 |
这种三单元配置虽然稍复杂,但具有显著优势:故障时启动速度极快,因为adbd.service的所有准备工作已完成,无需额外操作。adb镜像仅在开机时拉取一次,而非每次启动(或通过systemctl restart adb-image手动触发,这也会重启其他单元)。
将单元文件复制到目标机器的/etc/systemd/system/目录。
然后启用adbd.service以确保开机后自动启动:
shsystemctl enable adbd
最后,重启机器或手动启动服务:
shsystemctl start adbd
若修改单元文件,需运行systemctl daemon-reload使其生效。
参见LICENSE。
探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式
通过 Docker 登录认证访问私有仓库
在 Linux 系统配置镜像服务
在 Docker Desktop 配置镜像
Docker Compose 项目配置
Kubernetes 集群配置 Containerd
K3s 轻量级 Kubernetes 镜像加速
VS Code Dev Containers 配置
MacOS OrbStack 容器配置
在宝塔面板一键配置镜像
Synology 群晖 NAS 配置
飞牛 fnOS 系统配置镜像
极空间 NAS 系统配置服务
爱快 iKuai 路由系统配置
绿联 NAS 系统配置镜像
QNAP 威联通 NAS 配置
Podman 容器引擎配置
HPC 科学计算容器配置
ghcr、Quay、nvcr 等镜像仓库
无需登录使用专属域名
需要其他帮助?请查看我们的 常见问题Docker 镜像访问常见问题解答 或 提交工单
免费版仅支持 Docker Hub 访问,不承诺可用性和速度;专业版支持更多镜像源,保证可用性和稳定速度,提供优先客服响应。
专业版支持 docker.io、gcr.io、ghcr.io、registry.k8s.io、nvcr.io、quay.io、mcr.microsoft.com、docker.elastic.co 等;免费版仅支持 docker.io。
当返回 402 Payment Required 错误时,表示流量已耗尽,需要充值流量包以恢复服务。
通常由 Docker 版本过低导致,需要升级到 20.x 或更高版本以支持 V2 协议。
先检查 Docker 版本,版本过低则升级;版本正常则验证镜像信息是否正确。
使用 docker tag 命令为镜像打上新标签,去掉域名前缀,使镜像名称更简洁。
来自真实用户的反馈,见证轩辕镜像的优质服务