Jmap-JVM(十六)

news/2025/1/23 9:54:34/

上篇文章说了ZGC是jdk11加入的,他是未来jvm垃圾收集器的奠定者,满足TB级别内存处理,STW时间保持在10ms以下。

  • Jmap

我们可以先通过jmap -histo 进程ip 来查看,但是这样看不太清晰,我们可以用这行命令生成一个文件:jmap -histo > ./print.txt。

我们还可以通过jmap -heap 进程ip 来看堆信息。

 

以上则是命令执行后获取到的信息。

分别代表最大堆空间是3G多,年轻代74M,年轻代最大1个G,老年代171M,元空间则是20多M。

下面则是堆正在用的信息,eden的空间容量是capacity,已经使用和空闲的都显示在内,还有from svrvivor和to survivor容量和使用情况,最后old generation代表老年代使用情况。

命令:jmap -dump:format=b,file=print.hprof 进程ip

则可以导出dump文件,这里是可以通过设置jvm参数来导出的:

-XX:+HeapDumpOnOutOfMemoryError

-XX:+HeapDumpPath=./   (存放dump文件路径)

  • Jstack

命令:jstack 进程ip

 

从打印的信息可以看到,jstack很容易帮我们发现死锁,甚至连死锁在哪一行都标记出来(在165行)

Thread-20和thread-19线程互相死锁。

还可以看到他们锁的线程ip,是16进制,一个锁着0x000000078591c980

一个锁着0x000000078591c990

  • Jinfo

命令:Info -flags pid

Jinfo -sysprops pid

 

  • Jstat

命令:jstat -gc pid

 

S0C:survivor0区域,C代表当前总大小。  (单位KB)

S1C:survivor1区域,C代表当前总大小。

S0U:survivor0区域,U代表Use正在使用的区域大小。

S1U:survivor1区域,U代表Use正在使用的区域大小。

EC:eden区域,C代表当前总大小。

EU:eden区域,U代表Use正在使用的eden区域大小。

OC:old区域,C代表当前总大小。

OU:old区域,U代表Use正在使用的old区域大小。

MC:元空间区域,C代表当前总大小。

MU:元空间区域,U代表元空间正在使用的区域大小。

CCSC和CCSU代表压缩指针。

YGC:8,代表从系统启动开始youngGC发生8次GC。

TGCT:0.858,代表youngGC消耗时间0.858s。

FGC:2,代表从系统启动开始FULLGC发生2次。

FGCT:0.055,代表fullGC消耗0.055s。

GCT:FGC和YGC总的T之和。

Jstat -gc pid 1000 10 代表我要执行10次这个命令,1s执行一次。

Jstat -gccapacity pid可以查看堆情况。

Jstat -gcnew pid可以查看新生代垃圾回收。

Jstat -gcnewcapacity pid查看新生代内存。

Jstat -gcold pid老年代垃圾回收。

Jstat -gcoldcapacity pid老年代内存情况。

文章来源:https://blog.csdn.net/ke1ying/article/details/131949395
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.ppmy.cn/news/981097.html

相关文章

腾讯云大数据型CVM服务器实例D3和D2处理器CPU型号说明

腾讯云服务器CVM大数据型D3和D2处理器型号,大数据型D3云服务器CPU采用2.5GHz Intel Xeon Cascade Lake 处理器,大数据型D2云服务器CPU采用2.4GHz Intel Xeon Skylake 6148 处理器。腾讯云服务器网分享云服务器CVM大数据型CPU型号、处理器主频性能&#x…

SkyWalking链路追踪-搭建-spring-boot-cloud-单机环境 之《10 分钟快速搭建 SkyWalking 服务》

首先了解一下单机环境 第一步,搭建一个 Elasticsearch 服务。第二步,下载 SkyWalking 软件包。第三步,搭建一个 SkyWalking OAP 服务。第四步,启动一个 Spring Boot 应用,并配置 SkyWalking Agent。第五步,…

Go 语言入门指南

Go 语言入门指南 学一门语言先看看helloworld吧,感觉go结合了好多语言的方式,写起来一会像python一会像c,java差不多。反正语法挺奇特 package mainimport "fmt"func main() {fmt.Println("HelloWorld") }go语言特点&a…

HPC集群调度系统和计算系统

什么是计算云? 所谓的计算云指的是为计算业务优化的类云基础架构,它强调用云的方式解决计算问题,而不是将“计算”搬到现有的公有云或者容器云上。 目前公有云或者容器云(例如k8s)上的HPC解决方案本质上都是将现有的H…

飞机乘坐流程/怎么坐飞机

飞机乘坐流程/怎么坐飞机 编写原因对象人员经历背景飞机乘坐流程流程梗概订票去往机场办理登记牌/托运行李安检登机转机 飞行中下机 后记 编写原因 从上家单位裸辞,大概率下次不会找频繁出差的工作了,而日常出行应该也不会考虑飞机这种交通工具&#xf…

anydesk远程控制,主动连接。

目标 远程控制目标电脑,且无需对方同意,并且可以控制目标电脑开关机。 实现 目标电脑和己方电脑均安装anydesk。目标电脑取消开机密码。打开目标电脑的anydesk在设置安全设置中打开为自主访问设置密码。 额外设置 为了让笔记本电脑合盖后仍能被控制…

嵌入式_GD32看门狗配置

嵌入式_GD32独立看门狗配置与注意事项 文章目录 嵌入式_GD32独立看门狗配置与注意事项前言一、什么是独立看门狗定时器(FWDGT)二、独立看门狗定时器原理三、独立看门狗定时器配置过程与注意事项总结 前言 使用GD3单片机时,为了提供了更高的安…

第三大的数

414、第三大的数 class Solution {public int thirdMax(int[] nums) {Arrays.sort(nums);int tempnums[0];int ansnums[0];int count 0;// if(nums.length<3){// return nums[nums.length-1];// }// else {for(int inums.length-1;i>0;i--){if (nums[i]>nums[i…