eseguo il mio app sul ENV produzione (RHEL 5.2 x64, Oracle JRE 1.7_05, Tomcat 7.0.28) con argomenti JVM:Java OutOfMemory eccezione: Errore di mmap il caricamento del file zip
-Xms8192m -Xmx8192m -XX:MaxPermSize=1024m
-Doracle.net.tns_admin=/var/ora_net -XX:ReservedCodeCacheSize=512m -XX:+AggressiveOpts -XX:+UseFastAccessorMethods
-XX:+UseStringCache -XX:+OptimizeStringConcat -XX:+UseCompressedOops -XX:+UseG1GC -Dcom.sun.management.jmxremote
-Dcom.sun.management.jmxremote.port=9026 -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false
Dopo diverso tempo i 've ottenuto traccia dello stack del genere:
Java HotSpot(TM) 64-Bit Server VM warning: Attempt to deallocate stack guard pages failed.
Java HotSpot(TM) 64-Bit Server VM warning: Attempt to allocate stack guard pages failed.
mmap failed for CEN and END part of zip file
[...]
Caused by: java.lang.OutOfMemoryError: null
at java.util.zip.ZipFile.$$YJP$$open(Native Method) ~[na:1.7.0_05]
at java.util.zip.ZipFile.open(Unknown Source) ~[na:1.7.0_05]
at java.util.zip.ZipFile.<init>(Unknown Source) ~[na:1.7.0_05]
at java.util.zip.ZipFile.<init>(Unknown Source) ~[na:1.7.0_05]
at java.util.jar.JarFile.<init>(Unknown Source) ~[na:1.7.0_05]
at java.util.jar.JarFile.<init>(Unknown Source) ~[na:1.7.0_05]
at sun.net.www.protocol.jar.URLJarFile.<init>(Unknown Source) ~[na:1.7.0_05]
at sun.net.www.protocol.jar.URLJarFile.getJarFile(Unknown Source) ~[na:1.7.0_05]
at sun.net.www.protocol.jar.JarFileFactory.get(Unknown Source) ~[na:1.7.0_05]
at sun.net.www.protocol.jar.JarURLConnection.connect(Unknown Source) ~[na:1.7.0_05]
at sun.net.www.protocol.jar.JarURLConnection.getInputStream(Unknown Source) ~[na:1.7.0_05]
at java.net.URL.openStream(Unknown Source) ~[na:1.7.0_05]
at org.apache.catalina.loader.WebappClassLoader.findLoadedResource(WebappClassLoader.java:3279) ~[na:na]
at org.apache.catalina.loader.WebappClassLoader.getResourceAsStream(WebappClassLoader.java:1478) ~[na:na]
at org.apache.http.util.VersionInfo.loadVersionInfo(VersionInfo.java:242) ~[httpcore-4.2.jar:4.2]
at org.apache.http.impl.client.DefaultHttpClient.setDefaultHttpParams(DefaultHttpClient.java:180) ~[httpclient-4.2.jar:4.2]
at org.apache.http.impl.client.DefaultHttpClient.createHttpParams(DefaultHttpClient.java:158) ~[httpclient-4.2.jar:4.2]
at org.apache.http.impl.client.AbstractHttpClient.getParams(AbstractHttpClient.java:448) ~[httpclient-4.2.jar:4.2]
Guardando al mio profiler - everthing è ok (heap e memoria non heap utilizzata per il 10%) e non ho idea di dove sia il problema.
Questo problema si verifica ogni giorno alla stessa ora e non è collegato al tempo di attività dell'applicazione. Qual è la causa del problema?
Modificato:
Nuova uscita nel file di registro:
Java HotSpot(TM) 64-Bit Server VM warning: CodeCache is full. Compiler has been disabled.
Java HotSpot(TM) 64-Bit Server VM warning: Try increasing the code cache size using -XX:ReservedCodeCacheSize=
Code Cache [0x00002aaaab790000, 0x00002aaaad240000, 0x00002aaacb790000)
total_blobs=4223 nmethods=3457 adapters=707 free_code_cache=497085Kb largest_free_block=508887936
ma ho abbastanza memoria: http://i.stack.imgur.com/K8VMx.jpg
Risposta: problema nella versione java. Descritto qui: https://forums.oracle.com/forums/thread.jspa?messageID=10369413
Per curiosità, come giudichi la parte di Yourkit? – Erik
Sì, sto usando 'yjp-11.0.8', ma il problema si verifica prima di installarlo. Proverò a rilasciare il collezionista 'G1', ma penso che non risolva il mio problema perché lavoro con' G1' per molto tempo. Inoltre ho un problema adesso: [yjp_out] (http://my.jetscreenshot.com/demo/20121010-pnud-83kb). –
Ho visto questi errori in precedenza quando esaurisco risorse come l'esaurimento dello spazio di swap o l'esaurimento della mappatura della memoria consentita. Dai un'occhiata a sudo cat/proc/$ PID/maps | wc -l 'rispetto a' cat/proc/sys/vm/max_map_count' –