1 adb 架构
ADB
: Android Debug Birdge 即Android调试桥,是一个 Android 的命令行工具,可以用来连接并监控调试模拟器或实际的移动设备。adb 命令便于执行各种设备操作(例如安装和调试应用),并提供对 Unix shell(可用来在设备上运行各种命令)的访问权限。它是一种客户端-服务器
程序。
ADB 分为三部分:PC上的adb client
和 adb server
以及Android设备上的adb daemon(adbd)
。
客户端(adb client)
:在 PC 运行,用于发送命令。客户端在开发计算机上运行。您可以通过发出 adb 命令从命令行终端调用客户端,发送命令时,首先检测 PC 上有没有启动 Server,如果后台没有 Server,则自动启动一个 Server,然后将命令发送到 Server,并不关心命令发送过去以后会怎样。
守护进程 (adbd)
:在设备上运行命令。守护进程在每个设备上作为后台进程运行。当手机正确俩捏到 PC 上,并且 adb server 能够连接上 daemon 时,server 将手机的状态标记为 online
,否则为 offline
,这意味着 server 发现了一个新设备,但是不能成功连接到 daemon。
服务器(adb server)
:在 PC 运行,管理客户端和守护进程之间的通信。服务器在开发计算机上作为后台进程运行。ADB Server 维护着一个“已连接的设备的列表”,并且为每一个设备标记了一个状态:offline,bootloader,recovery 或者 online
;Server 一直在做一些循环和等待
,以协调 client 和 Server 还有 daemon 之间的通信。
PC 和 Android 设别是一个多对多
的关系:一个PC 可以连接多个Android设备;一个Android设备也可以连接多个PC。
2 adb 通信逻辑
当启动某个 adb 客户端时,客户端会先检查是否有 adb 服务器进程正在运行。如果没有,它将启动服务器进程。服务器在启动后会与本地 TCP 端口 5037
绑定,并监听 adb 客户端发出的命令 - 所有 adb 客户端均通过端口 5037
与 adb 服务器通信。然后,服务器会与所有正在运行的设备建立连接。它通过扫描 5555 到 5585
之间(该范围供前 16 个模拟器使用)的奇数号端口查找模拟器。服务器一旦发现 adb 守护进程 (adbd),便会与相应的端口建立连接。
adb client 与 adb server 之间是通过 tcp 进行通信,adb server 和 adbd 通过 usb 或者 tcp 进行通信。ADB Server 对本地的 TCP5037 端口进行监听,等待 ADB Client 的命令。ADB Client 每个命令都包含两个部分,前一部分包含固定四个字节,以十六进制的方式指明指令的长度,后一部分才是真正的指令内容。
三者之间的通信涉及到两条通讯通道:
- Client<–>Server<—>Daemon
总结
:在终端输入 adb 命令后都发生了什么?
- adb client 调用 adb 命令
- adb 进程 fork 出一个子进程作为 adb server
- adb server 查找当前可连接的设备
- server 在 5037 端口监听来自 adb client 的请求
- adb server 处理请求,比如 adb version 就是 server 可以直接处理的,处理不掉的发给 device,比如 adb devices
- adbd 拿到请求后交给 Java 虚拟器进程
- adbd 将结果返回给 adb server
- adb server 将结果返回给 adb client
3 adb 命令
3.1 adb 命令分类
Client发送的指令也分为三种:
- 不需要经过Server处理就能成功的,如adb version,adb help。
- 需要和Server通讯,但不需要和Demon通讯的指令,如adb devices.
- 需要Daemon进行处理的命令。
3.2 adb 常用命令
- adb start-server 启动 adb server
- adb kill-server 关闭 adb server
- adb devices 获取连接的设备
- adb install path_to_apk 安装 apk,加-r 参数表示覆盖安装
- adb pull remote local 从 Android 设备上获取文件到本地
- adb push local remote 从本地推送文件到 Android 设备上
- adb uninstall pkg_name 移除此应用软件包。添加 -k 选项可保存数据和缓存目录
- adb bugreport path 将 bugreport 输出到指定路径,可以用此命令获取各应用耗电量,然后用 battry-history 工具进行分析
- adb logcat 查看系统运行日志
- adb get-serialno 获取设备序列号
- adb shell 在目标设备中启动远程交互式 shell,例如执行 am、pm、dumpsys 命令
3.3 adb 连接设备/断开设备
3.3.1 USB模式连接
-
(1) 安卓设备打开开发者模式,启用usb调试
-
(2) CMD窗口输入adb devices,此时可以看到自己的设备
注意:无法看到自己设备时,查看手机USB调试是否打开;PC端是否安装手机驱动。
3.3.2 WIFI模式连接
使用WIFI连接要求
- (1) PC 和 安卓设备在同一个WIFI下
- (2) 使用WIFI连接都需先使用USB连接,通过USB连接进行配置WIFI连接,配置好后就可以拔掉USB线,然后通过WIFI连接。
3.3.2.1 连接一
# 先使用USB连接
adb shell # 进入安卓手机操作
setprop service.adb.tcp.port 5555 # 设置adbd绑定监听的端口号
stop adb
start adb # stop adb 和 start adb 相当于重启adbd
exit # 退出安卓手机
# 可以拔掉USB线,使用WIFI模式连接
adb connect 192.168.0.181:5555 # PC上client 通过 server 连接安卓手机 adbd
adb devices # 验证是否连接安卓手机
service.adb.tcp.port
:
- >0 , adbd将监听网络对应的端口(一般为5555)
- <=-1,adbd将监听USB ,默认就是-1。
3.3.2.2 WIFI方式连接二
# 先使用USB连接
adb tcpip 5555 # 操作成功会提示:restarting in TCP mode port 5555 # 表示使用tcpip模式连接
adb kill-server # 杀掉server服务,在WIFI连接时会重新fork一个server服务
# 可以拔掉USB线,使用WIFI模式连接
adb connect 192.168.0.148(手机的IP地址) # PC上client 通过 server 连接安卓手机 adbd
adb devices # 验证是否连接安卓手机
3.3.2.3 WIFI 无线调试下 连接与断开连接的指令
adb connect 192.168.0.181 连接设备
adb disconnect 192.168.0.181 断开设备连接
3.3.2.4 USB调试模式与WIFI调试模式切换
adb usb 切换到USB模式
adb tcpip 5555 切换到WIFI无线调试
[参考博客]
用了 adb 这么久,看了这篇才明白
ADB 工作原理