解决系统性能问题:线程增加导致堆增加

本文描述了一个使用Spring Boot构建的监控系统因频繁线程活动导致内存溢出的问题。作者通过分析日志、使用jvisualvm和jconsole工具,发现PS Old Gen区域满载是内存溢出的原因,而线程持续增加是由于未正确关闭SCPClient和SSH连接。修复这个问题后,成功解决了系统性能问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题描述

最近使用Spring boot 架构了一套监控系统.由于是监控系统,所以对系统的调用频率会比较频繁。例如,系统要每隔30秒开启线程去访问远程主机获取所需要的信息。所以系统的开销还是比较大。就是因为开销大,所以要保证系统自身不能卡死,不然还怎么去监控其它的呢?但是事与愿违,这套监控系统刚开始跑个两三天是没有问题的,后来发现,重启系统后,运行一个小时多就卡死了。前端访问不到页面,控制台报错信息:java.lang.OutOfMemoryError: Java heap space。导致所有需要采集的应用也不能正常运行。因此,此问题已经很严重了,需要立即解决了。

问题假设

出现OutOfMemoryError只要加大java虚拟机的内存应该就可以了吧!但是试了,不行。那么是不是spring boot没有做GC的操作呀!上网查了好多资料,都说Spring boot1.x的版本没有GC功能,说需要换成Spring boot2.x的版本。但是我觉得这个不可信呀!一个好的框架,没有GC的功能,那还会闻名吗?不过我试了换版本,还是没有用。那问题应该出现在哪呢?心中不断发问:lad, show me a way, show me a sign.

问题分析

  • 作为为开发,我们遇到问题,首先会先看日志。通过日志,我发现确实有好多错误信息。比如,被监控的数据库没有被连接上, 访问远程主机失败 和下载某个文件到本地失败等等。可能最近被监控的对象有被别人动过吧!但是不管怎样,这些不可能导致最后报出的OutOfMemoryError的问题吧!(不过还是有可能。)
  • 看完了日志,那么没有找到解决办法。大概知道是内存溢出导致系统死了。那是什么导致内存溢出呢?光看代码是不行了,所以要借助其它的工具了。笔者用了两个工具来分析。
  1.  首先笔者用jdk/ bin/ jvisualvm.exe的这个工具。由于是远程机器,所以需要开启jmx协议(读者可以参考笔者的博客《使用jvm监控应用》)。然后,在【远程】添加jxm的监控信息
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值