使用JVM常用GC日志打印参数

 更新时间:2021年09月14日 08:40:11   作者:NetWhite  
这篇文章主要介绍了使用JVM常用GC日志打印参数,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

JVM常用GC日志打印参数

1. PrintGC

最简单的GC参数。

启用配置:-XX:+PrintGC

日志如下:

根据上面红色方框内的数字1、2、3、4、5说明,1是GC类型,GC:minor GC(young gc),Full GC:major GC,2是GC前堆内存使用量,3是GC后堆内存使用量,4是堆内存总量,5是本次GC耗时

2. PrintGCDetails

打印GC的详细信息

启用配置:-XX:+PrintGCDetails

日志如下:

不同的垃圾回收器,GC日志(表示年代的词)可能会不一样, 和第一节中差不多,->前的是GC前堆内存使用量,->后面是GC后堆内存使用量,括号内是堆内存总量。

对于这个日志,PSYoungGen:年轻代,ParOldGen:老年代,PSPermGen:持久代(方法区)

Times: user表示用户态CPU耗时,sys表示系统CPU耗时,real表示GC实际耗时

3. PrintGCTimeStamps

GC时,打印进程启动到现在经历的时间

启用配置:-XX:+PrintGCTimeStamps

日志如下:

红色方框内的时间,表示进程启动到现在经历的时间

该参数需要配合其它GC日志打印参数一起使用,如下

4. PrintGCApplicationStoppedTime

打印GC时,应用停顿时间

启用配置:-XX:+PrintGCApplicationStoppedTime

日志如下:

5. PrintGCApplicationConcurrentTime

GC时打印应用执行时间

启用配置:-XX:+PrintGCApplicationConcurrentTime

日志如下:

6. PrintHeapAtGC

每次GC前后打印堆信息

启用配置:-XX:+PrintHeapAtGC

日志如下:

p.s. 上面几个参数可同时配合使用,同时使用PrintGC和PrintGCDetails时,打印的详细信息。

GC日志信息默认是打印到控制台,如果需要输出到文件,可以使用参数:-Xloggc:gc.log,gc.log是要输出的日志文件,路径为应用启动路径的相对路径下,也可以使用绝对路径。

JVM打印GC日志到文件

package gc;
public class GcTest {
 private static final int _1MB= 1024 * 1024;
 public static void main(String[] args) {
  byte[] a1, a2, a3, a4;
  a1 = new byte[2 * _1MB];
  a2 = new byte[2 * _1MB];
  a3 = new byte[2 * _1MB];
  a4 = new byte[2 * _1MB];
 }
}

打印GC日志

D:\study\workspace\jvm\src>java -Xms20M -Xmx20M -Xmn10M -XX:Survivor

Ratio=8 -XX:+PrintGCDetails -Xloggc:d:\gc.log gc.GcTest

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Java中的同步与异步详细介绍

    Java中的同步与异步详细介绍

    这篇文章主要介绍了Java中的同步与异步详细介绍,具有一定参考价值,需要的朋友可以了解下。
    2017-11-11
  • springboot实现异步调用@Async的示例

    springboot实现异步调用@Async的示例

    这篇文章主要介绍了springboot实现异步调用@Async的示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-12-12
  • IntelliJ IDEA 2022安装注册永久激活

    IntelliJ IDEA 2022安装注册永久激活

    java开发工具IntelliJ IDEA深受用户喜爱,很多朋友对这个idea开发工具比较忠心,一旦有新版本发出,很多小伙伴就迫不及待的想更新,今天小编给大家带来了idea2022.1最新永久激活码,亲测有效,喜欢的朋友快来下载体验吧
    2022-08-08
  • java如何从linux服务器下载文件

    java如何从linux服务器下载文件

    这篇文章主要介绍了java如何从linux服务器下载文件,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-01-01
  • java新增关联的三张表,每张表要求都插入集合,代码实现方式

    java新增关联的三张表,每张表要求都插入集合,代码实现方式

    这篇文章主要介绍了java新增关联的三张表,每张表要求都插入集合,代码实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-12-12
  • java解析{{}}变量名以及文本内容替换操作

    java解析{{}}变量名以及文本内容替换操作

    这篇文章主要介绍了java解析{{}}变量名以及文本内容替换操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-09-09
  • java版微信和支付宝退款接口

    java版微信和支付宝退款接口

    这篇文章主要为大家详细介绍了java版微信退款接口和java版支付宝退款接口,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-09-09
  • SpringBoot2中使用@RequestHeader获取请求头的方法

    SpringBoot2中使用@RequestHeader获取请求头的方法

    springMVC/SpringBoot中提供了@RequestHeader注解用来获取请求头。本文就详细的来介绍一下如何使用,感兴趣的可以了解下
    2021-10-10
  • RestTemplate使用Proxy代理作为跳板发送请求

    RestTemplate使用Proxy代理作为跳板发送请求

    这篇文章主要为大家介绍了RestTemplate使用代理proxy作为跳板发送请求的方法示例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步
    2022-03-03
  • 详解SpringBoot 统一后端返回格式的方法

    详解SpringBoot 统一后端返回格式的方法

    今天我们来聊一聊在基于SpringBoot前后端分离开发模式下,如何友好的返回统一的标准格式以及如何优雅的处理全局异常,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2022-05-05

最新评论