Skip to content

ADB

Android Debug Bridge

Android Debug Bridge or adb, is a command line tool that lets you communicate with a device (an emulator or a connected Android device). This tool is included in the Android SDK package and consists of both client and server-side programs that communicate with one another. This is not a guide on how to setup Android Debug Bridge rather a useful resource for the essential commands and functions that power users should know. The client-server program includes three main components:

  • Client, which runs on your local machine and sends commands to the daemon. You can envoke a client on a machine by using the adb command. The client checks if an adb server process is already running, if not it binds to local TCP port 5037 and listens for commands from the adb client. All adb clients use port 5037 to communicate with the adb server.
  • Daemon (adbd), runs as a background process on each device and issues commands sent to that device from a client application.
  • Server, runs as a background process on your local machine listening on port 5555 to 5585 on odd-numbered ports with a range of 16 emulator which handle client application communication to a adbd daemon.

Device Commands

Command Description
adb devices List connected devices
adb devices -l List devcies and model
adb start-server Starts the adbd server
adb kill-server Kills the adb server
adb remount Remounts filesystem r/w access
adb reboot Reboots the device
adb shell Gain user level shell access
adb root Restarts adbd with root permissions
adb reboot bootloader Reboots device into fastboot
adb connect device_ip Connect over TCP to device


Note: If you cannot connect to a device with adb over tcp than plug the device in over USB and issue the following commands:

adb usb
adb tcpip 5555
adb connect device_ip:5555

wait-for-device can be used after adb to ensure the command will run once the device is connected.

-s flag can be used to send commands to a specific device when multiple are connected.

disable-verity is related to device-mapper-verity (dm-verity) kernel feature, which provides transparent integrity checks of block devices. This helps prevent persistent rootkits that can hold root priviledge. If trying to mount the system folder but receiving the error dm_verity is enabled on the system and vendor partitions you can issue the adb shell su mount -o remount /system or just reboot the bootloader with verity disabled adb disable-verity

Example

$ adb wait-for-device reboot bootloader
$ adb -s foodevice root

File Management

Command Description
adb push local_file remote Copy file to device
adb pull remote_file local Pull file from device


Note: If you need a file from a system application you can use adb shell su (if su binary is present) and cp file to you sdcard to later pull from the device.

$ adb shell su
$ cp /system/somefile /sdcard/somefile
$ exit
$ adb pull /sdcard/somefile file-from-device
$ adb push file-from-device /sdcard/somefile

Logcat

Every sysadmins favorite passtime

Command Description
adb logcat --help Display logcat help dialog
adb logcat Start printing log message to stdout
adb logcat -e expr Prints logs that match regular expressions
adb logcat -g Display current log buffer sizes
adb logcat -G size Sets the buffer size (K or M)
adb logcat --pid=pid Print logs from given PID
adb logcat -c Clears the log buffers
adb logcat *:V* Enables all log messages verbose
adb logcat -f foofile Dumps specified file


Remote Shell Commands

The flags you choose to pass with adb must come before the command.

adb -flag device command

$ adb -s android123 shell . . .

Command Description
adb -d Direct command to the only running connected device
adb -e Direct command to the only running emultor
adb -s Direct command to specific serial number of device
adb shell command Most Unix commands work here
adb shell monkey -p app.package.name Starts the specific package
adb shell pm list packages Lists all installed packages
adb shell pm list packages -3 List 3rd-party packages
adb install app.package.name Install package
adb install -r app.package.name Re-install app and keep its data on device
adb uninstall app.package.name Uninstall package and user data
adb uninstall -k app.package.name Uninstall package but leave data
adb shell pm uninstall app.package.name Uninstall package but leaves data
adb shell pm clear app.package.name Deletes all data associated with package


Example: Uninstall app from all connected devices:

adb devices | tail -n +2 | cut -sf 1 | xargs -IX adb -s X uninstall app.package.name

Extras

Command Description
adb shell input text foo!, text to screen Print text to screen
adb shell screencap -p /sdcard/foo.png Screenshot device
adb shell screenrecord /sdcard/foocreep.mp4 Record screen of device

Intent Actions

am start is the way to launch apps from the command line this does require that you know the "intent" action as a parameter. Use a app like Activity Launcher to inspect you app for available parameters.

Launching HomeAssistant from the command line without the use of monkey should be easy right?

am start -n io.homeassistant.companion.android.minimal/io.homeassistant.companion.android.launch.LaunchActivity

Not the most memorable command and without a tool like Activity Launcher this would have been much harder.