当前位置:   article > 正文

Android Studio远程连接模拟器调试_android studio 远程调试

android studio 远程调试

需求

Android Studio 高版本已经可以使用 Pair Devices Using Wi-fi 功能连接同一局域网下的真机设备了,低版本也可以使用Android adb wifi 插件完成无线调试,还是比较方便的。但是,如何连接同一局域网下的模拟器,实现远程调试呢?这是本文需要解决的问题。

由于个人开发条件受限,模拟器运行内存消耗不小,在一个机器上开发调试设备压力比较大,切换窗口查看也不是很方便。平时工作时,是两台设备使用Mouse without Borders 共享键鼠,但毕竟是两个主机,交互有些不方便。在一台机器上开发,在另一台机器上运行模拟器调试,就是我的需求了。

ADB端口说明

模拟器运行时会有一个启动控制台,第一个模拟器控制台默认端口是5554,对应的ADB连接端口是5555。两个端口号默认相邻,ADB端口比控制台端口大1。对应关系举例如下:

模拟器 1,控制台:5554
模拟器 1,adb:5555
模拟器 2,控制台:5556
模拟器 2,adb:5557
依此类推

知道了端口关系,才能输对连接命令。

远程连接步骤

这里将运行AndroidStudio的主机称为开发端,将运行模拟器的主机称为调试端。

启动模拟器

启动模拟器之前需要安装模拟器,这里使用Android Studio AVD Manager 事先生成好的模拟器。因为不需要启动Android Studio,所以这里直接使用命令行的方式启动模拟器。

找到Android Sdk安装目录,我的是:

C:\Users\user\AppData\Local\Android\Sdk\
  • 1

和模拟器文件所在目录,我的是:

C:\Users\user\.android\avd
  • 1

模拟器目录下会有模拟器的名称,启动命令中会用到。
启动命令如下:

.\emulator\emulator.exe -avd Pixel_XL_API_31
  • 1

emulator.exe在 android Sdk 目录下的emulator目录里。-avd 参数指定要启动的模拟器名称。

启动后,保持控制台窗口开启,不然会关闭模拟器。输入Ctrl+C可手动关闭模拟器。

如果启动失败需要查看端口是否被其他程序占用,默认启动的第一个模拟器需要 5554,5555两个端口都可用。

由于模拟器启动占用了控制台,我们需要另开控制台执行后续命令。

查看端口占用:

Netstat -ano|findstr "5554"
  • 1

ADB连接

模拟器运行之后,需要连接ADB,完成桥接。然后在开发端连接调试端的ADB接口。

模拟器启动时一般会自动启动ADB服务。

ADB可执行程序所在位置在Android Sdk目录下的platform-tools目录下。

查看启动的模拟器名称和控制台端口:

.\platform-tools\adb.exe devices
  • 1

可以看到输出结果为:

List of devices attached
emulator-5554
  • 1
  • 2

表明,模拟器控制台端口为5554,那么可知adb连接端口为5555。

端口映射

现在adb已经连接了模拟器,端口为5555,但是仅能在本地访问。要想在开发端连接模拟器,还需要将端口映射到外网。

相关命令如下:

添加端口转发:
netsh interface portproxy add v4tov4 5555 127.0.0.1 5555

查看端口转发情况:
netsh interface portproxy show all

删除端口转发:
netsh interface portproxy delete v4tov4 listenport=5555 listenaddress=* protocol=tcp
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

正常情况下执行第一条命令即可。

要想外网访问,还需要设置防火墙以放行5555端口。

找到 Windows Defender 高级安全功能。
在这里插入图片描述
点击入站规则 - 新建规则

在这里插入图片描述
选择端口,下一步,输入放行端口 5555,其他默认,最后一步名称自取。比如:ADB远程调试5555。

远程连接

以上设置都是在调试端完成,目的就是开放模拟器的ADB连接端口5555。然后在开发端 Android Studio Terminal 窗口输入:

