Java JVM Old GC prend des dizaines de s, ce qui provoque une alarme système

Qingxiang Java 2021-11-25 17:38:37
java jvm old gc prend

Questions

Alarme environnementale de production,Délai d'interface.

Raisons

old gcÇa prend des dizaines des,Le système est instantanément bloqué,Puis les interfaces ont été décalées.


Une autre application prend aussi du tempss,Le système est instantanément bloqué,Et beaucoup d'alarmes.

Pas à chaque foisold gcIls vont tous se coincer.,Mais une fois de temps en tempsold gcÇa prendra du temps,La plupart du temps normal.

Causes profondes

Pourquoiold gcÇa prend tellement de temps?La raison en est qu'un noeud a été connectéskywalking,Et ensuite ajustéjvmConfiguration,Plus précisément::Proportion de jeunes et de personnes âgées,Par défaut2.Maintenant, oui.4,Double la taille de l'ancienne mémoire——Ce qui a conduit à l'âgegcLe seuil est plus élevé,C'est pour ça quegcUne fois.,Mais il est possible qu'une seule fois prenne trop de temps.


Noeud normalold gcC'est comme ça.

Noeud normal et noeud anormaljvmConfiguration

Noeud d'exception

 $ jinfo -flags 11597

Attaching to process ID 11597, please wait...

Debugger attached successfully.

Server compiler detected.

JVM version is 25.161-b12

Non-default VM flags: 

-XX:CICompilerCount=4 -XX:InitialHeapSize=3221225472 -XX:MaxHeapSize=3221225472 

-XX:MaxMetaspaceSize=524288000 

-XX:MaxNewSize=643825664 

-XX:MetaspaceSize=314572800 

-XX:MinHeapDeltaBytes=524288 -XX:NewRatio=4 -XX:NewSize=643825664 -XX:OldSize=2577399808 -XX:ThreadStackSize=512 -XX:+UseCompressedClassPointers -XX:+UseCompressedOops 

-XX:+UseParallelGC  //Par défaut:Débit prioritaire-Cénozoïque + Multithreading-Vieux temps

Command line:  -javaagent:/home/xxx/private-cloud/agent/skywalking-agent.jar -Dskywalking.agent.service_name=trade-base -Dskywalking.agent.instance_uuid=xxx -Ddubbo.application.name=xxx-base -Ddubbo.application.version=green-1 

-Xmx3072m -Xms3072m 

-XX:NewRatio=4  // Le rapport entre le nouveau et l'ancien ,Par défaut2.Maintenant, oui.4,Double la taille de l'ancienne mémoire——Ce qui a conduit à l'âgegcLe seuil est plus élevé,C'est pour ça quegcUne fois.,Mais il est possible qu'une seule fois prenne trop de temps.

-Xss512k 

-XX:MetaspaceSize=300m 

-XX:MaxMetaspaceSize=500m

Note:: Parce que c'est connecté skywalking,Et configuréjvmParamètres,Alors...jvm Les paramètres ne sont pas les mêmes que les noeuds normaux , C'est la raison pour laquelle .

Pourquoi la nouvelle configuration pose problème ?Parce que: Le rapport entre le nouveau et l'ancien ,Par défaut2.Maintenant, oui.4,Double la taille de l'ancienne mémoire——Ce qui a conduit à l'âgegcLe seuil est plus élevé,C'est pour ça quegcUne fois.,Mais il est possible qu'une seule fois prenne trop de temps.

Notez que c'est juste connecté skywalking,Et parce queskywalkingUtilisation des ressources,Alors...jvm Mémoire augmentée , Mais l'ancien et le nouveau ratio ne devraient pas être augmentés .

Noeud normal

$ jinfo -flags 53022

Attaching to process ID 53022, please wait...

Debugger attached successfully.

Server compiler detected.

JVM version is 25.161-b12

Non-default VM flags: 

-XX:CICompilerCount=3 

-XX:InitialHeapSize=127926272 

-XX:MaxHeapSize=2046820352 -XX:MaxNewSize=682098688 

-XX:MinHeapDeltaBytes=524288 -XX:NewSize=42467328 -XX:OldSize=85458944 

-XX:+UseCompressedClassPointers -XX:+UseCompressedOops -XX:+UseFastUnorderedTimeStamps 

-XX:+UseParallelGC // Collecteur d'ordures par défaut

Command line:  -Ddubbo.application.name=xxx-base -Ddubbo.application.version=green-1

Solutions

Retour en arrièrejvmConfiguration, C'est - à - dire que le noeud en question Jvm La configuration a été changée pour ressembler au noeud normal .

Noeud normaljvm Est d'utiliser la configuration par défaut ,C'est - à - dire qu'il n'y a pas de configurationjvmParamètres.

