上一篇 <<<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性能调优的评估指标及调优示例