JVM的GC日志的主要参数包括如下几个:
-XX:+PrintGC 输出GC日志
-XX:+PrintGCDetails 输出GC的详细日志
-XX:+PrintGCTimeStamps 输出GC的时间戳(以基准时间的形式)
-XX:+PrintGCDateStamps 输出GC的时间戳(以日期的形式,如 2013-05-04T21:53:59.234+0800)
-XX:+PrintHeapAtGC 在进行GC的前后打印出堆的信息
-Xloggc:../logs/gc.log 日志文件的输出路径
在我做了如下的设置
以后打印出来的日志为:
我们取倒数第二条记录分析一下各个字段都代表了什么含义
我们再对数据做一个简单的分析
从最后一条GC记录中我们可以看到 Young GC回收了 45278-6723=38555K的内存
Heap区通过这次回收总共减少了 46974-10551=36423K的内存。
38555-36423=2132K说明通过该次Young GC有2132K的内存被移动到了Old Gen,
我们来验证一下
在最后一次Young GC的回收以前 Old Gen的大小为8702-7006=1696
回收以后Old Gen的内存使用为10551-6723=3828
Old Gen在该次Young GC以后内存增加了3828-1696=2132K 与预计的相符
============================
"Allocation Failure" is a cause of GC cycle to kick.
"Allocation Failure" means what no more space left in Eden to allocate object. So, it is normal cause of young GC.
意思是说没法分配更多的空间给Eden区
Seeing GC Allocation Failure in GC logs is totally NORMAL and not a problem by itself.
When using the Parallel GC collector/compactor, the Heap is split in between Young and Old spaces. GC Allocation failure is your case simply indicates the JVM reaches its max capacity of the YG space and now has to cleanup the short-lived objects or "garbage" from your Java application.
This situation only becomes problematic is being executed too frequently and/or taking too much time to complete given it is a stop-the-world event.
从以上解释来看Allocation Failure 只是代表年轻带不足,不是说GC产生了问题
Gc日志分析工具
(1)GCViewer
https://github.com/chewiebug/GCViewer
中文解释:http://www.cnblogs.com/o-andy-o/p/4058271.html
其它监控方法
Jvisualvm动态分析jvm内存情况和gc情况,插件:visualGC