问题描述
最近使用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的问题吧&#