OOM问题排查+Jvm优化

OOM问题排查:

java 复制代码
1、top命令:查看cpu和内存的使用情况。
2、jstat命令:查看YGC和FGC情况,一般都是老年代不够用。导致OOM
3、jmap命令: 查看哪个类的实例过多,以每个类占用多少了内存。

4、jstack  查看线程与线程之间的阻塞状态。dump文件也是通过这个命令。这是参数不一样。

JVM调优的出发点:

java 复制代码
1、观察YGC的频率和耗时
频率过高:可能是E和S的容量不够,

2、观察FGC的频率和耗时
频率过高:说明老年代的对象得不到回收。
是不是有内存泄露:Gc后老年代没有变化
老年代的内存空间不够大:查看每次回收后老年代的空间变化。
老年代大对象的【担保策略】:担保策略就是指下面4个点。

备注:Java对象进入老年代的四种方式
1、minor gc之后,survivor区空间不能容量存活对象
2、对象达到年龄阈值进入老年代
3、大对象进入老年代
4、动态年龄判断

担保策略:4种分派方式跳转

一、什么是TLAB

java 复制代码
TLAB:用来解决内容分派的问题
1、指针碰撞,一半是已分派,一半是未分派,缺点:产生很多碎片。产生很多不连续的空闲空间。
2、空闲列表机制:在碰撞的基础上,将不连续的空间,通过一个空间列表记录起来。每次分派对象时,优先遍历空闲列表,来
分配合适的对象。
3、高并发下,需要用到互斥锁,这就大大折扣了,空闲列表的分派速度。为了解决内容分配效率问题,引入了TLAB的概念
4、TLAB是Thread Local Allocate buffer的缩写,结合EMA期望算法,

TLAB 是线程私有的,线程初始化的时候,会创建并初始化 TLAB

缺点:TLAB 要解决的问题很明显,尽量避免从堆上直接分配内存从而避免频繁的锁争用。引入 TLAB 后,会有内
存孔隙问题,还可能影响 GC 扫描性能
总结:开发中能使用局部变量的,就不要使用在方法外定义。
相关推荐
阿维的博客日记35 分钟前
Bean 会被 JVM 回收吗?
jvm·spring
liann1192 小时前
Agent 内存马禁止 Attach JVM
java·jvm·安全·网络安全·系统安全·网络攻击模型·信息与通信
代码漫谈2 小时前
JVM 参数调优:Spring Boot与JDK新特性的最佳结合
java·jvm·spring boot
2401_898717662 小时前
HTML5中SVG原生动画标签Animate的基础用法
jvm·数据库·python
2401_867623982 小时前
mysql如何导出特定条件的查询数据_使用mysqldump加where参数
jvm·数据库·python
likerhood2 小时前
认识 JVM:Java 程序背后的那台“隐形计算机”
java·开发语言·jvm
YOU OU3 小时前
JVM基础知识
开发语言·jvm
冷小鱼3 小时前
JVM 深度调优实战:从 JDK 8 到 JDK 21 的演进与中间件落地
java·jvm·中间件
AI人工智能+电脑小能手3 小时前
【大白话说Java面试题 第41题】【JVM篇】第1题:JVM由哪些部分组成?
java·开发语言·jvm·后端·面试
dfdfadffa12 小时前
如何用模块化方案组织一个可扩展的前端组件库项目
jvm·数据库·python