JDK版本为:1.8.0_291 arthas版本:3.5.2
arthas介绍
arthas是什么
arthas
是阿里巴巴开源的Java诊断工具,基本使用场景是定位复现一些生产环境比较难以定位问题。可以在线排查问题,以及动态追踪Java代码,实时监控JVM状态等等。
arthas能干什么
- 某个类从那个jar包加载的?为什么会报各种类的异常? (可以通过命令拿到指定类的加载路径和异常信息)
- 改的代码没有执行到?是没有commit还是分支搞错还是怎么样?(可以通过反编译拿到类的代码信息)
- 遇到问题无法在线上debug,难道只能通过加日志再重新发布吗?(可以通过jdk 1.5的
instrument
来进行代码的动态替换)
- 线上遇到某个用户的数据处理有问题,但线上同样无法debug,线下无法重现!(当前按照我的理解是只能向后兼容,arthas中可以看到很详细的jvm状态以及一些比较方便的工具,比如反编译,在线调试等)
- 是否有一个全局视角来查看系统的运行状况?(dashboard命令查看jvm的详细信息)
- 怎么快速定位应用的热点,生成火焰图?
- 怎样直接从JVM内查找某个类的实例?
arthas支持的版本
支持JDK 6+ 支持Linux/Mac/Windows
arthas的简单使用
- 下载arthas的启动程序,用来选择你所需要监控的服务arthas-packaging-3.5.2-bin.zip
- 下载解压之后,在文件夹里面有
arthas-boot.jar
,直接使用 java -jar的方式进行启动 java -jar arthas-boot.jar
- 注意需要配置好jdk的环境变量,不然无法启动的
- 启动之后选择一个你需要查看的jvm进程,然后就可以愉快的使用了
- 查看当前的线程信息,内存信息以及运行时系统版本以及JAVA版本信息
- thread
- 当前线程总的数量以及各个线程的状态体现
- 单个线程的名称,分组,优先级,状态,CPU的负载率 以及是否是守护线程
当然了,thread后面也可以通过管道符的方式筛选具体的线程信息,比如thread 2 | grep 'Attach'
- 反编译可以拿到当前类在具体系统中的classload信息,当然也可高亮显示,因为arthas在attach时,对于系统有影响,在反编译的下方会有编译时间
- watch(可以观看指定函数的返回值)
- watch hatricks.HelloWorld print returnObj(returnObj是arthas中的一种语法)
- 可以展示当前方法的花费时间以及方法的返回值
大家想了解arthas还是去arthas官方的在线教程去玩儿一下,可以快速入门哦
参考链接:
arthas官网 :https://arthas.aliyun.com/doc/