Cet article est basé sur la plateforme Multi - blog OpenWrite Publication!
版权声明
本文为[Qingxiang Java]所创,转载请带上原文链接,感谢
https://javamana.com/2021/11/20211125173709238y.html

  1. http://lx.gongxuanwang.com/sszt/32.htm
  2. 回顾我两个月面试阿里,携程,小红书,美团,网易等等(Java岗)
  3. JavaScript高级程序设计读后感(一)之零碎知识点查漏补缺
  4. http://lx.gongxuanwang.com/sszt/7.htm
  5. #yyds干货盘点#设计模式之【工厂模式】
  6. Java * SpringBoot实现万能文件在线预览,已开源,真香
  7. Redis | 第4章 Redis中的数据库《Redis设计与实现》
  8. Redis | 第4章 Redis中的数据库《Redis设计与实现》
  9. 关于centos docker版本过低导致 is not a valid repository/tag: invalid reference format
  10. Redis 源码简洁剖析 02 - SDS 字符串
  11. 回顧我兩個月面試阿裏,攜程,小紅書,美團,網易等等(Java崗)
  12. Rétrospectivement, j'ai passé deux mois à interviewer Ali, ctrip, Little Red Book, meituan, NetEase, etc. (Java post)
  13. Docker + webhook Automation Deployment Front End Project
  14. Java技术之Spring、Hibernate框架整合方法
  15. http://lx.gongxuanwang.com/sszt/32.htm
  16. 亚马逊自己的 Linux 发行版现在完全基于 Fedora 了
  17. Redis 源码简洁剖析 02 - SDS 字符串
  18. Java技術之Spring、Hibernate框架整合方法
  19. Méthode d'intégration des cadres de printemps et d'hibernation de la technologie Java
  20. Redis source Concise Analysis 02 - SDS String
  21. La distribution Linux d'Amazon est maintenant entièrement basée sur Fedora
  22. org.springframework.web.bind.MissingServletRequestParameterException
  23. Built in constraints and functions of MySQL Foundation (2)
  24. Basic operation of MySQL Foundation (I)
  25. Introduction to Java zero foundation 3: Java data types
  26. 从零开始搭建EasyDarwin环境——Linux系统开发环境搭建Golang
  27. Redis source Concise Analysis 02 - SDS String
  28. Construire l'environnement easydarwin à partir de zéro - - construire l'environnement de développement du système Linux golang
  29. javaweb代码是正确的,但是第一行代码就报错了
  30. **** | Java | 后端开挂:3行代码写出8个接口
  31. Java || 看了大二学长写的代码,我竟开始默默的模仿了。。。
  32. Java | 手把手教你实现一个抽奖系统(Java版)
  33. Java | Manuel pour vous apprendre à mettre en œuvre un système de loterie (version Java)
  34. Java | | après avoir lu le Code que j'ai écrit en deuxième année, j'ai commencé à imiter silencieusement...
  35. Java | back - end Pending: 3 - line Code write 8 Interfaces
  36. Le Code Web Java est correct, mais la première ligne de code est incorrecte
  37. Android网络编程之Http通信
  38. Android網絡編程之Http通信
  39. Http communication for Android Network Programming
  40. 数据结构实验八 领会图的两种主要储存结构和图的基本运算算法设计
  41. Hibernate数据校验简介
  42. The story of spring
  43. Il a dépensé 270 000 yuans pour soulever Xiaopeng p7 et a parcouru 3 627 km. Le propriétaire du véhicule a partagé 6 avantages et inconvénients.
  44. 阿里蚂蚁花呗团队面试题:spring+分布式+jvm+session+redis
  45. 【Java入门100例】14.字符串排序——compareTo()
  46. 【Java入门100例】13.修改文件扩展名——字符串替换
  47. Leetcode 79. Word Search [C + + / java detailed problem]
  48. Introduction à la vérification des données hibernantes
  49. Expérience de la structure des données
  50. Spring cloud gateway practice 2: more routing configuration methods
  51. Java network programming - summary overview
  52. 基于语法树的 Java 代码自动化插桩
  53. 云原生 Spring Boot 应用配置 Prometheus + Grafana 监控(保姆级)
  54. Spring cloud gateway practice 2: more routing configuration methods
  55. Jenkins file one line of code to deploy. Net program to k8s
  56. Java network programming - summary overview
  57. Cloud Native Spring Boot application configuration Prometheus + grafana Monitoring (baby - sitter)
  58. Insertion automatique de code Java basée sur l'Arbre syntaxique
  59. Le SUV phare de Xiaopeng, Xiaopeng G9, a fait ses débuts au salon de l'automobile et s'est tenu en position C dans la nouvelle force?
  60. Docker 从入门到实践系列四 - Docker 容器编排利器 Docker Compose