arthas/tunnel-server
2019-08-30 15:36:50 +08:00
..
src/main remove config. #835 2019-08-30 15:36:50 +08:00
.factorypath add tunnel client/server. #835 2019-08-29 16:05:50 +08:00
pom.xml tunnel server support endpoint. #835 2019-08-30 14:10:09 +08:00
README.md add tunnel client/server. #835 2019-08-29 16:05:50 +08:00

How it works

Tunnel server/client use websocket protocol.

For example:

  1. Arthas tunnel server listen at 192.168.1.10:7777

  2. Arthas tunnel client register to the tunnel server

    tunnel client connect to tunnel server with URL: ws://192.168.1.10:7777/ws?method=agentRegister

    tunnel server response a text frame message: response:/?method=agentRegister&id=bvDOe8XbTM2pQWjF4cfw

    This connection is control connection.

  3. The browser try connect to remote arthas agent, start connect to tunnel server with URL: 'ws://192.168.1.10:7777/ws?method=connectArthas&id=bvDOe8XbTM2pQWjF4cfw

  4. Arthas server find the control connection with the id bvDOe8XbTM2pQWjF4cfw, then send a text frame to arthas client: response:/?method=startTunnel&id=bvDOe8XbTM2pQWjF4cfw&clientConnectionId=AMku9EFz2gxeL2gedGOC

  5. Arhtas tunnel client open a new connection to tunnel server, URL: ws://127.0.0.1:7777/ws/?method=openTunnel&clientConnectionId=AMku9EFz2gxeL2gedGOC&id=bvDOe8XbTM2pQWjF4cfw. This connection is tunnel connection.

  6. Arhtas tunnel client start connect to local arthas agent, URL: ws://127.0.0.1:8563/ws. This connection is local connection.

  7. Forward websocket frame between tunnel connection and local connection.

browser <-> arthas tunnel server <-> arthas tunnel client <-> arthas agent