arthas tunnel servel 连接远程 arthas

tunnel servel 最大的优点在于支持分布式部署,它承担注册中心的功能,可以同时支持多个远程服务器的 arthas 注册到 tunnel-server,用户浏览器登录上 tunnel server 后,可以选择对 某一个arthas 进行监听

tunnel server 访问的原理如下

说明: 1.远程服务器的 arthas 会向 tunnel-server 注册服务,注册成功后每个 arthas 会得到一个 agentid 2.浏览器访问 tunnel-server 服务,选择 aegnt-id 后通过 tunnel-server 代理到对应的 arthas 服务
下面介绍 tunnel-server 服务的搭建。首先,需要下载 arthas-tunnel-server.jar,可以直接去 github 下载

github下载地址 https://github.com/alibaba/arthas/releases

将 arthas-tunnel-server.jar 上传到服务器,该服务器需要和 arthas 所在的服务器集群网络互通。

arthas-tunnel-server.jar 是一个 spring-boot 项目,可以通过 java -jar 启动,启动成功后如下图

java -jar arthas-tunnel-server-3.4.1.jar
arthas-tunnel-server 默认使用 8080 和 7777 两个端口,如果启动报错端口被占用,可以对这两个端口进行修改

8080 是服务的 web 端口,浏览器通过该端口连接 tunnel-server 服务,启动时通过-Dserver.port 参数修改

// 将默认的8080端口修改为8081

 java -jar -Dserver.port=8081 arthas-tunnel-server-3.4.1.jar

7777 是注册端口,远程服务器的 arthas 通过该端口注册到 tunnel-server。使用压缩工具打开arthas-tunnel-server.jar包,在application.properties配置文件中可以修改该端口

tunnel-server 启动成功后,打开本地浏览器输入 tunnel-server 的 ip 和端口进行连接,连接成功后如下图

此时,需要输入 AgentId 才能对远程 arthas 进行监控。每个 arthas 注册到 tunnel-server 成功后,会生成一个 AgentId,所以要拿到 AgentId 需要先启动 arthas 服务

在远程服务器上启动 arthas,并注册到 tunnel-server,使用 --tunnel-server 参数指定注册的地址

java -jar arthas-boot.jar --tunnel-server 'ws://119.196.154.132:7777/ws' 

arthas 启动成功后日志中最后一行的 id 就是我们需要的 AgentId

回到浏览器输入 AgentId,就可以连接远程 arthas 服务愉快的进行调试了

AgentId 是随机生成的,每次启动时都不相同,所以在浏览器中输入的时候需要到服务器上查看日志,比较麻烦。使用 --agent-id 参数可以指定 AgentId,建议把 arthas 所在服务器的 ip 作为 AgentId 来使用,方便记忆

java -jar arthas-boot.jar --tunnel-server 'ws://119.196.154.132:7777/ws' --agent-id 119.196.154.133

你可能感兴趣的:(arthas,JVM)