jstat

  • 可以检查 JVM 整体的运行情况,可以看到 新生代,老年代等的内存使用情况,以及GC 次数和耗时
  • 命令格式 如 jstat -<option> [-t] [-h<lines>] <vmid> [<interval> [<count>]]
  • 其中 -option 必选参数表示命令参数 如 gc 等, -t 为可选参数表示是否打印时间(秒),-h<lines> 可选参数,表示每隔多少行打印头部列表,如设置 -h 5 , 那么每五条记录就会重新打印表头,vmid 必选参数,Java 进程idinterval 可选参数表示采样的时间间隔,count 可选参数表示需要采样多少条,

jstat -gc pid

  • jstat -gc pid 这是最常用的语法,可以直接查看内存和垃圾回收情况
  • 首先我们要获得Java 进程的 PID 信息,可以通过 jps 命令来获取
  • 之后执行 jstat -gc pid 即可看到对应 Java 进程的内存情况,如下:

  • 这里说明一下关于这些列名的含义

    • S0C : 新生代中第一个 Survivor (即 From 区)的容量大小 (千字节)
    • S1C : 新生代中第二个 Survivor (即 To 区)的容量大小 (千字节)
    • S0U : 新生代 From Survivor 区已使用内存大小(千字节)
    • S1U : 新生代 To Survivor 区一使用内存大小(千字节)
    • EC : 新生代 Eden 区的容量大小(千字节)
    • EU : 新生代 Eden 区已使用内存大小(千字节)
    • OC : 老年代空间容量大小(千字节)
    • OU : 老年代已使用内存大小(千字节)
    • MC : 方法区的空间大小 (千字节)
    • MU : 方法区已使用的空间大小(千字节)
    • YGC : 从系统启动到现在 Young GC/Minor GC 的次数
    • YGCT : Young GC 总耗时(秒)
    • FGC :从系统启动到现在 Full GC 的次数
    • FGCT : Full GC 的总耗时(秒)
    • GCT : 垃圾回收总的耗时(秒)
    • NGCMN :年轻代( young )中初始化(最小)的大小 (千字节)
    • NGCMX :年轻代( young )的最大容量 (千字节)
    • GC :年轻代( young )中当前的容量 (千字节)
    • OGCMNold 代中初始化(最小)的大小 (千字节)
    • OGCMXold 代的最大容量 (千字节)
    • OGCold 代当前新生成的容量 (千字节)
    • PGCMNperm 代中初始化(最小)的大小 (千字节)
    • PGCMXperm 代的最大容量 (千字节)
    • PGCperm 代当前新生成的容量 (千字节)
    • S0 :年轻代中 From survivor (幸存区)已使用的占当前容量百分比
    • S1 :年轻代中 To Survivor (幸存区)已使用的占当前容量百分比
    • E :年轻代中 Eden (伊甸园)已使用的占当前容量百分比
    • Oold 代已使用的占当前容量百分比
    • Pperm 代已使用的占当前容量百分比
    • S0CMX :年轻代中 From survivor (幸存区)的最大容量 (千字节)
    • S1CMX :年轻代中 To Survivor (幸存区)的最大容量 (千字节)
    • ECMX :年轻代中 Eden (伊甸园)的最大容量 (千字节)
    • DSS :当前需要 survivor (幸存区)的容量 (千字节)( Eden 区已满)
    • TT : 持有次数限制
    • MTT : 最大持有次数限制

jstat -gcutil PID

  • 一般我们还可以通过 jstat -gcutil pid 来获取分代年龄的使用情况,显示为占比,如下,表头参考上面

jstat -gccapacity PID

  • -gccapacity 命令主要用来分析堆内存,用法参考上面,如下效果,表头含义参看上面

其他一些命令参数

  • jstat -gcnew PID : 年轻代GC 分析,其中 TTMTT 可以看到对象在年龄代存活的年龄和存活的最大年龄

  • jstat -gcnewcapacity PID : 年轻代内存分析

  • jstat -gcold PID: 老年代 GC 分析

  • jstat -gcoldcapacity: 老年代内存分析

  • jstat -gcmetacapacity PID: 元数据内存分析

jstat -class PID

  • 统计进程中加载的类的数量,如下:

  • 说明:

Loaded:加载class的数量
Bytes:所占用空间大小
Unloaded:未加载数量
Bytes:未加载占用空间
Time:时间

jstat -compiler PID

  • 编译信息的统计命令, 如下命令 jstat -class 15372

  • 说明:
Compiled:编译数量。
Failed:失败数量
Invalid:不可用数量
Time:时间
FailedType:失败类型
FailedMethod:失败的方法

jstat -printcompilation PID

  • JVM 编译方法的统计,如下命令 jstat -printcompilation 15372

  • 说明:
Compiled:最近编译方法的数量
Size:最近编译方法的字节码数量
Type:最近编译方法的编译类型。
Method:方法名标识。

好了今天就说到这里, jstat 死一个非常还用的工具,需要平时多使用多分析才能真真掌握,下次我们接着说相关的工具的使用~

