java容器堆栈_使用docker查看jvm状态,在docker中使用jmap,jstat

Docker中查看JVM的信息:

1.     列出docker容器:docker ps

2.     标准输入和关联终端:docker exec -it 容器ID  bash

3.     查找出java进程: ps – ef | grep java

4.     统计gc信息统计: jstat –gcutil 466 3000 每三秒打印一次

示例1--jstack查看线程堆栈信息

查看正在运行的容器id

docker ps

这里我运行的是一个spring boot应用,docker容器id如下

3a28810ae18d4bdcd2ecb525e4fdb038.png

使用docker exec进入Docker容器,命令如下

docker exec -it be6203473016 /bin/sh

be6203473016 是CONTAINER ID

d5f738f7380d0a2c685c23b7ca86a96a.png

运行jps,已经能看到刚才启动的spring boot应用了

2eb4fc9916f8b1fab94dc51ebd597d53.png

这时就可以使用jstat,jmap等根据进程id查看程序状态了,以下是我运行jstack查看的堆栈信息

aa9879a89f980580e935c1de516ddbf2.png

示例2--jmap导出内存堆栈信息

jmap -dump:format=b,file=/logs/test.bin 9

(上面的logs目录需要你自己在docker容器里找个已存在的目录啊)

导出jmap dump的文件,进一步分析,copy docker中的文件到宿主机的当前目录,命令如下:

docker cp be6203473016:/logs/test.bin .

test.bin 是我刚才用jmap -dump生成的文件

be6203473016是docker 容器id

在用sz从宿主机下载到工作电脑,命令如下:

sz test.bin

示例3--jstat统计gc回收信息

jstat –gcutil 9 3000

每三秒打印一次

6d3cb795c7df6203afb540899a076038.png

示例4--jinfo统计gc回收信息

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值