多种方法都能开启GC的日志功能,其中包括:使用-verbose:gc或-XX:+PrintGC这两个标志中的任意一个能建立基本的GC日志(这两个日志标志实际上互为别名,默认状况下的GC日志功能是关闭的)。使用-XX:+PrintGCDetails标志会建立更详细的GC日志。服务器
咱们推荐使用-XX:+PrintGCDetails标志(这个标志默认状况下也是关闭的);一般状况下使用基本的GC日志很难诊断垃圾回收时发生的问题。日志
除了使用详细的GC日志,咱们还推荐使用-XX:+PrintGCTimeStamps或者-XX:+PrintGCDateStamps,便于咱们更精确地判断几回GC操做之间的时间。这两个参数之间的差异在于时间戳是相对于0(依据JVM启动的时间)的值,而日期戳(date stamp)是实际的日期字符串。因为日期戳须要进行格式化,因此它的效率可能会受轻微的影响,不过这种操做并不频繁,它形成的影响也很难被咱们感知。字符串
默认状况下GC日志直接输出到标准输出,不过使用-Xloggc:filename标志也能修改输出到某个文件。除非显式地使用-PrintGCDetails标志,不然使用-Xloggc会自动地开启基本日志模式。使用日志循环(Log rotation)标志能够限制保存在GC日志中的数据量;对于须要长时间运行的服务器而言,这是一个很是有用的标志,不然累积几个月的数据极可能会耗尽服务器的磁盘。io
经过-XX:+UseGCLogfileRotation -XX:NumberOfGCLogfiles=N-XX:GCLogfileSize=N标志能够控制日志文件的循环。默认状况下,UseGCLogfileRotation标志是关闭的。开启UseGCLogfileRotation标志后,默认的文件数目是0(意味着不做任何限制),默认的日志文件大小是0(一样也是不做任何限制)。效率
所以,为了让日志循环功能真正生效,咱们必须为全部这些标志设定值。须要注意的是,若是设定的数值不足8 KB的话,日志文件的大小会以8 KB为单位规整。date