查看栈信息
先进入docker容器,docker exec -it 容器号 bash
-
top
查看进程列表 -
查看线程占用排行
top -Hp 1
(查看进程pid为1 下面的线程列表情况)
-
查看进程id为1的各线程情况
jstack -l 1
-
可以将栈信息生成文件
jstack -l 1 > 2.log
-
查看对应进程号的信息,比如要看线程id是28的,那么28的16进制是1C,则检索栈文件里ox1C的位置
-
查找对应线程的信息
cat 2.log | grep 0x1c
查看堆信息
- 安装java的jdk文件里的bin文件目录的工具可导入
堆快照文件
- 通过查看类的实例数 分析定位问题
排查cpu占用最高的线程从而定位代码位置
-
pid是进程id,tid是线程id
-
查看占用cpu的进程
top
- 查看指定进程里的线程占用cpu情况
ps -mp [pid] -O THREAD,tid,time |sort -k2r |head -10
- 打印 16进制转换后的线程id
printf "%x\n" [tid]
- 查看16进制转换后的线程id的 栈信息,查看对应代码位置
jstack [tid]
或者
jstack -l 1 | grep [tid]
调试时手动更改传参值|查看执行方法情况
- 在框内可以提前执行自己想要查看的方法
- 在此框更改传参值后,再此框可以再执行想要执行的方法,查看自己手动改了传参值后的方法情况