Android(安卓)使用模拟器远程调试
方法1
By hheimbuerger
Here is how I solved it on Windows. I pretty much followed Christopher's lead, but I can't edit, so a new answer will have to do.
The problem I had was that ADB as well as the emulator was just listening on 127.0.0.1, not 0.0.0.0, for me. Otherwise I would have usedTCPMon. I guess this is either different on Windows, or has changed with the latest versions of the SDK. (You can check withnetstat -ban
.)
-
I installed WinSSHD on the machine that runs the emulator. (I believe it should work with freeSSHd as well, but I couldn't get a login working there.)
-
I opened port 22 (TCP) in the Windows Firewall. (WinSSHD might be able to do that for you.)
-
I created a virtual account in the WinSSHD GUI.
-
I created a new PuTTY connection from the development machine to the emulator machine and made sure I could connect.
-
Then I set up tunnelling in PuTTY: Connection -> SSH -> Tunnels
Source port: 5554
Destination: localhost:5554
Type: Local/Auto
Source port: 5555
Destination: localhost:5555
Type: Local/Auto
(Connect and keep PuTTY open, to maintain the tunnel.)
-
Now I fired up the emulator on the remote machine and made sure that ADB is not running there.
-
I restarted ADB on the development machine (
adb kill-server
, thenadb start-server
). -
adb devices
and the remote emulator showed up asemulator-5554 device
. I could now deploy and run my app straight from Eclipse/ADT, where the emulator showed up under Virtual Devices as if it was a local emulator.
By Patrick McKinnon
| I realize this question is really old, but I solved the problem slightly differently, and it took me a while to figure out this trivial solution. I usually use a Windows7 PC or laptop (depending on where I'm working) as my front-end because I like the GUI, however I prefer to do all of my edit/compile/debug on a headless Ubuntu server because of all the command-line power it provides. My goal is to make each windows system as much of a thin-client as possible without any extra services (such as sshd) or firewall holes. So here is the senario:
The problem as described earlier is that the emulator on System-A binds to localhost, not the external ethernet interface, so adb on the System-B cannot access the emulator on System-A. All you need to do is set up remote port forwarding in PuTTY for your SSH connection to System-B. The trick is to check the "Remote" radio button when you create the two tunnels so that the tunnel direction is reversed (tunneling from the server you are logging into to the client you are logging in from).
Finally, connect with adb to "localhost" on System-B after establishing the SSH connection: Now you can download images/debug as normal, and it is a trivial matter to switch to a different Windows system if you want to take your laptop out and get some coffee. In addition, by also tunneling port 5037 in the same manner you can actually forward your adb server connection so that you can connect a real android device over USB on System-A, and download images to it from System-B. In order for this to work, you need to make sure that the adb server is running on System-A, and not running on System-B before starting your SSH session: First, start the adb server on System-A (command prompt) Next, kill the adb server on System-B Finally, restart your ssh session to System-B and verify |
更多相关文章
- view变化监听器ViewTreeObserver介绍
- Activities
- Android(安卓)dex分包技术
- Android(安卓)JNI 之 .h 头文件
- ItemDecoration解析(一) getItemOffsets
- Android获取CPU,内存等系统信息方法
- Android(安卓)一张图理解getWidth和getMeasuredWidth
- Android(安卓)instrumentation原理
- Starting an Activity(开始活动)