Arthas(阿尔萨斯) 的安装与使用

arthas官方文档:https://arthas.aliyun.com/doc/index.html点击此处进入

是Alibaba开源的Java诊断工具,深受开发者喜爱。在线排查问题,无需重启;动态跟踪Java代码;实时监控JVM状态。
Arthas 支持JDK 6+,支持Linux/Mac/Windows,采用命令行交互模式,同时提供丰富的 Tab 自动补全功能,进一步方便进行问题的定位和诊断。

1.下载安装

authas是一个jar包,可以直接下载后运行,推荐使用 arthas-boot.jar 。下载arthas-boot.jar,然后用java -jar的方式启动:
wget https://alibaba.github.io/arthas/arthas-boot.jar

Arthas(阿尔萨斯) 的安装与使用_第1张图片

2.启动authas

启动JAVA进程

启动之前确保有一个 java进程服务,然后再启动你的arthas。
在这里插入图片描述

启动arthas

java -jar arthas-boot.jar
Arthas(阿尔萨斯) 的安装与使用_第2张图片

出现上图 标识,说明启动成功。

启动报错

在这里插入图片描述

注:通过上面也分析到,我们启动arthas之前,必须要先启动我们的目标进程,否则arthas可能无法启动。

打印帮助信息

java -jar arthas-boot.jar -h
Arthas(阿尔萨斯) 的安装与使用_第3张图片

3.常用命令

启动成功之后,可以执行命令。
dashboard:观察每个线程及所占的CPU。
Arthas(阿尔萨斯) 的安装与使用_第4张图片

数据说明
ID: Java级别的线程ID没有ID及状态等信息(显示ID为-1)   
NAME: 线程名  GROUP: 线程组名
PRIORITY: 线程优先级, 1~10之间的数字,越大表示优先级越高 
STATE: 线程的状态,分为RUNNABLE 运行中TIMED_WAITIN 调用了以下方法的线程会进入TIMED_WAITING:Thread#sleep()Object#wait() 并加了超时参数Thread#join() 并加了超时参数LockSupport#parkNanos()LockSupport#parkUntil()
WAITING 当线程调用以下方法时会进入WAITING状态:Object#wait() 而且不加超时参数Thread#join() 而且不加超时参数LockSupport#park()
BLOCKED 阻塞,等待锁
CPU%: 线程消耗的cpu占比,采样100ms,将所有线程在这100ms内的cpu使用量求和,	再算出每个线程的cpu使用占比。    
TIME: 线程运行总时间,数据格式为分:秒
INTERRUPTED: 线程当前的中断位状态    
DAEMON: 是否是daemon线程Memory JVM内存信息  used 已使用内存  total总计  max 最大  usage使用比
GC 垃圾回收   Runtime 运行环境

JVM内部线程包括下面几种:
JIT编译线程: 如 C1 CompilerThread0, C2 CompilerThread0
GC线程: 如GC Thread0, G1 Young RemSet Sampling其它内部线程: 如VM Periodic Task Thread, VM Thread, Service Thread

thread: 查看那些进程占用CPU。
Arthas(阿尔萨斯) 的安装与使用_第5张图片

thread命令用于查看当前线程信息,查看线程堆栈,它有如下参数:
-id  查看指定id线程没有ID及状态等信息(显示ID为-1) 
-n [num] 查看当前最忙的几个线程
-b   找出当前阻程的线程,如果有死锁,会有红色的字提醒着,这个阻塞的	线程已经被另外一个线程阻塞。
-all  显示所有匹配的线程
-i [num]    查看[num]ms线程CPU时间
-state  查看指定状态的线程    如查看WAITING状态   thread -state WAITING

jmap -histo 进程号:查看那些进程占内存
jmap -histo 进程号 | head -20 :查看那些进程占内存,获取前20行。
Arthas(阿尔萨斯) 的安装与使用_第6张图片

GC相关命令:
jps :查看运行进程及进程号。

在这里插入图片描述

jinfo 进程号 :查看进程详情。
Arthas(阿尔萨斯) 的安装与使用_第7张图片

jstat -gc 进程号 : 查看GC 信息
在这里插入图片描述

4.卸载

在 Linux/Unix/Mac 平台
删除下面文件:

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

Windows平台直接删除user home下面的.arthas和logs/arthas目录

你可能感兴趣的:(性能,linux,多线程)