当前位置: 首页 > news >正文

系统发生GC内存溢出、频繁 Full GC、JVM报错

项目背景:

        服务器上主要两个系统,一个大屏的一个小系统,大屏查的那个数据库数据量很多,然后上周五客户那边说有点卡顿,我进服务器一看cpu干到98了,然后看日志报错GC内存不足了,但是当时我没看小系统的情况,然后刚刚客户说那个小系统登不上了,我进去看也是GC内存不足了,当时进系统看的时候内存的占用率其实并不高

查看两边系统的报错日志

小系统:分配的起始内存以及最大堆内存均为2048MB,在启用小系统之后任务管理器占用的内存为2357.9MB,报错时间在大系统之前并且提示堆内存不够用了

大系统:分配的起始内存以及最大堆内存均为10240MB,在启用小系统之后任务管理器占用的内存为8975.9MB

利用JDK工具查看实时的内存占用空间比

先找到服务对应的PID,然后使用jstat查看对应服务的内存分配

小系统,

  • 堆内存总共分配了大约2048 MB,比较符合JVM参数。

  • 当前实际使用约1282 MB,占用了分配的堆内存的62.5%左右。

大系统

  • Survivor + Eden + Old 区容量总和(即总堆容量):

    • 7168 + 8192 + 3478528 + 6990848 = 10419436 KB ≈ 10177 MB

    • 这与你设置的 -Xmx10240m 非常接近,说明最大堆设置已经被 JVM 识别并应用。

  • 实际使用的堆内存:

    • 7118 + 0 + 1898067.2 + 5221045.9 = 7121231.1 KB ≈ 6955 MB

    • 当前使用了 约 6.9GB 的堆内存,占比约 68%

  • Survivor + Eden + Old 区容量总和(即总堆容量):

    • 7168 + 8192 + 3478528 + 6990848 = 10419436 KB ≈ 10177 MB

    • 这与你设置的 -Xmx10240m 非常接近,说明最大堆设置已经被 JVM 识别并应用。

  • 实际使用的堆内存:

    • 7118 + 0 + 1898067.2 + 5221045.9 = 7121231.1 KB ≈ 6955 MB

    • 当前使用了 约 6.9GB 的堆内存,占比约 68%

总结:JVM 花了 过多时间(>98%)进行垃圾回收(GC),但回收了不到2%的堆内存。通常表示内存已经非常紧张,甚至快耗尽了,但是查看小系统的mapper层的时候发现数据量并不高,感觉小系统造成内存溢出的可能性并不是很大,应该是大系统占用内存过多影响到了小系统

相关文章:

  • Set系列集合
  • 解锁 MCP 中的 JSON-RPC:跨平台通信的奥秘
  • SymPy | 其他未知数表示方程中的某一未知数
  • JavaSE核心知识点04工具04-01(JDK21)
  • [特殊字符] useTranslations 客户端使用教程(Next.js + next-intl)
  • vue3+vite项目中使用Tailwind CSS
  • 深浅拷贝?
  • day 37
  • SWOT 模型:基础框架的应用价值与改进路径
  • day 22 练习——泰坦尼克号幸存者预测
  • Spring boot基础
  • JAVA基础编程练习题--50道
  • 东北某汽车集团云建设:如何用监控易护航云平台系统?
  • C语言初阶--结构体
  • win11+vs2022 安装opencv 4.11.0图解教程
  • ULVAC VWR-400M/ERH 真空蒸发器 Compact Vacuum Evaporator DEPOX (VWR-400M/ERH)
  • 推理模型 vs 非推理模型:核心区别及优劣势解析
  • sd webui 安装sd-webui-TemporalKit 加载报错解决办法
  • 联邦学习与数据隐私保护之间的联系
  • 每日算法-250526
  • 手机网站移动应用/seo赚钱吗
  • wordpress官方的三个主题好排名/福州关键词排名优化
  • 做商城网站需要准备那些/国家免费技能培训有哪些
  • 国内网站设计案例欣赏/深圳抖音seo
  • 嘉鱼网站建设公司/html网页制作用什么软件
  • 杭州网站建设icp备/百度认证服务平台