解决两个 Android 模拟器之间无法网络通信的问题

简介: 让同一个 PC 上运行的两个 Android 模拟器之间能相互通信,出(qiong)差(ren)的智慧。

本文解决的是一个小众场景的问题:

出差在外,需要调试局域网内的两台 Android 设备之间通过 TCP 通信的情况,可手边又不是随时有多台可用的设备,于是想在笔记本上同时跑两台 Android 模拟器来构造调试环境,但是发现它俩的 IP 地址竟然都是 10.0.2.15,场面一度十分尴尬……

图片

谷狗之后,众多相关的博客和问答贴将我引向了官方文档页面:

Interconnecting emulator instances

原来官方指南上解释过相关的知识,现将我关心和以前迷惑的部分翻译摘录如下,如果希望对此有个更全面的了解,还是推荐完整阅读 Android 官方文档里有关 Emulator 的章节 https://developer.android.com/studio/run/emulator.html

首先讲一点预备知识,再说解决方案。

模拟器的网络地址空间

每个模拟器都运行在一个虚拟路由/防火墙服务后面,这个服务将模拟器和宿主机器的网络接口、配置以及 Internet 隔离开来。对模拟器而言,宿主机器和其它模拟器对它是不可见的,它只知道自己是通过以太网连接到路由/防火墙。

每个模拟器的虚拟路由管理 10.0.2/24 的网络地址空间,所有地址都是 10.0.2.xx 格式。地址预分配的情况如下:

图片

另外一点就是模拟器上的 127.0.0.1 是指它自己,所以如果想访问宿主机器上运行的服务,要使用 10.0.2.2。需要注意的是所有模拟器的网络地址分配都是一样的,这样一来,如果有两个模拟器同时运行在一台电脑上,它们都会有各自的路由,并且给两个模拟器分配的 IP 都是 10.0.2.15。它们被路由隔离,相互不可见。

实现两台模拟器之间的通信

现在来解决标题和文首提到的问题,主要用到了网络重定向。

假设开发环境是:

  • PC 是指运行模拟器的宿主电脑

  • emulator-5554 是模拟器 1,将在 TCP 通信中作为 server 端

  • emulator-5556 是模拟器 2,将在 TCP 通信中作为 client 端

配置步骤:

  1. 在 emulator-5554 上运行 server,侦听 10.0.2.15:58080

  2. 在 PC 上运行 cat~/.emulator_console_auth_token,得到一个 token

  3. 在 PC 上依次运行

    telnet localhost 5554

    auth

    redir add tcp:51212:58080

    <token> 是指第 2 步中得到的 token。

    51212 是 PC 端口,58080 是 5554 模拟器的端口。

  4. 在 emulator-5556 上运行 client 程序,连接 10.0.2.2:51212

至此,两台模拟器之间已经可以通过 TCP 愉快地通信了。

它们之间的网络连接和通信示意图如下:

图片

注:

  • 以上步骤中用到的端口号都是可以根据你的需求替换的

  • Windows 下 telnet 命令默认没有启用,具体启用方法请搜狗一下

模拟器的网络限制

  1. 模拟器上运行的 Apps 可以连接到宿主电脑上的网络,但这是通过模拟器间接实现,不是直接连到宿主电脑的网卡。模拟器可以看作是宿主电脑上运行的一个普通程序。

  2. 因为模拟器的特殊网络配置,可能无法支持一些网络协议,比如 ping 命令使用的 ICMP 协议。目前,模拟器不支持 IGMP 和 multicast。

    试验了一下,模拟器的 shell 里 ping www.sogou.com 一直卡在那,在手机的 shell 里就可以。

额外的发现

在阅读 Android 官方文档里关于模拟器的章节时,意外地发现有一节 Sending a voice call or SMS to another emulator instance

就是说模拟器可以给另外的模拟器打电话和发短信,电话号码就是端口号,比如 emulator-5554 模拟器,电话号码就是 5554,这个号码也可以从模拟器的窗口标题栏上找到,比如 AndroidEmulator-Nexus_5X_API_19:5554,里面那个 5554 就是。

后话

天下博文,大部分都逃不出官方文档与公开源码的范畴(比如本文就是),而且都是选定文档里讲的某一小部分来进行讲解演绎,这在作为扩展视野、快速上手、快速解决问题等用途时还是比较实用的,但如果想系统、全面地学习,官方文档一般是更好的选择。

