docker容器中進行Threaddump查看jvm狀態


前言

在執行性能測試時需要導出Threaddump,程序運行在Docker容器中,在容器外不能直接使用jcmd 命令和jstack命令進行dump操作,會提示沒有該命令,執行yum安裝也不行。

 

解決辦法:

查看正在運行的容器id
執行命令:docker ps

查到的docker容器id如下

 

 

使用docker exec進入Docker容器,命令如下:
docker exec -it 29198c060396 /bin/sh


運行jps,已經能看到剛才啟動的spring boot應用了

這時就可以使用jstat,jmap等根據進程id查看程序狀態了,以下是我運行jstack查看的堆棧信息

 

 


導出jmap dump的文件,進一步分析,copy docker中的文件到宿主機,命令如下
docker cp 29198c060396:/logs/d.20170726.txt .

d.20170726.txt 是我剛才用jmap -dump生成的文件

29198c060396是docker 容器id

 

在Docker中執行jstack時提示No such process,如下圖:

 

 

原因分析:

docker中不能直接使用宿主機上的進程ID

解決方法:

docker container內進程信息,與宿主機上進程信息的映射關系,可以使用docker top查看宿主機與Docker中進程的對應關系,具體操作如下:

1. 找到容器的id

docker ps

2. 找到容器在宿主機上映射后的進程信息

docker top 9b40a74ceb82(容器id)

就會得到類似下面的信息,其中PID是容器內進程在宿主機上的pid,ppid是容器內進程在宿主機上的父進程pid

UID                 PID                 PPID                C                   STIME               TTY                 TIME                CMD
root                9849                1611                0                   Mar07               ?                   00:00:00            bash /usr/bin/start

 

找到對應的容器內PID后就可以使用JStack進行Thread dump操作

 


參考資料:

https://blog.csdn.net/longxing_123/article/details/76163980

https://blog.csdn.net/micklf/article/details/79563869


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM