早就听闻阿里开源的 Arthas 在做 Java 应用诊断上十分牛逼,没失望

沙海 2021年3月10日01:07:13杂谈 Java评论47字数 1921阅读6分24秒阅读模式
摘要

早就听闻阿里开源的 Arthas 在做 Java 应用诊断上十分牛逼,没失望 点击关注 ? 不装逼的程序员

早就听闻阿里开源的 Arthas 在做 Java 应用诊断上十分牛逼,没失望

点击关注 ? 不装逼的程序员 文章源自JAVA秀-https://www.javaxiu.com/2981.html

早就听闻阿里开源的 Arthas 在做 Java 应用诊断上十分牛逼,身边也有很多同事在使用,因此决定开一个坑,自己从零学习下这个工具的使用,本系列使用的版本是当前最新版 3.4.5。文章源自JAVA秀-https://www.javaxiu.com/2981.html

由于 Arthas 经过这么长时间的发展,本身文档、在线教程已经十分健全了,同时还有第三方的 IDEA 插件、许多教学视频去帮助我们入门使用,因此这个系列的文章定位是个人笔记,而并非教程,希望不要误人子弟。文章源自JAVA秀-https://www.javaxiu.com/2981.html

概述

https://arthas.aliyun.com文章源自JAVA秀-https://www.javaxiu.com/2981.html

当你遇到以下类似问题而束手无策时,Arthas可以帮助你解决:文章源自JAVA秀-https://www.javaxiu.com/2981.html

  • 这个类从哪个 jar 包加载的?为什么会报各种类相关的 Exception?文章源自JAVA秀-https://www.javaxiu.com/2981.html

  • 我改的代码为什么没有执行到?难道是我没 commit?分支搞错了?文章源自JAVA秀-https://www.javaxiu.com/2981.html

  • 遇到问题无法在线上 debug,难道只能通过加日志再重新发布吗?文章源自JAVA秀-https://www.javaxiu.com/2981.html

  • 线上遇到某个用户的数据处理有问题,但线上同样无法 debug,线下无法重现!文章源自JAVA秀-https://www.javaxiu.com/2981.html

  • 是否有一个全局视角来查看系统的运行状况?文章源自JAVA秀-https://www.javaxiu.com/2981.html

  • 有什么办法可以监控到JVM的实时运行状态?文章源自JAVA秀-https://www.javaxiu.com/2981.html

  • 怎么快速定位应用的热点,生成火焰图?文章源自JAVA秀-https://www.javaxiu.com/2981.html

使用 Arthas 需要 JDK 版本在 1.6 以上。文章源自JAVA秀-https://www.javaxiu.com/2981.html

早就听闻阿里开源的 Arthas 在做 Java 应用诊断上十分牛逼,没失望文章源自JAVA秀-https://www.javaxiu.com/2981.html

快速安装

https://arthas.aliyun.com/doc/install-detail.html文章源自JAVA秀-https://www.javaxiu.com/2981.html

Arthas 本身也是个 Java 进程,得益于 Java 跨平台特性,所以我就直接在 Windows 上安装了。文章源自JAVA秀-https://www.javaxiu.com/2981.html

(1)下载 Arthas 包文章源自JAVA秀-https://www.javaxiu.com/2981.html

curl -O https://arthas.aliyun.com/arthas-boot.jar

(2)运行 Arthas文章源自JAVA秀-https://www.javaxiu.com/2981.html

java -jar arthas-boot.jar

需要注意的是运行 Arthas 前至少保证系统正在运行一个 Java 进程,否则无法启动,并会报错:Can not find java process. Try to pass in command line.Please select an available pid。解决办法就是跑一个 Java 应用即可。文章源自JAVA秀-https://www.javaxiu.com/2981.html

如果需要卸载 Arthas 的话:文章源自JAVA秀-https://www.javaxiu.com/2981.html

在 Linux/Unix/Mac 平台,删除下面文件:文章源自JAVA秀-https://www.javaxiu.com/2981.html

rm -rf ~/.arthas/rm -rf ~/logs/arthas

Windows平台直接删除user home下面的.arthas和logs/arthas目录文章源自JAVA秀-https://www.javaxiu.com/2981.html

快速入门

4.1 attach 进程

这里我们使用 Arthas 官方提供的 demo 包,这样我们就不需要自己编写代码了。将 demo 包下载下来并运行。文章源自JAVA秀-https://www.javaxiu.com/2981.html

curl -O https://arthas.aliyun.com/arthas-demo.jarjava -jar arthas-demo.jar

这个 demo 功能是死循环做质因数分解,并记录下无法分解的次数,如下图所示。文章源自JAVA秀-https://www.javaxiu.com/2981.html

