OutOfMemory内存溢出问题排查

2023-10-22 21:59

本文主要是介绍OutOfMemory内存溢出问题排查,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

OutOfMemory内存溢出问题排查

错误

2022-12-06 00:43:53.296[,] [registrationTask1] ERROR
o.s.s.support.TaskUtils$LoggingErrorHandler.handleError@96 -
Unexpected error occurred in scheduled task.
java.lang.OutOfMemoryError: Java heap space 2022-12-06 00:42:49.129[,]
[redisson-netty-4-39] WARN
io.netty.resolver.dns.DnsNameResolver.channelRead@1210 - [id:
0xca8e828a, L:/0:0:0:0:0:0:0:0:38476] Received a DNS response with an
unknown ID: 9619 xxl-job, JobThread-43-1670256900014

当出现OOM的时候运维首先重启了服务,然后将heapdump-8050.hprof的dump日志文件导出,这里导出需要在jvm启动参数添加如下参数:

-XX:-HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/mnt/TXG/quartz/heapdump-8050.hprof

排查思路

  1. 下载MAT工具进行分析,链接:添加链接描述

  2. 导入hprof日志在这里插入图片描述

  3. 点击柱状图查看对象引用关系在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    从上面可以看出usersInfo的对象特别多,所以问题的原因应该就算usersInfo对象加载过多导致,usersInfo没有出现被引用的对象,那么凭借经验应该是一次性加载这个对象的时候过多导致;

  4. 查看线程定位具体溢出代码在这里插入图片描述
    点击齿轮表示线程,再点击Total:25 of 54 entries;29 more(总计:54个条目中的25个;29更多),点击更多展开查看是否存在业务代码标识;
    在这里插入图片描述
    根据上图可以得到代码问题:com.ytjj.quartz.task.ProductTask(400行)
    在这里插入图片描述
    在这里插入图片描述
    这里得出查询未做分页处理,根据sql日志这个时刻数据查询出了4百多万条数据,导致内存溢出,问题解决;

这篇关于OutOfMemory内存溢出问题排查的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/263853

相关文章

Go使用pprof进行CPU,内存和阻塞情况分析

《Go使用pprof进行CPU,内存和阻塞情况分析》Go语言提供了强大的pprof工具,用于分析CPU、内存、Goroutine阻塞等性能问题,帮助开发者优化程序,提高运行效率,下面我们就来深入了解下... 目录1. pprof 介绍2. 快速上手:启用 pprof3. CPU Profiling:分析 C

springboot3.4和mybatis plus的版本问题的解决

《springboot3.4和mybatisplus的版本问题的解决》本文主要介绍了springboot3.4和mybatisplus的版本问题的解决,主要由于SpringBoot3.4与MyBat... 报错1:spring-boot-starter/3.4.0/spring-boot-starter-

在 Spring Boot 中使用异步线程时的 HttpServletRequest 复用问题记录

《在SpringBoot中使用异步线程时的HttpServletRequest复用问题记录》文章讨论了在SpringBoot中使用异步线程时,由于HttpServletRequest复用导致... 目录一、问题描述:异步线程操作导致请求复用时 Cookie 解析失败1. 场景背景2. 问题根源二、问题详细分

解读为什么@Autowired在属性上被警告,在setter方法上不被警告问题

《解读为什么@Autowired在属性上被警告,在setter方法上不被警告问题》在Spring开发中,@Autowired注解常用于实现依赖注入,它可以应用于类的属性、构造器或setter方法上,然... 目录1. 为什么 @Autowired 在属性上被警告?1.1 隐式依赖注入1.2 IDE 的警告:

解决java.lang.NullPointerException问题(空指针异常)

《解决java.lang.NullPointerException问题(空指针异常)》本文详细介绍了Java中的NullPointerException异常及其常见原因,包括对象引用为null、数组元... 目录Java.lang.NullPointerException(空指针异常)NullPointer

Android开发中gradle下载缓慢的问题级解决方法

《Android开发中gradle下载缓慢的问题级解决方法》本文介绍了解决Android开发中Gradle下载缓慢问题的几种方法,本文给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、网络环境优化二、Gradle版本与配置优化三、其他优化措施针对android开发中Gradle下载缓慢的问

关于Nginx跨域问题及解决方案(CORS)

《关于Nginx跨域问题及解决方案(CORS)》文章主要介绍了跨域资源共享(CORS)机制及其在现代Web开发中的重要性,通过Nginx,可以简单地解决跨域问题,适合新手学习和应用,文章详细讲解了CO... 目录一、概述二、什么是 CORS?三、常见的跨域场景四、Nginx 如何解决 CORS 问题?五、基

MySQL安装时initializing database失败的问题解决

《MySQL安装时initializingdatabase失败的问题解决》本文主要介绍了MySQL安装时initializingdatabase失败的问题解决,文中通过图文介绍的非常详细,对大家的学... 目录问题页面:解决方法:问题页面:解决方法:1.勾选红框中的选项:2.将下图红框中全部改为英

Nginx启动失败:端口80被占用问题的解决方案

《Nginx启动失败:端口80被占用问题的解决方案》在Linux服务器上部署Nginx时,可能会遇到Nginx启动失败的情况,尤其是错误提示bind()to0.0.0.0:80failed,这种问题通... 目录引言问题描述问题分析解决方案1. 检查占用端口 80 的进程使用 netstat 命令使用 ss

mybatis和mybatis-plus设置值为null不起作用问题及解决

《mybatis和mybatis-plus设置值为null不起作用问题及解决》Mybatis-Plus的FieldStrategy主要用于控制新增、更新和查询时对空值的处理策略,通过配置不同的策略类型... 目录MyBATis-plusFieldStrategy作用FieldStrategy类型每种策略的作