天天看点

Arthas学习使用场景安装入门

Arthas学习

  • 使用场景
  • 安装
  • 入门

使用场景

  1. 这个类从哪个jar包加载的?为什么会报各种类相关的Exception?
  2. 我改的代码为什么没有执行到?每提交么?提交的分支不对么?
  3. 遇到问题无法在线上debug,难道只能通过添加日志然后重新发布么?
  4. 线上遇到某个用户的数据处理有问题,但线上同样无法debug,线下无法重现!
  5. 是否有一个全局视角来查看系统的运行情况?
  6. 有什么办法可以监控到JVM的实时运行状态?
  7. 怎么快速定位应用的热点,生成火焰图?

安装

推荐使用arthas-boot,下载arthas-boot.jar,然后使用java -jar的方式启动:

curl -O https://alibaba.github.io/arthas/arthas-boot.jar

java -jar arthas-boot.jar

打印帮助信息

java -jar arthas-boot.jar -h

  • 如果下载速度比较慢,可以使用aliyun的镜像:

    java -jar arthas-boot.jar --repo-mirror aliyun --use-http

  • 如果从github下载有问题,可以使用gitee镜像

    curl -O https://arthas.gitee.io/arthas-boot.jar

    其他安装方式自行查找

入门

  1. 启动Demo

    curl -O https://alibaba.github.io/arthas/arthas-demo.jar

    java -jar arthas-demo.jar

    arthas-demo是一个简单的程序,每隔一秒生成一个随机数,再执行质因数分解,并打印出分解结果。

  2. 启动arthas

    在命令行下面执行(使用和目标进程一致的用户启动,否则attach失败):

    java -jar arthas-boot.jar

  3. 执行该程序的用户需要和目标进程具有相同的权限。比如以admin用户来执行:

    sudo su admin && java -jar arthas-boot.jar 或者 sudo -u admin -EH java -jar arthas-boot.jar。

  4. 如果attach不上目标进程,可以查看~/logs/arthas/目录下的日志。

选择应用java进程

Arthas学习使用场景安装入门

Demo进程是第一个,则输入1,回车。Arthas会attach到目标进程上,并输出日志:

Arthas学习使用场景安装入门

查看dashboard

输入dashboard,会展示当前进程的信息,按ctrl+c可以中断arthas的执行。

Arthas学习使用场景安装入门

通过thread 命令来获取arthas-demo进程的Main Class

thread 1会打印线程ID 1的栈,通常是main函数的线程。

Arthas学习使用场景安装入门

通过jad来反编译main class

Arthas学习使用场景安装入门

watch

通过watch命令来查询demo.MathGame#primeFactors函数的返回值

Arthas学习使用场景安装入门

退出arthas

如果只是退出当前的连接,可以使用quit或者exit命令。Attach到目标上的arthas还会继续运行,端口会保持开发,下次连接时可以直接连上。

如果想完全退出arthas,可以执行stop命令。