目录
相关文章
|
17天前
|
存储 弹性计算 人工智能
阿里云Alex Chen:普惠计算服务,助力企业创新
本文整理自阿里云弹性计算产品线、存储产品线产品负责人陈起鲲(Alex Chen)在2024云栖大会「弹性计算专场-普惠计算服务,助力企业创新」中的分享。在演讲中,他分享了阿里云弹性计算,如何帮助千行百业的客户在多样化的业务环境和不同的计算能力需求下,实现了成本降低和效率提升的实际案例。同时,基于全面升级的CIPU2.0技术,弹性计算全线产品的性能、稳定性等关键指标得到了全面升级。此外,他还宣布了弹性计算包括:通用计算、加速计算和容器计算的全新产品家族,旨在加速AI与云计算的融合,推动客户的业务创新。
|
24天前
|
存储 人工智能 弹性计算
产品技术能力飞跃,阿里云E-HPC荣获“CCF 产品创新奖”!
9月24日,在中国计算机学会举办的“2024 CCF 全国高性能计算学术年会”中,阿里云弹性高性能计算(E-HPC)荣获「 CCF HPC China 2024 产品创新奖」。这也是继 2022 年之后,阿里云E-HPC 再次荣获此奖项,代表着阿里云在云超算领域的持续创新结果,其产品能力和技术成果得到了业界的一致认可。
|
7天前
|
SQL 人工智能 安全
【灵码助力安全1】——利用通义灵码辅助快速代码审计的最佳实践
本文介绍了作者在数据安全比赛中遇到的一个开源框架的代码审计过程。作者使用了多种工具,特别是“通义灵码”,帮助发现了多个高危漏洞,包括路径遍历、文件上传、目录删除、SQL注入和XSS漏洞。文章详细描述了如何利用这些工具进行漏洞定位和验证,并分享了使用“通义灵码”的心得和体验。最后,作者总结了AI在代码审计中的优势和不足,并展望了未来的发展方向。
|
3天前
|
负载均衡 算法 网络安全
阿里云WoSign SSL证书申请指南_沃通SSL技术文档
阿里云平台WoSign品牌SSL证书是由阿里云合作伙伴沃通CA提供,上线阿里云平台以来,成为阿里云平台热销的国产品牌证书产品,用户在阿里云平台https://www.aliyun.com/product/cas 可直接下单购买WoSign SSL证书,快捷部署到阿里云产品中。
1843 6
阿里云WoSign SSL证书申请指南_沃通SSL技术文档
|
1天前
|
存储 安全 Oracle
【灵码助力安全3】——利用通义灵码辅助智能合约漏洞检测的尝试
本文探讨了智能合约的安全性问题,特别是重入攻击、预言机操纵、整数溢出和时间戳依赖性等常见漏洞。文章通过实例详细分析了重入攻击的原理和防范措施,展示了如何利用通义灵码辅助检测和修复这些漏洞。此外,文章还介绍了最新的研究成果,如GPTScan工具,该工具通过结合大模型和静态分析技术,提高了智能合约漏洞检测的准确性和效率。最后,文章总结了灵码在智能合约安全领域的应用前景,指出尽管存在一些局限性,但其在检测和预防逻辑漏洞方面仍展现出巨大潜力。
|
6天前
|
Web App开发 算法 安全
什么是阿里云WoSign SSL证书?_沃通SSL技术文档
WoSign品牌SSL证书由阿里云平台SSL证书合作伙伴沃通CA提供,上线阿里云平台以来,成为阿里云平台热销的国产品牌证书产品。
1778 2
|
15天前
|
编解码 Java 程序员
写代码还有专业的编程显示器?
写代码已经十个年头了, 一直都是习惯直接用一台Mac电脑写代码 偶尔接一个显示器, 但是可能因为公司配的显示器不怎么样, 还要接转接头 搞得桌面杂乱无章,分辨率也低,感觉屏幕还是Mac自带的看着舒服
|
22天前
|
存储 人工智能 缓存
AI助理直击要害,从繁复中提炼精华——使用CDN加速访问OSS存储的图片
本案例介绍如何利用AI助理快速实现OSS存储的图片接入CDN,以加速图片访问。通过AI助理提炼关键操作步骤,避免在复杂文档中寻找解决方案。主要步骤包括开通CDN、添加加速域名、配置CNAME等。实测显示,接入CDN后图片加载时间显著缩短,验证了加速效果。此方法大幅提高了操作效率,降低了学习成本。
5030 15
|
9天前
|
人工智能 关系型数据库 Serverless
1024,致开发者们——希望和你一起用技术人独有的方式,庆祝你的主场
阿里云开发者社区推出“1024·云上见”程序员节专题活动,包括云上实操、开发者测评和征文三个分会场,提供14个实操活动、3个解决方案、3 个产品方案的测评及征文比赛,旨在帮助开发者提升技能、分享经验,共筑技术梦想。
1018 147
|
17天前
|
存储 缓存 关系型数据库
MySQL事务日志-Redo Log工作原理分析
事务的隔离性和原子性分别通过锁和事务日志实现,而持久性则依赖于事务日志中的`Redo Log`。在MySQL中,`Redo Log`确保已提交事务的数据能持久保存,即使系统崩溃也能通过重做日志恢复数据。其工作原理是记录数据在内存中的更改,待事务提交时写入磁盘。此外,`Redo Log`采用简单的物理日志格式和高效的顺序IO,确保快速提交。通过不同的落盘策略,可在性能和安全性之间做出权衡。
1582 12