一次排查Java项目内存泄漏的过程

博主通过ServerStatus监控发现服务内存持续增长,使用jmap和MAT工具进行分析。MAT指出WordDictionary中HashMap数量异常,原因是频繁创建JiebaSegmenter对象。修复方案是改为全局静态变量,避免频繁创建。提醒开发者熟悉代码并定期检查内存状况。
摘要由CSDN通过智能技术生成

发现问题

公司自己维护的服务三四个,有的服务还分多个节点,自己也有几个私人服务器,所以为了能实时知道各个服务器的情况,就使用ServerStatus做了个云探针,功能很简单,能实时的监控每个服务器的内存、cpu、硬盘、流量的使用情况,如下
实时监控图
虽然只有几个指标,但是已经能让我全面的掌握各服务的性能,再搭配chrome插件iChrome,每天打开浏览器就能第一时间看到监控界面,
iChrome.png
我始终相信一句话:

工欲善其事必先利其器

最近一段时间,我发现我的一个服务所在的两台服务器内存处于不停的增长状态,8g内存,直接超过65%,这让我很郁闷,为什么会酱紫,就在昨天,我在一个服务器上做测试(不是普通的测试,而是去验证某正逻辑在线上是否正确的测试),

要使用Arthas来排查Java项目内存泄漏问题,你可以按照以下步骤进行操作: 1. 下载和启动Arthas:你可以在Arthas的官方网站(https://arthas.aliyun.com/)上下载最新版本的Arthas,并按照前面提到的步骤启动Arthas。 2. 选择目标进程:输入`select <pid>`命令,其中`<pid>`是你想诊断的Java进程的进程ID。 3. 开启HeapDump:输入`heapdump`命令,Arthas将会生成一个Heap Dump文件,用于分析内存使用情况。 4. 分析Heap Dump文件:将Heap Dump文件下载到本地,并使用Java内存分析工具,如Eclipse Memory Analyzer(MAT)或VisualVM等,打开该文件进行分析。这些工具可以帮助你定位内存泄漏的原因和具体的对象引用关系。 5. 使用Arthas命令:在Arthas中,你可以使用`jmap`命令查看Java堆内存的使用情况,使用`jclassloader`命令查看类加载器信息,使用`dashboard`命令查看实时的性能指标等等。这些命令可以帮助你进一步分析内存泄漏问题。 6. 根据分析结果进行修复:根据内存分析工具和Arthas的结果,定位到可能引起内存泄漏的代码或对象,然后进行相应的修复,如释放资源、修正错误的引用等。 请注意,内存泄漏问题的排查并不是一项简单的任务,需要结合工具和分析技巧进行深入分析。同时,也建议在项目开发过程中注意内存使用和资源释放,以避免潜在的内存泄漏问题的产生。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值