Ubuntu+Docker+内网穿透:保姆级教程实现安卓开发环境远程部署
文章目录
- 前言
- 1. 虚拟化环境检查
- 2. Android 模拟器部署
- 3. Ubuntu安装Cpolar
- 4. 配置公网地址
- 5. 远程访问
- 小结
- 6. 固定Cpolar公网地址
- 7. 固定地址访问
前言
本文将详细介绍一种创新性的云开发架构:基于Ubuntu系统构建Android仿真容器环境,并集成安全隧道技术实现远程访问。这种技术组合打破了传统开发的空间限制,使开发者能够实时调用本地资源,显著提升分布式团队的协作效能。
在移动应用开发领域,随着项目复杂度的持续增长,传统开发环境配置正面临两大核心痛点:配置流程繁琐、运维开销大。本文提出的容器技术方案通过模块化封装Android开发环境,有效降低了环境初始化的难度。其核心价值体现在环境复用效率提升,开发者可快速部署标准化开发环境,避免重复配置硬件参数的繁琐操作。
针对远程开发需求,本方案采用加密隧道技术实现私有服务的公网暴露。通过构建安全通信通道,可使异地团队成员无缝接入本地开发环境。这种技术架构特别适用于敏捷开发模式,推荐采用Ubuntu系统作为部署基础。如需了解Docker环境搭建细节,请参考本系列配套教程:Docker 安装教程。
1. 虚拟化环境检查
执行下面命令安装检查工具
sudo apt install cpu-checker
然后执行下面命令检查是否支持虚拟化
kvm-ok
提示下面信息表示正常支持虚拟化环境,如果不是出现如下信息,需要检查设备开启虚拟化支持,然后再进行下面进行android 模拟器部署
2. Android 模拟器部署
本文采用docker方式部署,首先拉取一个镜像,官方提供很多种安卓版本,具体可以访问Github查看:https://github.com/budtmo/docker-android,理论上版本越高运行的开销会越大,所以本例以运行一个低版本的android 来演示,执行下面命令拉取一个android 9.0版本镜像.
sudo docker pull budtmo/docker-android:emulator_9.0
拉取后开始运行容器,下面命令指运行一台Samsung Galaxy S7 的安卓设备,其他机型可以去看一下官方教程,对外访问端口是6080
docker run -d -p 6080:6080 -e EMULATOR_DEVICE="Samsung Galaxy S7" -e WEB_VNC=true --device /dev/kvm --name android-container budtmo/docker-android:emulator_9.0
运行后,输入sudo docker ps 可以看到运行的容器,UP状态表示正常
运行后,在浏览器访问Linux ubuntu 6080端口,即可成功看到android 模拟器界面,首次启动可能会比较慢,如果觉得卡,可以部署更低的机型,如S6,本地测试访问成功后,下面我们安装cpolar内网穿透,实现远程访问
3. Ubuntu安装Cpolar
上面在本地Docker中成功部署了Android模拟器,并局域网访问成功,下面我们在Linux安装Cpolar内网穿透工具,通过Cpolar 转发本地端口映射的http公网地址,我们可以很容易实现远程访问,而无需自己注册域名购买云服务器.下面是安装cpolar步骤
cpolar官网地址: https://www.cpolar.com
- 使用一键脚本安装命令
curl -L https://www.cpolar.com/static/downloads/install-release-cpolar.sh | sudo bash
- 安装完成后,可以通过如下方式来操作cpolar服务,首先执行加入系统服务设置开机启动,然后再启动服务
# 加入系统服务设置开机启动
sudo systemctl enable cpolar# 启动cpolar服务
sudo systemctl start cpolar# 重启cpolar服务
sudo systemctl restart cpolar# 查看cpolar服务状态
sudo systemctl status cpolar# 停止cpolar服务
sudo systemctl stop cpolar
Cpolar安装和成功启动服务后,内部或外部浏览器上通过局域网IP加9200端口即:【http://192.168.xxx.xxx:9200】访问Cpolar管理界面,使用Cpolar官网注册的账号登录,登录后即可看到cpolar web 配置界面,接下来在web 界面配置即可
4. 配置公网地址
点击左侧仪表盘的隧道管理——创建隧道,创建一个android 模拟器的公网http地址隧道!
- 隧道名称:可自定义命名,注意不要与已有的隧道名称重复
- 协议:选择http
- 本地地址:6080(docker部署后对外访问的端口)
- 域名类型:免费选择随机域名
- 地区:选择China vip
点击创建
隧道创建成功后,点击左侧的状态——在线隧道列表,查看所生成的公网访问地址,有两种访问方式,一种是http 和https,两种都可以访问,下面选择其中一种进行远程访问
5. 远程访问
使用上面Cpolar生成的 https公网地址,在任意设备的浏览器进行访问,即可成功看到我们Android 模拟器,简单几步即可实现无需云服务器,无需公网IP实现远程访问.
小结
为了更好地演示,我们在前述过程中使用了cpolar生成的隧道,其公网地址是随机生成的。
这种随机地址的优势在于建立速度快,可以立即使用。然而,它的缺点是网址由随机字符生成,不太容易记忆(例如:3ad5da5.r10.cpolar.top)。另外,这个地址在24小时内会发生随机变化,更适合于临时使用。
我一般会使用固定二级子域名,原因是我希望将网址发送给同事或客户时,它是一个固定、易记的公网地址(例如:android.cpolar.cn),这样更显正式,便于流交协作。
6. 固定Cpolar公网地址
由于以上使用cpolar所创建的隧道使用的是随机公网地址,24小时内会随机变化,不利于长期远程访问。因此我们可以为其配置二级子域名,该地址为固定地址,不会随机变化。
注意需要将cpolar套餐升级至基础套餐或以上,且每个套餐对应的带宽不一样。【cpolar.cn已备案】
登录cpolar官网,点击左侧的预留,选择保留二级子域名,设置一个二级子域名名称,点击保留,保留成功后复制保留的二级子域名名称
保留成功后复制保留成功的二级子域名的名称
返回登录cpolar web UI管理界面,点击左侧仪表盘的隧道管理——隧道列表,找到所要配置的隧道,点击右侧的编辑
修改隧道信息,将保留成功的二级子域名配置到隧道中
- 域名类型:选择二级子域名
- Sub Domain:填写保留成功的二级子域名
点击更新
(注意,点击一次更新即可,不需要重复提交)
更新完成后,打开在线隧道列表,此时可以看到公网地址已经发生变化,地址二级名称变成了我们自己设置的二级子域名名称
7. 固定地址访问
最后,我们使用固定的公网https地址访问,可以看到同样访问成功,这样一个固定且永久不变的公网地址就设置好了,随时随地都可以远程访问本地android模拟器,无需公网IP,无需云服务器!
经过本阶段的实操演练,用户已熟练掌握基于Ubuntu平台的Android开发环境容器化部署技术。该技术方案通过Docker构建Android仿真系统,配合内网穿透技术突破地理限制,成功搭建了具备远程接入能力的开发平台。这种架构不仅解决了传统开发环境配置效率低、维护成本高的难题,更构建了支持分布式团队协作的可靠技术底座。
建议立即应用该技术架构,开发者可在任意网络条件下快速启动开发环境。除基础功能外,该方案具备良好的可扩展性,支持CI/CD测试流程、多终端兼容性验证等高级应用场景。为提升团队协作效能,建议将该容器化方案推广至开发小组,共同体验云端开发带来的效率革新。
预祝各位同仁工作顺利,技术精进。本方案将持续迭代优化,期待与您共同探索更多技术可能性。