linux查看java堆栈

1、查看JAVA进程JVM参数

jinfo -flags pid(进程号)
-XX:CICompilerCount=2 最大的并行编译数
-XX:InitialHeapSize=16777216 JVM 的初始堆内存大小
-XX:MaxHeapSize=257949696 JVM 的最大堆内存大小
-XX:MaxNewSize=85983232
-XX:MinHeapDeltaBytes=196608
-XX:NewSize=5570560
-XX:OldSize=11206656
 

2、JVM 查看当前Java进程的启动参数

jmap -heap [进程号]

NewRatio:  指定老年代/新生代的堆内存比例,默认2:1。在hotspot虚拟机中,堆内存 = 新生代 + 老年代。在设置了-XX:MaxNewSize的情况下,-XX:NewRatio的值会被忽略,老年代的内存=堆内存 - 新生代内存。老年代的最大内存 = 堆内存 - 新生代 最大内存。

SurvivorRatio: 新生代中1个Eden区与1个Survivor区的大小比值。在hotspot虚拟机中,新生代 = 1个Eden + 2个Survivor。如果新生代内存是10M,SurvivorRatio=8,那么Eden区占8M,2个Survivor区各占1M。

Eden区是一块,Survivor区是两块。

Eden区和Survivor区的比例是8:1:1

JVM内存的结构为
堆:存放对象
栈:运行时存放栈帧
程序计数器
方法区:存放类和常量

Jdk 1.8之后好像取消了方法区,直接将永久代放到了本地内存里面

3、Jstat可以用来监视VM内存内的各种堆和非堆的大小及其内存使用量。

jstat -gcutil pid

通过 jstat -gcutil pid 命令,我们可以对gc信息进行统计。

jstat -gc pid

这个命令看起来显示的信息比上一个命令还多。jstat -gc pid 可以显示gc的信息,查看gc的次数,及时间。其中最后五项,分别是young gc的次数,young gc的时间,full gc的次数,full gc的时间,gc的总时间。

jstat -gccapacity pid

jstat -gccapacity pid 命令可以显示:VM内存中三代(young,old,perm)对象的使用和占用大小。如:PGCMN显示的是最小perm的内存使用量,PGCMX显示的是perm的内存最大使用量,PGC是当前新生成的perm内存占用量,PC是但前perm内存占用量。其他的可以根据这个类推, OC是old内纯的占用量。

jstat -gcnew pid

jstat -gcnew pid 命令可以显示年轻代对象的信息。

jstat -gcnewcapacity pid

jstat -gcnewcapacity pid 命令可以显示年轻代对象的信息及其占用量。

jstat -gcold pid

jstat -gcold pid 命令可以显示old代对象的信息。

jstat -gcoldcapacity pid

jstat -gcoldcapacity pid 命令可以显示old代对象的信息及其占用量。

jstat -class pid

jstat -class pid 命令可以显示加载class的数量,及所占空间等信息。

jstat -compiler pid

jstat -compiler pid 命令可以显示VM实时编译的数量等信息。

jstat -printcompilation pid

jstat -printcompilation pid 命令可以显示当前VM执行的信息。

参数解释

  • S0C:年轻代中第一个survivor(幸存区)的容量 (kb)
  • S1C:年轻代中第二个survivor(幸存区)的容量 (kb)
  • S0U:年轻代中第一个survivor(幸存区)目前已使用空间 (kb)
  • S1U:年轻代中第二个survivor(幸存区)目前已使用空间 (kb)
  • EC:年轻代中Eden(伊甸园)的容量 (kb)
  • EU:年轻代中Eden(伊甸园)目前已使用空间 (kb)
  • OC:Old代的容量 (kb)
  • OU:Old代目前已使用空间 (kb)
  • PC:Perm(持久代)的容量 (kb)
  • PU:Perm(持久代)目前已使用空间 (kb)
  • YGC:从应用程序启动到采样时年轻代中gc次数
  • YGCT:从应用程序启动到采样时年轻代中gc所用时间(s)
  • FGC:从应用程序启动到采样时old代(全gc)gc次数
  • FGCT:从应用程序启动到采样时old代(全gc)gc所用时间(s)
  • GCT:从应用程序启动到采样时gc用的总时间(s)
  • NGCMN:年轻代(young)中初始化(最小)的大小 (kb)
  • NGCMX:年轻代(young)的最大容量 (kb)
  • NGC:年轻代(young)中当前的容量 (kb)
  • OGCMN:old代中初始化(最小)的大小 (kb)
  • OGCMX:old代的最大容量 (kb)
  • OGC:old代当前新生成的容量 (kb)
  • PGCMN:perm代中初始化(最小)的大小 (kb)
  • PGCMX:perm代的最大容量 (kb)
  • PGC:perm代当前新生成的容量 (kb)
  • S0:年轻代中第一个survivor(幸存区)已使用的占当前容量百分比
  • S1:年轻代中第二个survivor(幸存区)已使用的占当前容量百分比
  • E:年轻代中Eden(伊甸园)已使用的占当前容量百分比
  • O:old代已使用的占当前容量百分比
  • P:perm代已使用的占当前容量百分比
  • S0CMX:年轻代中第一个survivor(幸存区)的最大容量 (kb)
  • S1CMX :年轻代中第二个survivor(幸存区)的最大容量 (kb)
  • ECMX:年轻代中Eden(伊甸园)的最大容量 (kb)
  • DSS:当前需要survivor(幸存区)的容量 (kb)(Eden区已满)
  • TT: 持有次数限制
  • MTT : 最大持有次数限制

 

4、命令jmap是一个多功能的命令。它可以生成 java 程序的 dump 文件, 也可以查看堆内对象示例的统计信息、查看 ClassLoader 的信息以及 finalizer 队列。

jmap pid查看进程的内存映像信息,类似 Solaris pmap 命令。

jmap -heap pid显示Java堆详细信息
jmap -histo:live pid显示堆中对象的统计信息
jmap -clstats pid 打印类加载器信息

jmap -finalizerinfo pid打印等待终结的对象信息

jmap -dump:format=b,file=heapdump.phrof pid生成堆转储快照dump文件

5、jinfo 是 JDK 自带的命令,可以用来查看正在运行的 java 应用程序的扩展参数,包括Java System属性和JVM命令行参数;也可以动态的修改正在运行的 JVM 一些参数。当系统崩溃时,jinfo可以从core文件里面知道崩溃的Java应用程序的配置信息

jinfo pid输出当前 jvm 进程的全部参数和系统属性

jinfo -flag name pid输出对应名称的参数

jinfo -flag [+|-]name pid开启或者关闭对应名称的参数

jinfo -flag name=value pid修改指定参数的值。

jinfo -flags pid输出全部的参数

jinfo -sysprops pid输出当前 jvm 进行的全部的系统属性

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值