如何排查jvm问题的方法

2023年 12月 11日 26.7k 0

对于还在正常运行的系统:

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

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

  • 一般生产系统中都会设置当系统发生了OOM时,生成当时的dump文件(-XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/usr/local/base)
  • 我们可以利用jsisualvm等工具来分析dump文件
  • 根据dump文件找到异常的实例对象,和异常的线程(占用CPU高),定位到具体的代码
  • 然后再进行详细的分析和调试
  • 总之,调优不是一蹴而就的,需要分析、推理、实践、总结、再分析,最终定位到具体的问题

    相关文章

    JavaScript2024新功能:Object.groupBy、正则表达式v标志
    PHP trim 函数对多字节字符的使用和限制
    新函数 json_validate() 、randomizer 类扩展…20 个PHP 8.3 新特性全面解析
    使用HTMX为WordPress增效:如何在不使用复杂框架的情况下增强平台功能
    为React 19做准备:WordPress 6.6用户指南
    如何删除WordPress中的所有评论

    发布评论