Linux里面cpu占用太高排查思路是啥?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Linux里面cpu占用太高排查思路是啥?相关的知识,希望对你有一定的参考价值。

思路就是top查看是什么进程占用高,一般是应用或者数据库,应用方面可以看看运行吐出日志是否有报错信息,查netstat连接应用端口的会话是不是有异常,数据库进程高,可以使用自带的检查命令后台看是否有执行很久的sql事务,锁等待频繁,报错日志等,找到问题针对性的优化,一步一步解决。 参考技术A 方法一

第一步:使用
top命令,然后按shift+p按照CPU排序

找到占用CPU过高的进程的pid
第二步:使用
top -H -p [进程id]

找到进程中消耗资源最高的线程的id
第三步:使用
echo 'obase=16;[线程id]' | bc或者printf "%x\n" [线程id]

将线程id转换为16进制(字母要小写)
bc是linux的计算器命令
第四步:执行
jstack [进程id] |grep -A 10 [线程id的16进制]”

查看线程状态信息
方法二

第一步:使用
top命令,然后按shift+p按照CPU排序

找到占用CPU过高的进程
第二步:使用
ps -mp pid -o THREAD,tid,time | sort -rn

获取线程信息,并找到占用CPU高的线程
第三步:使用
echo 'obase=16;[线程id]' | bc或者printf "%x\n" [线程id]

将需要的线程ID转换为16进制格式
第四步:使用
jstack pid |grep tid -A 30 [线程id的16进制]

打印线程的堆栈信息
参考技术B 可以通过top命令来查看占用cpu的软件看是否有僵尸进程在占用cpu如果可以通过kill杀死无用的进程!

排查linux下java应用cpu占用过高

用于快速排查JavaCPU性能问题(top us值过高),自动查出运行的Java进程中消耗CPU多的线程,并打印出其线程栈,从而确定导致性能问题的方法调用。
目前只支持Linux。原因是MacWindowsps命令不支持列出进程的线程id,更多信息参见#33,欢迎提供解法。

PS,如何操作可以参见@bluedavy《分布式Java应用》的【5.1.1 CPU消耗分析】一节,说得很详细:

  1. top命令找出消耗CPU高的Java进程及其线程id
    1. 开启线程显示模式(top -H,或是打开top后按H
    2. CPU使用率排序(top缺省是按CPU使用降序,已经合要求;打开top后按P可以显式指定按CPU使用降序)
    3. 记下Java进程id及其CPU高的线程id
  2. 查看消耗CPU高的线程栈:
    1. 用进程id作为参数,jstack出有问题的Java进程
    2. 手动转换线程id成十六进制(可以用printf %x 1234
    3. jstack输出中查找十六进制的线程id(可以用vim的查找功能/0x1234,或是grep 0x1234 -A 20
  3. 查看对应的线程栈,分析问题

查问题时,会要多次上面的操作以分析确定问题,这个过程太繁琐太慢了。

 

 

转自:https://github.com/oldratlee/useful-scripts/blob/master/docs/java.md#-show-busy-java-threads

以上是关于Linux里面cpu占用太高排查思路是啥?的主要内容,如果未能解决你的问题,请参考以下文章

SQLSERVER排查CPU占用高的情况

linux服务器中毒排查过程

Linux系统中负载较高&磁盘I/O %util特别高问题排查思路与解决方法(学完Linux问题基本都可以解决)

linux cpu占用100%排查

Linux排查Java程序占用CPU很高的解决办法

排查linux下java应用cpu占用过高