天道酬勤,学无止境

java运维

JAVA应用运维,线上故障排查全套路

原文链接:https://fredal.xin/java-error-check线上故障主要会包括cpu、磁盘、内存以及网络问题,而大多数故障可能会包含不止一个层面的问题,所以进行排查时候尽量四个方面依次排查一遍。同时例如jstack、jmap等工具也是不囿于一个方面的问题的,基本上出问题就是df、free、top 三连,然后依次jstack、jmap伺候,具体问题具体分析即可。CPU一般来讲我们首先会排查cpu方面的问题。cpu异常往往还是比较好定位的。原因包括业务逻辑问题(死循环)、频繁gc以及上下文切换过多。而最常见的往往是业务逻辑(或者框架逻辑)导致的,可以使用jstack来分析对应的堆栈情况。使用jstack分析cpu问题我们先用ps命令找到对应进程的pid(如果你有好几个目标进程,可以先用top看一下哪个占用比较高)。接着用top -H -p pid来找到cpu使用率比较高的一些线程然后将占用最高的pid转换为16进制printf '%x\n' pid得到nid接着直接在jstack中找到相应的堆栈信息jstack pid |grep 'nid' -C5 –color可以看到我们已经找到了nid为0x42的堆栈信息,接着只要仔细分析一番即可。当然更常见的是我们对整个jstack文件进行分析,通常我们会比较关注WAITING和TIMED_WAITING的部分

2021-05-12 17:33:55    分类:博客    java运维   linux