关于 ADB 实现的说明
I.總體概述
Android 調(diào)試橋(ADB)用于:
- 跟蹤所有連接的或運(yùn)行于給定開發(fā)者主機(jī)上的 Android 設(shè)備和模擬器實(shí)例。
- 為客戶端(命令行用戶,或像 DDMS 這樣的輔助程序)實(shí)現(xiàn)各種控制命令(比如,”adb shell”,”adb pull”,等等)。這些命令在 ADB 中稱為 ‘service’。
總的來說,一切工作通過以下組件完成:
這是一個(gè)運(yùn)行于主機(jī)上的后臺(tái)進(jìn)程。它的目的是為了感知USB端口,以了解何時(shí)連接/移除設(shè)備,以及模擬器實(shí)例何時(shí)啟動(dòng)/停止。
它必須維護(hù)一個(gè) “已連接設(shè)備” 列表并為它們中的每一個(gè)分配一個(gè) ‘狀態(tài)’:OFFLINE,BOOTLOADER,RECOVERY 或 ONLINE(下面還有更多)。
ADB server 真的是一個(gè)巨大的多路復(fù)用循環(huán),它的目的是編排客戶端,服務(wù)和設(shè)備之間的數(shù)據(jù)(包,真正的)交換。
‘a(chǎn)dbd’ 作為 Android 設(shè)備或模擬器系統(tǒng)內(nèi)的后臺(tái)進(jìn)程運(yùn)行。它的目的是連接 ADB server(對(duì)于設(shè)備來說是通過 USB,對(duì)于模擬器來說是通過 TCP)并為運(yùn)行在主機(jī)上的客戶端提供一些服務(wù)。
當(dāng) ADB server 已經(jīng)成功地連接到設(shè)備內(nèi)部的 adbd 時(shí),它才認(rèn)為設(shè)備是 ONLINE 的。否則,設(shè)備是 OFFLINE 的,這意味著 ADB server 探測到了一個(gè)新的設(shè)備/模擬器,但無法連接到 adbd 守護(hù)進(jìn)程。
BOOTLOADER 和 RECOVERY 狀態(tài)對(duì)應(yīng)于處在 bootloader 或 recovery 模式下的設(shè)備相應(yīng)的狀態(tài)。
‘a(chǎn)db’ 命令行程序用于在 shell 或腳本中運(yùn)行 adb 命令。它首先嘗試定位主機(jī)上的 ADB server,如果沒有它將會(huì)自動(dòng)地啟動(dòng)一個(gè)。
然后,客戶端給 ADB server 發(fā)送它的服務(wù)請(qǐng)求。它無需知道。
當(dāng)前,一個(gè)單獨(dú)的 ‘a(chǎn)db’ 二進(jìn)制文件同時(shí)被用作服務(wù)器和客戶端。這使得分發(fā)和啟動(dòng)服務(wù)器更簡單。
基本上有兩種客戶端可以與之交互的服務(wù)。
Host 服務(wù):
- 這些服務(wù)運(yùn)行于 ADB server 內(nèi),且一點(diǎn)也不需要與設(shè)備通信。一個(gè)典型的例子是 “adb devices”,它被用于返回當(dāng)前已知的設(shè)備和它們的狀態(tài)的列表。盡管如此,他們還是一些其他的服務(wù)。
Local 服務(wù):
這些服務(wù)或者運(yùn)行于 adbd 守護(hù)進(jìn)程內(nèi),或者由它在設(shè)備上啟動(dòng)。ADB server 用于在客戶端和運(yùn)行于 adbd 內(nèi)的服務(wù)間多路復(fù)用流。在這種情況下,它的角色是初始化連接,然后作為一個(gè)數(shù)據(jù)通道。
II. 協(xié)議細(xì)節(jié)
1. 客戶端 <-> 服務(wù)器協(xié)議
這里詳述 ADB 客戶端和 ADB server 本身之間使用的協(xié)議。ADB server 監(jiān)聽在 TCP:localhost:5037 上。
客戶端使用如下的格式發(fā)送一個(gè)請(qǐng)求:
比如,要向 ADB server 查詢它內(nèi)部的版本號(hào),客戶端將執(zhí)行如下動(dòng)作:
‘host:’ 前綴用于表示請(qǐng)求發(fā)往服務(wù)器本身(我們稍后將討論其它種類的請(qǐng)求)。內(nèi)容長度以 ASCII 編碼,以方便調(diào)試。
服務(wù)器應(yīng)該以如下幾種方式之一響應(yīng)一個(gè)請(qǐng)求:
1. 請(qǐng)求成功:4 字節(jié)的 “OKAY” 字符串
2. 請(qǐng)求失敗,4 字節(jié)的 “FAIL” 字符串,接著是一個(gè) 4 字節(jié)的十六進(jìn)制長度,接著是一個(gè)字符串給出了失敗的原因。
3. 作為一個(gè)特殊的擴(kuò)展,’host:version’,一個(gè) 4 字節(jié)的十六進(jìn)制字符串對(duì)應(yīng)于服務(wù)器的內(nèi)部版本號(hào)
注意在 OKAY 之后,連接依然是存活的,這允許客戶端執(zhí)行其它的請(qǐng)求。但是在某些情況下,OKAY 將甚至改變連接的狀態(tài)。
比如,在 ‘host:transport:’ 請(qǐng)求的情況中,其中 ‘’ 用于標(biāo)識(shí)一個(gè)給定的設(shè)備/模擬器;在 “OKAY” 應(yīng)答之后,客戶端執(zhí)行的所有進(jìn)一步的請(qǐng)求將直接進(jìn)入對(duì)應(yīng)的 adbd 守護(hù)進(jìn)程。
文件 SERVICES.TXT 列出了 ADB 當(dāng)前實(shí)現(xiàn)的所有服務(wù)。
2. 傳輸
ADB 傳輸建模了 ADB server 和一個(gè)設(shè)備或模擬器間的連接。當(dāng)前有兩種類型的傳輸:
- USB 傳輸,用于通過 USB 連接的物理設(shè)備
- 本地傳輸,用于在主機(jī)上運(yùn)行的模擬器,通過 TCP 與服務(wù)器連接
理論上來說,編寫一個(gè)本地傳輸,代理 ADB server 和連接到/運(yùn)行于另一臺(tái)機(jī)器上的設(shè)備/模擬器之間的連接應(yīng)該是可能的。盡管這還沒有完成。
每個(gè)傳輸可以攜帶一個(gè)或多個(gè)客戶端和它們指向的設(shè)備/模擬器間的多路復(fù)的用流。ADB server 必須適當(dāng)?shù)靥幚硪馔獾膫鬏斨袛?#xff08;比如,當(dāng)設(shè)備被物理拔除時(shí))。
翻譯原文
超強(qiáng)干貨來襲 云風(fēng)專訪:近40年碼齡,通宵達(dá)旦的技術(shù)人生總結(jié)
以上是生活随笔為你收集整理的关于 ADB 实现的说明的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 使用 GDB 调试 Android 应用
- 下一篇: OSI 网络协议模型为什么是 7 层?