Metaspace OOM before reaching MaxMetaspaceSize
David Holmes
david.holmes at oracle.com
Fri Apr 26 06:28:42 UTC 2019
Hi Shengpei,
On 26/04/2019 10:19 am, Shengpei Zhang wrote:
> Hi,
>
> We recently saw a weird Metaspace OOM. The hs_err_pid log showed the
> metaspace usage was 325078K, while the MaxMetaspaceSize was set to 4G.
The log shows the mmap failure occurs when trying to create the stack
guard pages of the new thread - nothing related to Metaspace.
Cheers,
David
> The machine was running JAVA10.
>
> Few observations:
>
> 1. It only happened at one machine, and we were not able to reproduce it.
>
> 2. Error log indicated memory allocation failure in native memory.
>
> [2019-03-29T11:18:01.298-0700][126538][info ][gc,metaspace,freelist]
> [2019-03-29T11:18:01.298-0700][126538][info ][gc,metaspace,freelist]
> Chunkmanager (non-class):
> [2019-03-29T11:18:01.298-0700][126538][info ][gc,metaspace,freelist]
> 62578 specialized (128 bytes) chunks, total 64079872 bytes
> [2019-03-29T11:18:01.298-0700][126538][info ][gc,metaspace,freelist] 5778
> small (512 bytes) chunks, total 23666688 bytes
> [2019-03-29T11:18:01.298-0700][126538][info ][gc,metaspace,freelist] 27
> medium (8192 bytes) chunks, total 1769472 bytes
> [2019-03-29T11:18:01.298-0700][126538][info ][gc,metaspace,freelist] 13
> humongous chunks, total 8890368 bytes
> [2019-03-29T11:18:01.298-0700][126538][info ][gc,metaspace,freelist]
> total size: 98406400 bytes.
> [2019-03-29T11:18:01.298-0700][126538][info ][gc,metaspace,freelist]
> Chunkmanager (class):
> [2019-03-29T11:18:01.298-0700][126538][info ][gc,metaspace,freelist]
> unavailable.
> java.lang.OutOfMemoryError: Metaspace
> Dumping heap to java_pid240.hprof ...
> vmop [ threads: total
> initially_running wait_to_block ][ time: spin block sync cleanup
> vmop ] page_trap_count
> 66467.977: ICBufferFull [ 3427
> 154 353 ][ 0 60 63 8 0 ]
> 58
> [2019-03-29T11:18:01.308-0700][459 ][info ][safepoint ] Total
> time for which application threads were stopped: 0.0725507 seconds,
> Stopping threads took: 0.0630158 seconds
> [thread 384508 also had an error]
> #
> # There is insufficient memory for the Java Runtime Environment to continue.
> # Native memory allocation (mmap) failed to map 16384 bytes for committing
> reserved memory.
> # An error report file with more information is saved as:
> # /data/hs_err_pid240.log
>
> 3. The hs_err_pid log showed the metaspace memory usage was 325078K, it is
> far less than the reserved size 568176K. Also, the MaxMetaspaceSize was set
> to 4G. I checked the machine had plenty of free native memory at that time.
> If there was a huge allocation, I assume JVM would try to reserve more
> memory first?
>
> Heap:
> garbage-first heap total 188743680K, used 47178320K [0x00007ee320000000,
> 0x00007f1020000000)
> region size 32768K, 70 young (2293760K), 0 survivors (0K)
> Metaspace used 325078K, capacity 451348K, committed 547448K,
> reserved 568176K
>
> Also it showed that there was 5G free memory on the machine:
>
> /proc/meminfo:
> MemTotal: 263892284 kB
> MemFree: 5111480 kB
> MemAvailable: 42423728 kB
> Buffers: 752620 kB
> Cached: 36011560 kB
> SwapCached: 0 kB
> Active: 221763832 kB
> Inactive: 31633872 kB
>
> 4. The stacktrace
>
> --------------- T H R E A D ---------------
>
> Current thread (0x00007edec0023840): JavaThread
> "http-client-exchange-39327" daemon [_thread_new, id=384507,
> stack(0x00007ed6c8a6b000,0x00007ed6c8c6c000)]
>
> Stack: [0x00007ed6c8a6b000,0x00007ed6c8c6c000], sp=0x00007ed6c8c6aa90,
> free space=2046k
> Native frames: (J=compiled Java code, A=aot compiled Java code,
> j=interpreted, Vv=VM code, C=native code)
> V [libjvm.so+0xdf3ee2] VMError::report_and_die(int, char const*, char
> const*, __va_list_tag*, Thread*, unsigned char*, void*, void*, char const*,
> int, unsigned long)+0x162
> V [libjvm.so+0xdf4b8b] VMError::report_and_die(Thread*, char const*, int,
> unsigned long, VMErrorType, char const*, __va_list_tag*)+0x2b
> V [libjvm.so+0x6a7c98] report_vm_out_of_memory(char const*, int, unsigned
> long, VMErrorType, char const*, ...)+0xd8
> V [libjvm.so+0xbfdc8e] os::pd_commit_memory(char*, unsigned long,
> bool)+0xce
> V [libjvm.so+0xbf647f] os::commit_memory(char*, unsigned long, bool)+0x1f
> V [libjvm.so+0xbff1f8] os::pd_create_stack_guard_pages(char*, unsigned
> long)+0x68
> V [libjvm.so+0xd9013c] JavaThread::create_stack_guard_pages()+0x5c
> V [libjvm.so+0xd92c7c] JavaThread::run()+0x2c
> V [libjvm.so+0xc03e82] thread_native_entry(Thread*)+0xf2
> C [libpthread.so.0+0x7e25] start_thread+0xc5
>
> We have never seen such issue before. Does anyone have insights?
>
> Thanks,
> Shengpei
>
More information about the hotspot-dev
mailing list