XX:+ HeapDumpOnOutOfMemoryError最大文件大小限制

我正在使用XX:+HeapDumpOnOutOfMemoryErrorJVM标志运行Java进程,并看到以下输出:

java.lang.OutOfMemoryError: Java heap space

Dumping heap to /local/disk2/heaps/heapdump.hprof ...

Dump file is incomplete: file size limit

有没有办法解决这个问题?

回答:

-XX:+HeapDumpOnOutOfMemoryError当无法满足Java堆的分配或永久生成时,命令行选项告诉HotSpot

VM生成堆转储。使用此选项运行不会产生任何开销,因此对于OutOfMemoryError需要很长时间才能浮出水面的生产系统很有用。

为了解决您面临的特定问题,可以使用以下纠正措施之一:

XX:HeapDumpSegmentSize

-XX:HeapDumpSegmentSize选项在生成分段的HPROF堆转储时指定适当的段大小。

格式

-XX:HeapDumpSegmentSize =大小[k | K] [m | M] [g | G]

java -XX:+HeapDumpOnOutOfMemory -XX:HeapDumpSegmentSize=512M myApp

预设值

1 GB

-XX:SegmentedHeapDumpThreshold

当堆使用量大于指定大小时,-XX:SegmentedHeapDumpThreshold选项将生成分段堆转储(.hprof文件,1.0.2格式)。

需要分段的HPROF转储格式才能正确生成包含4 GB以上数据的堆转储。如果-XX:SegmentedHeapDumpThreshold选项的值设置为大于4

GB,则可能无法正确生成堆转储。

格式

-XX:SegmentedHeapDumpThreshold =大小

java -XX:SegmentedHeapDumpThreshold=512M myApp

默认值

2 GB

以上是 XX:+ HeapDumpOnOutOfMemoryError最大文件大小限制 的全部内容, 来源链接: utcz.com/qa/431329.html

回到顶部