jmap、jstat、jinfo、jstack命令详解

4 篇文章 0 订阅

jmap

jmap -histo [pid] > ./log.txt
    此命令可以用来查看内存信息,实例个数以及占用内存大小
    num:序号 
    instances:实例数量 
    bytes:占用空间大小 
    class name:类名称,[C is a char[],[S is a short[],[I is a int[],[B is a byte[],[[I is a int[][] 
jmap -heap [pid]
jmap -dump:format=b,file=eureka.hprof [pid]
    堆内存dump
    也可以设置内存溢出自动导出dump文件(内存很大的时候,可能会导不出来) 
        1. -XX:+HeapDumpOnOutOfMemoryError 
        2. -XX:HeapDumpPath=./   (路径) 
    可以用jvisualvm命令工具导入该dump文件分析

jstack

jstack [pid] 
    查找进程死锁
    "Thread-1" 线程名  
    prio=5 优先级=5 
    tid=0x000000001fa9e000 线程id 
    nid=0x2d64 线程对应的本地线程标识nid 
    java.lang.Thread.State: BLOCKED 线程状态

jinfo

jinfo -flags [pid]
    查看jvm的参数
jinfo -sysprops [pid
    查看java系统参数

jstat

jstat [-命令选项] [vmid] [间隔时间(毫秒)] [查询次数] 
    查看堆内存各部分的使用量,以及加载类的数量
jstat -gc pid 最常用,可以评估程序内存使用及GC压力整体情况
    S0C:第一个幸存区的大小,单位KB 
    S1C:第二个幸存区的大小 
    S0U:第一个幸存区的使用大小
    S1U:第二个幸存区的使用大小 
    EC:伊甸园区的大小 
    EU:伊甸园区的使用大小 
    OC:老年代大小 
    OU:老年代使用大小 
    MC:方法区大小(元空间) 
    MU:方法区使用大小 
    CCSC:压缩类空间大小 
    CCSU:压缩类空间使用大小 
    YGC:年轻代垃圾回收次数 
    YGCT:年轻代垃圾回收消耗时间,单位s 
    FGC:老年代垃圾回收次数  
    FGCT:老年代垃圾回收消耗时间,单位s 
    GCT:垃圾回收消耗总时间,单位s 
jstat -gccapacity [pid] 堆内存统计
    NGCMN:新生代最小容量 
    NGCMX:新生代最大容量 
    NGC:当前新生代容量 
    S0C:第一个幸存区大小 
    S1C:第二个幸存区的大小 
    EC:伊甸园区的大小 
    OGCMN:老年代最小容量 
    OGCMX:老年代最大容量 
    OGC:当前老年代大小 
    OC:当前老年代大小 
    MCMN:最小元数据容量 
    MCMX:最大元数据容量 
    MC:当前元数据空间大小 
    CCSMN:最小压缩类空间大小 
    CCSMX:最大压缩类空间大小 
    CCSC:当前压缩类空间大小 
    YGC:年轻代gc次数 
    FGC:老年代GC次数 
jstat -gcnew [pid]  新生代垃圾回收统计
    S0C:第一个幸存区的大小 
    S1C:第二个幸存区的大小 
    S0U:第一个幸存区的使用大小 
    S1U:第二个幸存区的使用大小 
    TT:对象在新生代存活的次数 
    MTT:对象在新生代存活的最大次数 
    DSS:期望的幸存区大小 
    EC:伊甸园区的大小 
    EU:伊甸园区的使用大小 
    YGC:年轻代垃圾回收次数 
    YGCT:年轻代垃圾回收消耗时间
  • 1
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值