你的应用突然出现了OOM异常,你会如何排查?

调优不是一蹴而就的,需要分析、推理、实践、总结、再分析,最终定位到县体的问题

  1. 可以使用jmap来查看IVM中各个区域的使用情况
  2. 可以通过jstack来查看线程的运行情况,比如哪些线程阻塞、是否出现了死锁
  3. 可以通过jstat命令来查看垃圾回收的情况,特别是fullgc,如果发现fullgc比较频繁,那么就得进行调优
  4. 通过各个命令的结果,或者ivisualvm等工具来进行分析
  5. 首先,初步猜测频繁发送fulgc的原因,如果频繁发生fullgc但是又一直没有出现内存溢出,那么表示fulgc实际上是回收了很多对象了,所以这些对象最好能在younggc过程中就直接回收掉,避免这些对象进入到老年代,对于这种情况,就要考虑这些存活时间不长的对象是不是比较大,导致年轻代放不下,直接进入到了老年代,尝试加大年轻代的大小,如果改完之后,fulgc减少,则证明修改有效
  6. 同时,还可以找到占用CPU最多的线程,定位到具体的方法,优化这个方法的执行,看是否能避免某些对象的创建,从而节省内存

对于已经发生了OOM的系统:

1.一般生产系统中都会设置当系统发生了OOM时,生成当时的dump文件(-XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/usr/local/base)

2.我们可以利用jsisualvm等工具来分析dump文件

3.根据dump文件找到异常的实例对象,和异常的线程(占用CPU高),定位到具体的代码

4,然后再进行详细的分析和调试

#机械人面试中的常问题##面试时最害怕被问到的问题#
职保镖-扶你上马 文章被收录于专栏

知识分享,交天下朋友,扶你上马,送你一层,职业规划,面试指导、高薪谈判、背调辅助

全部评论
mark
点赞 回复 分享
发布于 02-27 15:49 广西

相关推荐

04-01 21:44
已编辑
同济大学 C++
1.自我介绍2.你简历上有写容器,详细解释一下容器怎么实现隔离的?内部网络是怎么定义的?容器间怎么通信的?越详细越好(这个下去有认真看,回答namespace和c组机制,详细讲了这两种机制还有容器内部的一些依赖相关的问题)3.一个容器向另一个容器之间发送数据,这个数据会到内核么?响应过程是怎么样的?(这个问题不是很了解,回答是从sel4微内核架构、容器运行时、容器的bridge模式去考虑的)4.给你一个数据帧,这个数据帧是怎么一层层解析成应用的?、(理解成网络的MAC帧了,回答了一下网络的七层模型还有涉及到的一些协议,面试官提醒之后换了一种方式,但是感觉这个答得一般)5.了解I/O多路复用么?(还说了其他的一些名词没太听懂)答:不太了解这方面的6.C++多态了解么?里面的virtual有什么作用7.C++智能指针unique_ptr、shared_ptr8.后续的职业生涯规划怎样的9.反问环节1)面试结果多久出?答:很快2)对我今天的面试表现有什么建议呢?请尖锐一点答:可以看出你对容器的了解还是非常深入的,但是对于网络模型,比如数据包到达网卡之后怎么解析的了解不太深入,后续需要对知识的广度和深度进行挖掘。3)如果通过这次面试了后面还有几面呢?答:还有一次HR面————————总体感受就是,问得非常深入,会涉及非常底层的一些实现,感觉确实有一些不足。面试官提问的时候也会去进行一些引导,可惜有些问题确实不太了解腾子收留我吧求求了!!!————————wc!!!!刚随便看了一下,复试秒过!!!收留我吧鹅厂!!求求了!!!
腾讯二面852人在聊 查看11道真题和解析
点赞 评论 收藏
分享
评论
1
21
分享

创作者周榜

更多
牛客网
牛客企业服务