GC常用日志参数配置及分析工具说明

上一篇 <<<GC中新生代进入老年代的方式汇总
下一篇 >>>FullGC、MinorGC、STW等常见问题如何解答


日志详细信息

-XX:+PrintHeapAtGC

控制台打印日志信息

-verbose:gc -XX:+PrintGCDetails

输出到指定路径

-Xloggc:./gc.log

日志大小分块

-XX:-UseGCLogFileRotation -XX:GCLogFileSize = 8M

堆内存异常打印

-XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=hdpserver_oom.hprof

Young GC日志

[GC (System.gc()) [PSYoungGen: 105324K->480K(149504K)] 310421K->205577K(491008K), 0.0013451 secs] [Times: user=0.00 sys=0.00, real=0.01 secs] 
新生代发生GC ,从堆内存回收前占用:105324K 回收后变为占用480K ,后面表示GC的用时。

Full GC日志

[Full GC (System.gc()) [PSYoungGen: 480K->0K(149504K)] [ParOldGen: 205097K->581K(341504K)] 205577K->581K(491008K), [Metaspace: 4065K->4065K(1056768K)], 0.0094772 secs] [Times: user=0.03 sys=0.00, real=0.01 secs] 
当发生老年代GC时,也会触发新生代GC,新生代堆回收前占用488K,回收后占用0K,ParOldGen 老年代回收前占用205097K,回收后占用581K,Metaspace表示元空间的情况

GC日志分析工具

GCViewer、GCEasy、GCHisto、GCLogViewer 、Hpjmeter、garbagecat


相关文章链接:
<<<JVM整体内存结构的图解,直观明了
<<<javap命令查看对象信息及操作方法在JVM层的实现原理
<<<javap命令反查汇编指令汇总
<<<ClassLoader类加载器顺序Demo测试与双亲委派源码解读
<<<自定义SPI和热部署技术破坏类加载器的双亲委派模式
<<<JVM中对象如何完成空间分配和初始化工作
<<<JVM元空间(方法区)和栈内存溢出原因及解决方案
<<<JVM堆内存溢出和内存泄露问题定位和解决
<<<JVM常见死锁问题产生原因和多种诊断方式
<<<服务器CPU飙升为100%问题排查及如何避免
<<<JVM内存诊断命令和排查工具汇总
<<<JVM新生代老年代算法汇总图解
<<<JVM垃圾回收不要手动System.gc的真正原因
<<<JVM垃圾回收引用计数法和根搜索算法图解
<<<JVM垃圾回收STW(Stop-The-World)代码演示
<<<JVM垃圾回收器的发展历程及使用场景汇总
<<<JVM串行并行垃圾回收器的关注点
<<<一张图看懂CMS垃圾回收器的底层原理
<<<G1能作为JDK9默认垃圾回收器的优势分析
<<<CMS和G1的漏标问题解决及三色标记算法图解
<<<GC中新生代进入老年代的方式汇总
<<<FullGC、MinorGC、STW等常见问题如何解答
<<<JVM性能调优的评估指标及调优示例

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容