XX:+HeapDumpOnOutOfMemoryError Max file size limit

前端 未结 2 832
臣服心动
臣服心动 2021-01-12 22:45

I\'m running a Java process with the XX:+HeapDumpOnOutOfMemoryError JVM flag and seeing the following output:

java.lang.OutOfMemoryError: Java h         


        
相关标签:
2条回答
  • 2021-01-12 23:29

    A simple reason for that exact failure message may be:
    There was not enough space in the dump directory.

    The dump directory is the current working directory if not altered via the JVM parameter -XX:HeapDumpPath (see documentation).

    0 讨论(0)
  • 2021-01-12 23:33

    The -XX:+HeapDumpOnOutOfMemoryError command-line option tells the HotSpot VM to generate a heap dump when an allocation from the Java heap or the permanent generation cannot be satisfied. There is no overhead in running with this option, and so it can be useful for production systems where OutOfMemoryError takes a long time to surface.

    In order to resolve the specific problem that you are facing, you can use one of the following corrective measures:

    Measure 1: XX:HeapDumpSegmentSize

    The -XX:HeapDumpSegmentSize option specifies an appropriate segment size when generating a segmented HPROF heap dump.

    Format

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

    Example

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

    Default Values
    1 GB

    Measure 2 -XX:SegmentedHeapDumpThreshold

    The -XX:SegmentedHeapDumpThreshold option generates a segmented heap dump (.hprof file, 1.0.2 format) when the heap usage is larger than the specified size.

    The segmented HPROF dump format is required to correctly generate heap dumps containing more than 4 GB of data. If the value of -XX:SegmentedHeapDumpThreshold option is set more than 4 GB, heap dumps may not be generated correctly.

    Format
    -XX:SegmentedHeapDumpThreshold=size

    Example

    java -XX:SegmentedHeapDumpThreshold=512M myApp

    Default Value
    2 GB

    0 讨论(0)
提交回复
热议问题