Quels sont les paramètres -Xms et -Xmx lors du démarrage de JVM?

1008

Veuillez expliquer l'utilisation Xmset les Xmxparamètres des machines virtuelles Java. Quelles sont les valeurs par défaut pour eux?

Pankaj
la source
2
lors de son utilisation -Xmx128m -Xms64mpeut atteindre un pic autour de 275mmem mem RES, mais lors de son utilisation -Xmx128m -Xms128mpeut pic autour de 550mmem mem RES En utilisant Java 8 La meilleure chose est de souligner le GC et de regarder ce qui se passe ...
Christophe Roussy

Réponses:

1360

L'indicateur Xmxspécifie le pool d'allocation de mémoire maximum pour une machine virtuelle Java (JVM), tandis que Xmsspécifie le pool d'allocation de mémoire initial.

Cela signifie que votre machine virtuelle Java sera démarrée avec une Xmsquantité de mémoire et pourra utiliser un maximum Xmxde mémoire. Par exemple, le démarrage d'une machine virtuelle Java comme ci-dessous la démarrera avec 256 Mo de mémoire et permettra au processus d'utiliser jusqu'à 2048 Mo de mémoire:

java -Xms256m -Xmx2048m

L'indicateur de mémoire peut également être spécifié dans différentes tailles, telles que des kilo-octets, des mégaoctets, etc.

-Xmx1024k
-Xmx512m
-Xmx8g

L' Xmsindicateur n'a pas de valeur par défaut et a Xmxgénéralement une valeur par défaut de 256 Mo. Une utilisation courante de ces drapeaux est lorsque vous rencontrez un java.lang.OutOfMemoryError.

Lorsque vous utilisez ces paramètres, gardez à l'esprit que ces paramètres sont pour le tas de la JVM et que la JVM peut / utilisera plus de mémoire que la taille allouée au tas. De la documentation d'Oracle :

Notez que la JVM utilise plus de mémoire que le tas. Par exemple, les méthodes Java, les piles de threads et les descripteurs natifs sont alloués dans une mémoire distincte du tas, ainsi que dans les structures de données internes JVM.

hexacyanide
la source
12
Il en est de même lorsque l'utilisation de la mémoire dépasse Xmx, nous obtenons jvm hors exception de mémoire.
Pankaj
59
Oui c'est correct. Quand il essaie de dépasser cela, même s'il peut collecter des ordures pour essayer de libérer suffisamment de mémoire. S'il n'y a toujours pas assez de mémoire pour satisfaire la demande et que le tas a déjà atteint la taille maximale, un OutOfMemoryErrorse produira.
David Conrad
2
Lorsque j'utilise le framework ForkJoin, mon ordinateur se bloque parce qu'il prend trop de mémoire. Est-il possible que sur OpenJDK il n'y ait pas de limite stricte sur la mémoire par défaut?
Christophe De Troyer
6
Comme précisé à java -Xmx 1G signifie 1 Go ou 2 ^ 30 B? , la manière non ambiguë d'exprimer la quantité de mémoire avec laquelle vous commencez via -Xms256mest "256 Mo", et non "256 Mo", car elle utilise des puissances binaires plutôt que des puissances de dix. Voir en.wikipedia.org/wiki/Binary_prefix . En outre, comme un espace inutilisable est réservé pour un pool supplémentaire d'espace Survivor, la quantité de mémoire réellement disponible Runtime.getRuntime().maxMemory()est inférieure à la valeur spécifiée via -Xmx
nealmcb
1
Un guide utile des erreurs courantes relatives à la taille du tas: blog.paulgu.com/java/6-common-errors-in-setting-java-heap-size
ctrlplusb
315

Exécutez la commande java -Xet vous obtiendrez une liste de toutes les -Xoptions:

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

Les options -X ne sont pas standard et peuvent être modifiées sans préavis.

J'espère que cela vous aidera à comprendre Xms, Xmxainsi que bien d'autres choses qui comptent le plus. :)

Rupesh Yadav
la source
1
J'ai appris une nouvelle commande aujourd'hui, merci @RupeshYadav
jumping_monkey
18

Vous pouvez le spécifier dans votre IDE. Par exemple, pour Eclipse dans Run ConfigurationsArguments VM . Vous pouvez entrer en -Xmx800m -Xms500mtant que

Entrez la description de l'image ici

Mehrez BEN MOHAMED
la source
Dans RubyMine sur OSX, c'est dans le menu Aide> Modifier les options de VM personnalisées.
Jon Schneider
8
Cela ne répond pas à la question. La question est de savoir à quoi ils servent, pas comment les définir.
Captain Man
@Hearen Comment se séparer dans intellij ??
3

-Xms taille de segment de mémoire initiale pour le démarrage, cependant, pendant le processus de travail, la taille de segment de mémoire peut être inférieure à -Xms en raison de l'inactivité des utilisateurs ou des itérations du GC. Il ne s'agit pas d'une taille de segment minimale requise.

-Xmx taille maximale du tas

lazylead
la source