[JVM工具(1)] 堆栈检查利器jstat的使用的更多相关文章

  1. Linux ---> 监控JVM工具

    Linux ---> 监控JVM工具shkingshking 发布时间: 2013/10/10 01:27 阅读: 2642 收藏: 26 点赞: 1 评论: 0 JDK内置工具使用 jps(J ...

  2. jvm工具

    jvm工具 知识,经验是基础,数据是依据,工具是运营知识处理数据的手段 数据:运行日志.异常堆栈.GC日志.线程快照.堆转存储快照 JPS:虚拟机进程状况工具 jvm process status t ...

  3. 内存问题检查利器——Purify

    内存问题检查利器——Purify 一.           引言 我们都知道软件的测试(在以产品为主的软件公司中叫做QA—Quality Assessment)占了整个软件工程的30% -50%,但有 ...

  4. 【原创】大叔经验分享(71)docker容器中使用jvm工具

    java应用中经常需要用到jvm工具来进行一些操作,如果java应用部署在docker容器中,如何使用jvm工具? 首先要看使用的docker镜像, 比如常用的openjdk镜像分为jdk和jre,只 ...

  5. 使用TCMalloc的堆栈检查

    在前一篇译文<TCMalloc:线程缓冲的Malloc>详细讲解了TCMalloc的工作原理和特点,今天翻译<heap-checking using tcmalloc>,了解T ...

  6. JVM基础系列第11讲:JVM参数之堆栈空间配置

    JVM 中最重要的一部分就是堆空间了,基本上大多数的线上 JVM 问题都是因为堆空间造成的 OutOfMemoryError.因此掌握 JVM 关于堆空间的参数配置对于排查线上问题非常重要. tips ...

  7. 通用且常用的Java正则匹配工具,用以检查邮箱名、电话号码、用户密码、邮政编码等合法性

    一个通用且常用的Java正则匹配工具,用以检查邮箱名.电话号码.用户密码.邮政编码等合法性. import java.util.regex.Matcher; import java.util.rege ...

  8. JVM工具jstat使用说明

    输入:jstat -help得到以下帮助信息 Usage: jstat --help|-options jstat -<option> [-t] [-h<lines>] < ...

  9. jvm工具及命令大全

      虚拟机栈 栈桢大小缺省为1M,可用参数 –Xss调整大小,例如-Xss256k 堆 -Xms:堆的最小值: -Xmx:堆的最大值: -Xmn:新生代的大小: -XX:NewSize:新生代最小值: ...

随机推荐

  1. 面试必看!靠着这份字节和腾讯的面经,我成功拿下了offer!

    准备 敲定了方向和目标后就开始系统准备,主要分为以下几个方面来准备. 算法题 事先已经看过别人的社招面经知道头条每轮技术面都有算法题,而这一块平时练习的比较少,校招时刷的题也忘记了很多.因此系统复习的 ...

  2. 硕思logo设计师注册码去哪里找,文末附链接

    硕思logo设计师注册码去哪里找呢?当然是硕思logo设计师官网啦! 最近小编总是会被网友们咨询关于logo设计的问题,其中很多网友并不是专业的设计人员,特别是一些设计公司面对新手设计时,往往会不知所 ...

  3. 详细了解IDM的“计划任务”功能

    今天我们一起来看看IDM下载器的"计划任务"功能. IDM是什么就不多说了,只需要知道它是一个十分好用的资源下载器就行了,下载速度非常快,搭配一些浏览器扩展程序甚至能加速百度盘的下 ...

  4. 你还在 if...else?代码这样写才好看!

    前言 if...else 是所有高级编程语言都有的必备功能.但现实中的代码往往存在着过多的 if...else.虽然 if...else 是必须的,但滥用 if...else 会对代码的可读性.可维护 ...

  5. iOS 默认Cell选中

    NSInteger selectIndex = [NSIndexPath indexPathForItem:0 inSection:0]; [self.ui_tableView selectRowAt ...

  6. 【模板】【P3402】可持久化并查集

    (题面来自洛谷) 题目描述 n个集合 m个操作 操作: 1 a b 合并a,b所在集合 2 k 回到第k次操作之后的状态(查询算作操作) 3 a b 询问a,b是否属于同一集合,是则输出1否则输出0 ...

  7. 前端静态站点在阿里云自建 K8S DevOps 集群上优雅的进行 CI/CD

    目录 网站 域名 K8S DevOps 集群 私有 Gitlab 使用 Docker 编译站点 * Dockerfile * 构建编译 Image * 测试编译 Image * 推送镜像到 Aliyu ...

  8. nginx反向代理docker容器化django

    1.新建Dockerfile FROM python:3.8.5 MAINTAINER ChsterChen ENV PYTHONUNBUFFERED 1 COPY pip.conf /root/.p ...

  9. 熊海CMS xhcms v1.0代码审计

    有空的时候就进行小型CMS的代码审计,这次审计的对象是熊海CMS v1.0 本地环境安装好了之后,可以看到提示安装了锁文件 说明重装漏洞应该不会存在了,这时候丢进seay代码审计系统的代码也出结果了, ...

  10. tensorflow GPU的使用

    参考:https://blog.csdn.net/mzpmzk/article/details/78647711 import os # 默认情况,TF 会占用所有 GPU 的所有内存, 我们可以指定 ...