ADB is a communication protocol specific to Android. ADB allows to connect or control an Android device from a computer.
It can be used with a Genymotion Device image instance to:
- Control an instance Android OS.
- Connect an instance to a developer's tool (IDE), such as Android Studio, VS Code, JetBrains Rider, etc.
- Access an instance shell.
- Upload files to an instance.
Prerequisite
- Your EC2 firewall has an inbound rule to allow TCP port 5555 or SSH connection from authorized hosts. See Requirements.
- Android SDK platform-tools from https://developer.android.com or Android Studio.
Android Studio
The Android SDK platform-tools are included with Android Studio. By default, they are located in the following folders:
Linux
$HOME
/Android/Sdk
macOS
$HOME
/Library/Android/sdk
Windows
(Windows folder path not provided in the extracted content.)
Step 1 - Toggle ADB connection
> Warning: ADB connections are neither secured nor authenticated: you should ONLY allow TCP port 5555 from authorized hosts in your Firewall inbound rules!
Instead of opening TCP port 5555, you can use an SSH tunnel to secure the connection.
Web UI
1. Go to the Configuration panel. 2. In the ADB section, click on the toggle button to enable or disable ADB access.
Command Line (SSH)
(Commands for this option are not included in the extracted content.)
HTTP API
User data parameters
You can use the POST method and call the /configuration/adb API to set the following variables:
- Set
active:trueto enable ABD at run-time, and/oractive_on_reboot:trueto enable after reboot. - Set
active:falseto disable ADB at run-time, and/oractive_on_reboot:falseto disable after reboot.
For detailed usage, please refer to Device HTTP API.
It is also possible to use user data parameters, to enable ABD connection at boot. For detailed instructions, please refer to Automate instance parameters.
Step 2 - Connect ADB to the instance
After enabling ADB connection, you can connect the instance to ADB:
Use an SSH tunnel
Though it is possible to open TCP port 5555 to restricted hosts in your EC2 firewall, using an SSH tunnel is the most secured method.
1. Set SSH access
Follow the instructions from chapter Access with SSH to setup and enable SSH access to your instances.
2. Create an ssh tunnel
In a new terminal/shell create an SSH tunnel:
> Warning: Do not close this terminal/shell or this will close the tunnel as well.
> Tip: To create a tunnel for other virtual devices, just increment the port number for every new virtual device (5556, 5557, 5558, etc.).
Example:
With PuTTy
1. Set PuTTy to connect to your instance.
2. Go to Connection > SSH > Tunnels and set Source port to 5555 and Destination to localhost:5555.
3. Click on Add.
4. Click on Open to start the connection.
> Warning: The PuTTy terminal has to remain open during your operations. If PuTTY is closed, it will close the tunnel as well.
To create a tunnel for other virtual devices, make sure you increment the port number for every new virtual device (5556, 5557, 5558, etc.)
3. Connect ADB
1. Open another shell to run other commands. 2. Connect your virtual device to ADB:
adb
localhost:5555
To connect other virtual devices to ADB, make sure you increment the port number for every new virtual device (e.g. 5556, 5557, 5558, etc.). For example:
Then, to connect this instance to ADB:
adb
localhost:5556
HTTP API
(HTTP API subsection content is already included under “Step 1 - Toggle ADB connection”. No additional content is present in the extracted text.)
Back to top
(Back to top UI element excluded.)