Quand Java déclenche-t-il gc
1. Stratégies de recyclage de mémoire et concepts communs
Les stratégies courantes de recyclage de la mémoire peuvent être comprises à partir des dimensions suivantes :
1 Série et parallèle
Série : un seul thread effectue un travail de recyclage de la mémoire. C'est très simple et ne nécessite pas de prendre en compte des problèmes tels que la synchronisation, mais cela prend beaucoup de temps et ne convient pas à plusieurs processeurs.
Parallèle : plusieurs threads effectuent un travail de recyclage simultanément. Convient à plusieurs processeurs et très efficace.
2 Concurrence et arrêter le monde
arrêter le monde : le thread d'application dans la JVM se bloquera et seul le thread de récupération de place travaille pour nettoyer les déchets . Simple, pas besoin de considérer des problèmes tels que le recyclage sale.
Concurrence : pendant que le garbage collection est en cours, l'application est également en cours d'exécution. Assurer le temps de réponse des applications. Il peut y avoir des situations où le recyclage n'est pas propre et nécessite un recyclage secondaire.
3 &copie compressée et non compressée
Compression : après la collecte des ordures, les objets survivants seront glissés dans un espace continu pour nettoyer les fragments et garantir que l'espace restant est contigu.
Non compressé : conservez les fragments et ne compressez pas.
copie : déplacez les objets survivants vers le nouvel espace et libérez tout l'ancien espace. (Nécessite une mémoire plus grande.)
Un algorithme de garbage collection peut être envisagé et conçu à partir des dimensions ci-dessus, et finalement produire un garbage collector avec différentes caractéristiques adaptées à différents scénarios.
2. YGC&FGC de JVM
YGC : GC le tas nouvelle génération. La fréquence est relativement élevée car la plupart des objets ont une durée de vie courte et sont recyclés dans la nouvelle génération. Le coût de performance est faible.
FGC : GC complet à l’échelle du tas. FGC est déclenché lorsque l'utilisation de l'espace du tas par défaut atteint 80 % (réglable). En prenant notre environnement de production comme exemple, FGC est généralement déclenché rarement, parfois une fois tous les 10 jours ou environ une semaine.
3. Quand YGC sera-t-il déclenché et quand FGC sera-t-il déclenché ?
● Moment de YGC :
Espace edn insuffisant
● Synchronisation de FGC :
1. Ancien espace insuffisant
2. Espace permanent insuffisant ;
3. , etc. Déclencheur de synchronisation ;
4. Stratégie pessimiste pendant YGC ;
5. Vider les informations de la mémoire en direct (jmap –dump:live).
Pour le timing de déclenchement de YGC, il est tout à fait évident qu'il n'y a pas suffisamment d'espace eden à ce moment-là, ygc sera définitivement déclenché
Pour le. le moment du déclenchement de FGC, l'ancien espace insuffisant, l'espace permanent insuffisant et l'appel de system.gc() sont relativement évidents. Dans ce cas, GC sera généralement déclenché.
La plus compliquée est la stratégie dite pessimiste. Le mécanisme qu'elle déclenche est qu'elle calcule d'abord la taille moyenne de la promotion précédente, c'est-à-dire de la nouvelle génération, en passant par ygc jusqu'au taille moyenne de la nouvelle génération, puis si l'espace restant dans l'ancienne génération est inférieur à la taille de la promotion, un FullGC sera déclenché. La stratégie envisagée par SDK est que dans une perspective à moyen et à long terme, la possibilité d'un espace de promotion insuffisant la prochaine fois est très élevée. Au lieu d'attendre jusque-là le fullGC, il est préférable de croire avec pessimisme que le FullGC sera définitivement déclenché la prochaine fois. et exécutez directement FullGC en premier. Et à partir du processus d'utilisation réel, il a également obtenu un effet relativement stable.
Site Web php chinois, un grand nombre de Tutoriels d'introduction à Java gratuits, bienvenue pour apprendre en ligne !
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!