Out of Memory Errors - Java
Transcription
Out of Memory Errors - Java
Out of Memory Errors a list of all of them Kees Jan Koster kjkoster@java-monitor.com Wednesday, March 13, 13 Wednesday, March 13, 13 • http://java-monitor.com/livedemo.html • • • • free, on-line service up and running in 5 minutes access server stats from your mobile get help in the integrated forum Wednesday, March 13, 13 java-monitor probe java-monitor probe java-monitor probe java-monitor server java-monitor plugin java-monitor probe java-monitor probe Wednesday, March 13, 13 Wednesday, March 13, 13 Wednesday, March 13, 13 Wednesday, March 13, 13 Wednesday, March 13, 13 Out of Memory Errors a list of all of them Kees Jan Koster kjkoster@java-monitor.com Wednesday, March 13, 13 Wednesday, March 13, 13 JVM cannot continue operation Wednesday, March 13, 13 java.lang.OutOfMemoryError: Java heap space at java.lang.Thread.start0(Native Method) at java.lang.Thread.start(Thread.java:597) at org.apache.tomcat.util.net.JIoEndpoint$Worker.start(JIoEndpoint.java:478) at org.apache.tomcat.util.net.JIoEndpoint.newWorkerThread(JIoEndpoint.java:697) at org.apache.tomcat.util.net.JIoEndpoint.createWorkerThread(JIoEndpoint.java:676) at org.apache.tomcat.util.net.JIoEndpoint.getWorkerThread(JIoEndpoint.java:708) at org.apache.tomcat.util.net.JIoEndpoint.processSocket(JIoEndpoint.java:743) at org.apache.tomcat.util.net.JIoEndpoint$Acceptor.run(JIoEndpoint.java:320) at java.lang.Thread.run(Thread.java:619) at ... Wednesday, March 13, 13 java.lang.OutOfMemoryError: at at at at at at at at at at Java heap space java.lang.Thread.start0(Native Method) java.lang.Thread.start(Thread.java:597) org.apache.tomcat.util.net.JIoEndpoint$Worker.start(JIoEndpoint.java:478) org.apache.tomcat.util.net.JIoEndpoint.newWorkerThread(JIoEndpoint.java:697) org.apache.tomcat.util.net.JIoEndpoint.createWorkerThread(JIoEndpoint.java:676) org.apache.tomcat.util.net.JIoEndpoint.getWorkerThread(JIoEndpoint.java:708) org.apache.tomcat.util.net.JIoEndpoint.processSocket(JIoEndpoint.java:743) org.apache.tomcat.util.net.JIoEndpoint$Acceptor.run(JIoEndpoint.java:320) java.lang.Thread.run(Thread.java:619) ... Wednesday, March 13, 13 • non-fatal OOME’s • Java heap space • PermGen space • GC overhead limit exceeded • Requested array size exceeds VM limit • unable to create new native thread Wednesday, March 13, 13 • fatal OOME’s • thr_setspecific: out of swap space • Out of swap space to map in thread stack • CodeCache: no room for %s • CodeCache: no room for vtable chunks • offset table expansion • G1 heap expansion • Cannot create GC thread. Out of system resources • object start array expansion • card table last card • unable to allocate initial hashtable for jvmti object • • Wednesday, March 13, 13 tags Cannot create GangWorker array ... • non-fatal OOME’s • Java heap space • PermGen space • GC overhead limit exceeded • Requested array size exceeds VM limit • unable to create new native thread Wednesday, March 13, 13 heap Wednesday, March 13, 13 nonheap Wednesday, March 13, 13 Wednesday, March 13, 13 • memory profiling • what does not belong? • what’s big when it should be small? • what’s many that should be few? Wednesday, March 13, 13 • JavaRanch.com • • • • appalling performance JVM pauses inexplicably large memory consumption memory leak? Wednesday, March 13, 13 Wednesday, March 13, 13 • analysed heap dump and found: • org.apache.lucene.search.FieldCache$StringIndex • 3 copies, each about 115MB • similar, but not identical • containing strings like “20081010125634” • developer changed type from String to long • timestamp index Wednesday, March 13, 13 before after Wednesday, March 13, 13 seconds milliseconds Wednesday, March 13, 13 • Java heap space • check for memory leaks • get heap dumps • • • -XX:+HeapDumpOnOutOfMemoryError • use a memory profiler bigger heap using -Xmx=… PermGen space • check class loading • clean up redeployment leaks • check for string interning • bigger non-heap using -XX:MaxPermSize=… Wednesday, March 13, 13 • non-fatal OOME’s • Java heap space • PermGen space • GC overhead limit exceeded • Requested array size exceeds VM limit • unable to create new native thread Wednesday, March 13, 13 Wednesday, March 13, 13 young generation old generation heap scavenger collector Wednesday, March 13, 13 full garbage collector nonheap • GC Java heap space • check for memory leaks • get heap dumps • • d e d e e c x e t i m i l d a e h r ove • -XX:+HeapDumpOnOutOfMemoryError • use a memory profiler bigger heap using -Xmx=… PermGen space • check class loading • clean up redeployment leaks • check for string interning • bigger non-heap using -XX:MaxPermSize=… Wednesday, March 13, 13 42536.572: [GC 42536.572: [ParNew: 353920K->2080K(353920K), >1137843K(2520704K), 0.1249020 secs] 42546.733: [GC 42546.733: [ParNew: 316704K->3604K(353920K), >1139368K(2520704K), 0.0602080 secs] 42555.527: [GC 42555.527: [ParNew: 318228K->5034K(353920K), >1140797K(2520704K), 0.0611270 secs] 42564.154: [GC 42564.154: [ParNew: 319658K->5214K(353920K), >1142411K(2520704K), 0.0782850 secs] 42571.444: [GC 42571.444: [ParNew: 319838K->5514K(353920K), >1144161K(2520704K), 0.0651220 secs] 42576.714: [GC 42576.714: [ParNew 0.1246980 secs] 1450967K0.0599980 secs] 1452467K0.0609210 secs] 1453992K0.0780650 secs] 1455421K0.0649090 secs] 1457035K- (promotion failed): 320138K- >320138K(353920K), 0.2365970 secs]42576.951: [CMS: 1139969K->1120688K( 2166784K), 9.2214860 secs] 1458785K->1120688K(2520704K), 9.4584090 secs] 42587.017: [GC 42587.017: [ParNew: 314624K->34454K(353920K), 0.1340880 secs] 1435312K>1205264K(2520704K), 0.1344800 secs] 42588.700: [GC 42588.701: [ParNew: 349078K->23091K(353920K), Wednesday, March 13, 13 Wednesday, March 13, 13 CMS is non-compacting Wednesday, March 13, 13 can’t meet “young generation guarantee” promotion failed Wednesday, March 13, 13 • promotion failed • -Xloggc:/var/log/gc.log -verbose:gc • • • Wednesday, March 13, 13 -XX:+PrintGCDetails -XX:+PrintGCTimeStamps bigger heap smaller eden ... • non-fatal OOME’s • Java heap space • PermGen space • GC overhead limit exceeded • Requested array size exceeds VM limit • unable to create new native thread Wednesday, March 13, 13 heap Wednesday, March 13, 13 nonheap ObjectInputStream is = ... int size = is.readInt(); String[] someArray = new String[size]; Wednesday, March 13, 13 ObjectInputStream is = ... int size = is.readInt(); if (size > 100) { throw new IllegalArgumentException(“insane “ + size); } String[] someArray = new String[size]; Wednesday, March 13, 13 Wednesday, March 13, 13 • Requested array size exceeds VM limit • use the stack trace (this once!) • allocate smaller arrays • validate external array sizes Wednesday, March 13, 13 • non-fatal OOME’s • Java heap space • PermGen space • GC overhead limit exceeded • Requested array size exceeds VM limit • unable to create new native thread Wednesday, March 13, 13 heap nonheap native code thread stacks are allocated here Wednesday, March 13, 13 OS 1-2 GB heap non- native heap code 4GB hard 32-bit process limit Wednesday, March 13, 13 • unable to create new native thread • -Xss to limit thread stacks • *reduce* the heap and/or non-heap pools • switch to 64-bit • use sane heap/non-heap/thread stack sizes Wednesday, March 13, 13 • non-fatal OOME’s • Java heap space • PermGen space • GC overhead limit exceeded • Requested array size exceeds VM limit • unable to create new native thread Wednesday, March 13, 13 • fatal OOME’s • thr_setspecific: out of swap space • Out of swap space to map in thread stack • CodeCache: no room for %s • CodeCache: no room for vtable chunks • offset table expansion • G1 heap expansion • Cannot create GC thread. Out of system resources • object start array expansion • card table last card • unable to allocate initial hashtable for jvmti object • • Wednesday, March 13, 13 tags Cannot create GangWorker array ... physical memory RAM SWAP fast Wednesday, March 13, 13 disk-based memory very, very slow RAM Wednesday, March 13, 13 SWAP RAM Wednesday, March 13, 13 SWAP RAM Wednesday, March 13, 13 SWAP • fatal OOME’s • thr_setspecific: out of swap space • Out of swap space to map in thread stack • CodeCache: no room for %s • CodeCache: no room for vtable chunks • offset table expansion • G1 heap expansion • Cannot create GC thread. Out of system resources • object start array expansion • card table last card • unable to allocate initial hashtable for jvmti object n o i t a c o l l a M A R k c e h s c t i • m i l m e t s y s k c e h c • • • Wednesday, March 13, 13 tags Cannot create GangWorker array ...
Similar documents
::rflrio Dc6ooo2 !.fi"d
snrt^toiradt : :Jn6 g o.tJ., lil:JnGutohirilrrr:aH'o.u. iufiq:rairn:r:fin$saudufia: :6 n.rl.2553 - 14 n'$' 2553 - r{nn'r:er:'tortl'hisiyrur ,irl*u,{otrio'hiur'qun Iqui?rflrstrunrdatu Cellculture tln;
More information