前言
在執行性能測試時需要導出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
