目前应用程序基本是Java,所以需要登录docker容器内部执行jstack命令打印堆栈信息再分析。
确认目标进程
PS:输入大写P即可按照CPU占比排序进程(即 Shift + p)
# top
登录容器
# sudo docker exec -it 容器ID bash
打印堆栈信息
-
打印线程堆栈
-
必须切换至admin用户(进程是admin启动的)
-
jstack需要绝对路径(容器admin用户的PATH没有包含JAVA路径)
-
输出的日志文件需要放在 /home/admin/${应用名}/logs 目录下,方便后面拷贝
# sudo -u admin /opt/taobao/java/bin/jstack -l 37 > /home/admin/busuac/logs/busuac.jstack.log
拷贝文件
退出容器,在宿主机ECS上执行mv命令将文件拷贝至个人家目录,再sftp从家目录下载文件即可
-
源文件就是上一步生成的
-
目标路径是个人的家目录(即命令中的~)
# cp /home/admin/busuac/logs/busuac.jstack.log ~
如何分析jstack
jstack文件就是一堆线程信息,如何确定哪个线程占比高?