Spiega l'uso dei parametri Xms
e Xmx
nelle JVM. Quali sono i valori predefiniti per loro?
Il flag Xmx
specifica il massimo pool di allocazione della memoria per una macchina virtuale Java (JVM), mentre Xms
specifica il pool di allocazione della memoria iniziale.
Questo significa che la vostra JVM sarà avviata con una quantità di memoria Xms
e sarà in grado di utilizzare una quantità massima di memoria Xmx
. Per esempio, avviare una JVM come qui sotto la farà partire con 256 MB di memoria e permetterà al processo di usare fino a 2048 MB di memoria:
java -Xms256m -Xmx2048m
Il flag di memoria può anche essere specificato in diverse dimensioni, come kilobyte, megabyte e così via.
-Xmx1024k
-Xmx512m
-Xmx8g
Il flag Xms
non ha un valore predefinito, e Xmx
ha tipicamente un valore predefinito di 256 MB. Un uso comune per questi flag è quando si incontra un java.lang.OutOfMemoryError
.
Quando usi queste impostazioni, tieni a mente che queste impostazioni sono per lo heap della JVM, e che la JVM può/deve usare più memoria che la sola dimensione allocata allo heap. Da documentazione di Oracle:
Si noti che la JVM usa più memoria del solo heap. Per esempio i metodi Java, gli stack dei thread e gli handle nativi sono allocati in memoria separata dall'heap, così come le strutture dati interne della JVM.
Eseguite il comando java -X
e otterrete una lista di tutte le opzioni -X
:
C:\Users\Admin>java -X
-Xmixed mixed mode execution (default)
-Xint interpreted mode execution only
-Xbootclasspath:<directories and zip/jar files separated by ;>
set search path for bootstrap classes and resources
-Xbootclasspath/a:<directories and zip/jar files separated by ;>
append to end of bootstrap class path
-Xbootclasspath/p:<directories and zip/jar files separated by ;>
prepend in front of bootstrap class path
-Xdiag show additional diagnostic messages
-Xnoclassgc disable class garbage collection
-Xincgc enable incremental garbage collection
-Xloggc:<file> log GC status to a file with time stamps
-Xbatch disable background compilation
-Xms<size> set initial Java heap size.........................
-Xmx<size> set maximum Java heap size.........................
-Xss<size> set java thread stack size
-Xprof output cpu profiling data
-Xfuture enable strictest checks, anticipating future default
-Xrs reduce use of OS signals by Java/VM (see documentation)
-Xcheck:jni perform additional checks for JNI functions
-Xshare:off do not attempt to use shared class data
-Xshare:auto use shared class data if possible (default)
-Xshare:on require using shared class data, otherwise fail.
-XshowSettings show all settings and continue
-XshowSettings:all show all settings and continue
-XshowSettings:vm show all vm related settings and continue
-XshowSettings:properties show all property settings and continue
-XshowSettings:locale show all locale related settings and continue
**Le opzioni -X non sono standard e sono soggette a cambiamenti senza preavviso.
Spero che questo vi aiuti a capire Xms
, Xmx
e molte altre cose che contano di più :)
La domanda in sé è già stata affrontata sopra. Sto solo aggiungendo una parte dei valori predefiniti.
Come da http://docs.oracle.com/cd/E13150_01/jrockit_jvm/jrockit/jrdocs/refman/optionX.html
Il valore predefinito di Xmx dipenderà dalla piattaforma e dalla quantità di memoria disponibile nel sistema.