adb connect 192.168.0.110:5555
  • 1

192.168.0.110是调试端的ip地址,这样即可完成连接。

查看连接的设备状态:

adb devices
  • 1

补充(2023.10.22)

端口占用问题

通常很少会修改办公电脑常用服务的默认端口,一般不会有服务占用这里的 5555 端口。但有一个常见的例外 Hyper-V。该服务会在系统的“TCP动态端口范围”内随机占用端口。有时候可能会占用到我们需要的端口。

以下命令可以查看TCP动态端口范围:

netsh int ipv4 show dynamicport tcp
  • 1

查看已占用端口:

netsh int ipv4 show excludedportrange protocol=tcp
  • 1

我们可以将TCP动态端口范围调整下,以防涵盖开发的常用端口。

设置TCP动态端口范围(管理员运行):

netsh int ipv4 set dynamic tcp start=49152 num=16384
netsh int ipv6 set dynamic tcp start=49152 num=16384
  • 1
  • 2

启动多个模拟器

为了方便,我们可以在防火墙入站规则那里多放行几个端口,比如5555-5599。
然后在端口转发时,添加多个映射:

netsh interface portproxy add v4tov4 5555 127.0.0.1 5555
netsh interface portproxy add v4tov4 5557 127.0.0.1 5557
netsh interface portproxy add v4tov4 5559 127.0.0.1 5559
  • 1
  • 2
  • 3

模拟器多次启动时会自动增加端口号,导致我们需要反复添加上面的端口映射。我们可以让模拟器固定在某个端口启动:

.\emulator\emulator.exe -port 5554 -avd Pixel_XL_API_30
.\emulator\emulator.exe -port 5556 -avd Pixel_6_API_23
.\emulator\emulator.exe -port 5558 -avd Pixel_6_Pro_API_25
  • 1
  • 2
  • 3

使用 -port 指定端口号。
开发端连接模拟器时,使用端口号区分。

adb connect 192.168.0.110:5555
adb connect 192.168.0.110:5557
adb connect 192.168.0.110:5559
  • 1
  • 2
  • 3

其他问题

虽然原理很简单,但是执行命令时仍然会出现这样那样的问题,让简单的的事情变得复杂。

比如,模拟器启动之后,运行adb devices,有时候会提示 device offline。
再比如,运行命令检查端口时,Netstat -ano|findstr “5555” ,发现有个iphelper 进行占用了端口。

其实这些问题的根本原因都是端口被占用,也不是其他进程的问题,只是反复运行上面的命令或者模拟器重启后引起的。

这里提供完整的步骤,每次启动模拟器时,按顺序执行命令即可解决上面的问题。

以端口 5555 举例,其他类比。涉及路径,端口等请参考自己的开发环境。

  1. 先删除端口转发
netsh interface portproxy delete v4tov4 listenport=5555 listenaddress=* protocol=tcp
  • 1
  1. 检查端口是否占用
Netstat -ano|findstr "5555"
  • 1

如果发现有大量 TIME_WAIT 或者 CLOSE_WAIT 状态的进程占用端口,表示模拟器或者adb刚刚关闭,端口未释放,稍等一会儿再运行,直到没有任何进程占用端口。等待时间一般为4分钟。

  1. 启动adb
C:\Users\user\AppData\Local\Android\Sdk\platform-tools\adb.exe devices
  • 1
  1. 新开dos启动模拟器
C:\Users\user\AppData\Local\Android\Sdk\emulator\emulator.exe -port 5554 -avd Pixel_2_API_23
  • 1

注意端口号 -1

  1. 添加端口转发
netsh interface portproxy add v4tov4 5555 127.0.0.1 5555
  • 1
  1. 开发端连接模拟器
adb connect 192.168.0.108:5555
  • 1

启用多个模拟器,也是按照上面的步骤一个一个启动。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小小林熬夜学编程/article/detail/302313
推荐阅读
相关标签
  

闽ICP备14008679号