近段时间将公司的项目迁移到了docker上运行,今天在使用jmap -heap 查看Java进程信息时,无论是在容器外还是容器里(docker exec进入到容器),都发现提示报错。最终通过google查询出解决方案,现将解决办法整理如下:
在docker 容器,无法执行jmap jstack 等命令的解决办法
错误信想:
jvm.hotspot.debugger.NoSuchSymbolException: Could not find symbol "gHotSpotVMTypes" in any of the known library names (libjvm.so, libjvm_g.so, gamma_g)
1.安装nsenter
git clone https://github.com/jpetazzo/nsenter.git
docker build -t jpetazzo/nsenter .
docker run --rm -v /usr/local/bin:/target jpetazzo/nsenter
以上方法执行后,你会发现/use/local/bin下安装了nsenter
2.查询出docker容器的PID,并通过nsenter进入到容器中
命令示例:PID=$(docker inspect --format {{.State.Pid}} <container_name_or_ID>)
如:
echo $(docker inspect --format {{.State.Pid}} tj_mm)
命令示例:nsenter --target $PID --mount --uts --ipc --net --pid
如:
nsenter --target 9174 --mount --uts --ipc --net —pid
通过此命令进入容器后就可以使用ps -x|grep java 并通过 jmap等方法来查看java进程情况了。
3.快速进入到容器,在安装nsenter时,你会发现同时安装了docker-enter
命令示例:docker-enter <container_name_or_ID>
如:
docker-enter tj_mm
参考资料:
https://forums.docker.com/t/how-to-dump-heap-from-a-java-program-running-in-container/3217/3