美文网首页
tomcat 故障/假死排查思路(未完)

tomcat 故障/假死排查思路(未完)

作者: charlven | 来源:发表于2020-01-10 10:35 被阅读0次

    @[TOC]

    确定是问题类型(CPU型/内存型问题)

    1. 观察 tomcat 日志有无明显异常,如 OOM 报错则可以直接判断为内存型tomcat问题。
    2. 通过 top / df -h / ps / free 命令查看系统资源占用情况。

    问题分析

    CPU 型

    一般表现为:存在计算量大、复杂的算法 / 存在死循环代码

    1. 通过 top 命令查看占用 CPU 高的进程。 top -p <pid> 可以查出某个进程的资源占用情况。
    2. 通过 top 查看某个进程中的所有线程占用情况
      top -p <pid> H
      
    3. 通过 jstack 定位问题。

    内存型

    1. 通过日志直接定位
    2. 采集 OOM 数据:
      JvmOptions="-XX:+HeapDumpOnOutOfMemoryError"
      JvmOptions="-XX:HeapDumpPath=$(COREMAIL_HOME)/logs/tomcat-heapdump.bin"
      

    问题解决

    CPU 型

    1. 一般能够找到对应代码问题,优化代码。
    2. 提高硬件设备。

    内存型

    1. 找到代码的地方、优化。
    2. 寻找能够优化的配置,如 PermGen(不过 JAVA 8之后就废弃了持久代),增加 jvm 内存。
    3. 提高硬件设备

    相关文章

      网友评论

          本文标题:tomcat 故障/假死排查思路(未完)

          本文链接:https://www.haomeiwen.com/subject/gjjpactx.html