JVM内存管理<一>:Java内存异常问题排查

一、 内存溢出问题的排查

1. 使用工具 - jdk自带

  • jmap
  • visualvm

2. 流程

  1. 堆转储:
    (1) 方法一:程序运行时,采用:jmap -dump:format=b,file=d:\\data\\xxlJob.hprof 23300 进行堆文件的转储
    (2) 方法二:在内存溢出的时候,打印堆转储文件
java 复制代码
-XX:+HeapDumpOnOutOfMemoryError           # 开启OOM时自动转储堆
-XX:HeapDumpPath=/path/to/dump/dir/       # 指定堆转储文件路径
-XX:OnOutOfMemoryError="command args"     # OOM时执行外部命令
  1. 导入visualVM中
    文件->装入->选择堆转储文件
  1. 分析:自定义的对象的数量、大小都不应该太大
    a. 通过大小、对象数量进行排序,查看靠前的对象是否存在自定义的对象
    b. 通过名称排序,查看自定义的对象中,哪个对象最靠前

二、gc频繁问题的排查

1. 了解堆分配的策略

a. 优先分配到年轻代

b. 大对象直接分配到老年代

c. 长期存活的对象进入老年代

d. 对象担保策略:如果年轻代的对象的总容量大于了老年代的剩余容量,需要进行一次full gc

2. 频繁minor gc

原因

(1) 内存分配过小

(2) 内存泄漏

(3) 频繁的对象创建
排查和解决方案

(1)经过mimor gc之后,对象仍旧无法被清除,导致full gc:考虑内存泄漏问题,查看是否存在内存泄漏,可以通过jmap + visualvm进行排查

(2) 如果是并发高的场景:minor gc之后,考虑eden分配过小,尝试增大内存的分配量,尤其是eden区的

(3) 如果不是高并发,内存还有急速升高的情况,可能是对象创建太过频繁,或者创建了大对象导致的

总结:分配大内存 + 排查堆转储文件,查看哪个自定义对象的占用内存较大,优化代码

3. 频繁full gc

原因

(1)minor gc分配太小,导致频繁minor gc,进而对象年龄急速增加,进入老年代

(2)full gc 分配太小,空间担保机制,使得minor gc之前,需要进行full gc

(3)内存泄漏或者大对象的创建
解决方案:

(1)首先尝试分配大内存

(2)如果不行,通过排查堆转储文件,也就是使用jmap和visualvm查看较大的自定义对象

相关推荐
轻抚酸~3 小时前
小迪23年-32~40——java简单回顾
java·web安全
Sirius Wu5 小时前
Maven环境如何正确配置
java·maven
七七&5565 小时前
2024年08月13日 Go生态洞察:Go 1.23 发布与全面深度解读
开发语言·网络·golang
java坤坤5 小时前
GoLand 项目从 0 到 1:第八天 ——GORM 命名策略陷阱与 Go 项目启动慢问题攻坚
开发语言·后端·golang
元清加油5 小时前
【Golang】:函数和包
服务器·开发语言·网络·后端·网络协议·golang
健康平安的活着6 小时前
java之 junit4单元测试Mockito的使用
java·开发语言·单元测试
Java小白程序员6 小时前
Spring Framework :IoC 容器的原理与实践
java·后端·spring
xuTao6677 小时前
Easy Rules 规则引擎详解
java·easy rules
DjangoJason7 小时前
C++ 仿RabbitMQ实现消息队列项目
开发语言·c++·rabbitmq
m0_480502648 小时前
Rust 入门 KV存储HashMap (十七)
java·开发语言·rust