早就听闻阿里开源的 Arthas 在做 Java 应用诊断上十分牛逼,没失望文章源自JAVA秀-https://www.javaxiu.com/2981.html

我们首先启动 Arthas 并 attach 上该进程。文章源自JAVA秀-https://www.javaxiu.com/2981.html

早就听闻阿里开源的 Arthas 在做 Java 应用诊断上十分牛逼,没失望文章源自JAVA秀-https://www.javaxiu.com/2981.html

默认情况下,Arthas只listen 127.0.0.1,所以如果想从远程连接,则可以使用 --target-ip参数指定 listen 的IP文章源自JAVA秀-https://www.javaxiu.com/2981.html

另外如果条件允许的话,在 attach 后也可以使用浏览器登录,访问:http://127.0.0.1:3658 即可。也可以填入 IP,远程连接其他机器的 Arthas。早就听闻阿里开源的 Arthas 在做 Java 应用诊断上十分牛逼,没失望文章源自JAVA秀-https://www.javaxiu.com/2981.html

4.2 常用命令

4.2.1 dashboard

https://arthas.aliyun.com/doc/dashboard.html文章源自JAVA秀-https://www.javaxiu.com/2981.html

使用 dastboard 命令可以查看 Java 进程信息(定时刷新),如需退出使用 q 即可。它由如下四个部分组成:文章源自JAVA秀-https://www.javaxiu.com/2981.html

  • 第一部分是显示JVM中运行的所有线程:所在线程组,优先级,线程的状态,CPU的占用率,是否是后台进程等文章源自JAVA秀-https://www.javaxiu.com/2981.html

  • 第二部分显示的JVM内存的使用情况文章源自JAVA秀-https://www.javaxiu.com/2981.html

  • 第三部分显示的是 GC 相关的信息文章源自JAVA秀-https://www.javaxiu.com/2981.html

  • 第四部分是操作系统的一些信息和Java版本号文章源自JAVA秀-https://www.javaxiu.com/2981.html

早就听闻阿里开源的 Arthas 在做 Java 应用诊断上十分牛逼,没失望文章源自JAVA秀-https://www.javaxiu.com/2981.html

4.2.2 thread

https://arthas.aliyun.com/doc/thread.html文章源自JAVA秀-https://www.javaxiu.com/2981.html

使用 thread 命令可以查看当前所有的线程信息。早就听闻阿里开源的 Arthas 在做 Java 应用诊断上十分牛逼,没失望文章源自JAVA秀-https://www.javaxiu.com/2981.html

并且可以通过追加 PID 的方式,查看具体某个线程的状态。早就听闻阿里开源的 Arthas 在做 Java 应用诊断上十分牛逼,没失望文章源自JAVA秀-https://www.javaxiu.com/2981.html

4.2.3 jad

https://arthas.aliyun.com/doc/jad.html文章源自JAVA秀-https://www.javaxiu.com/2981.html

使用 jad 命令可以反编译 class 文件。文章源自JAVA秀-https://www.javaxiu.com/2981.html

早就听闻阿里开源的 Arthas 在做 Java 应用诊断上十分牛逼,没失望文章源自JAVA秀-https://www.javaxiu.com/2981.html

4.2.2 watch

https://arthas.aliyun.com/doc/watch.html文章源自JAVA秀-https://www.javaxiu.com/2981.html

watch 命令可以监控方法的入参出参:文章源自JAVA秀-https://www.javaxiu.com/2981.html

早就听闻阿里开源的 Arthas 在做 Java 应用诊断上十分牛逼,没失望文章源自JAVA秀-https://www.javaxiu.com/2981.html

退出 Arthas

如果只是退出当前的连接,可以用quit或者exit命令。Attach到目标进程上的 Arthas 还会继续运行,端口会保持开放,下次连接时可以直接连接上。文章源自JAVA秀-https://www.javaxiu.com/2981.html

如果想完全退出arthas,可以执行stop命令。文章源自JAVA秀-https://www.javaxiu.com/2981.html

来源 | https://jitwxs.cn/a64edcb1.html文章源自JAVA秀-https://www.javaxiu.com/2981.html

继续阅读
速蛙云 - 极致体验,强烈推荐!!!购买套餐就免费送各大视频网站会员!快速稳定、独家福利社、流媒体稳定解锁!速度快,全球上网、视频、游戏加速、独立IP均支持!基础套餐性价比很高!这里不多说,我一直正在使用,推荐购买:https://www.javaxiu.com/59919.html
weinxin
资源分享QQ群
本站是JAVA秀团队的技术分享社区, 会经常分享资源和教程; 分享的时代, 请别再沉默!
沙海
匿名

发表评论

匿名网友 填写信息

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定