分享一个实用脚本--一键定位服务器CPU占用100%问题

时间:2021-04-30 17:40:58 来源:宁晋电脑网 作者:网友

视频推荐

方法/步骤

概述

最近在github看到个挺实用的工具,用来定位CPU高的原因是很有用的,下面一起来看看吧~

github:https://github.com/oldratlee/useful-scripts

下面主要介绍show-busy-java-threads的一些用法,用于快速排查Java的CPU性能问题(top us值过高),自动查出运行的Java进程中消耗CPU多的线程,并打印出其线程栈,从而确定导致性能问题的方法调用。


传统定位方案

1、top oder by with P:1040 // 首先按进程负载排序找到 axLoad(pid)2、top -Hp 进程PID:1073 // 找到相关负载 线程PID3、printf “0x%x”线程PID: 0x431 // 将线程PID转换为 16进制,为后面查找 jstack 日志做准备4、jstack 进程PID | vim +/十六进制线程PID - // 例如:jstack 1040|vim +/0x431 -


一键定位方案

 source <(curl -fsSL https://raw.githubusercontent.com/oldratlee/useful-scripts/release-2.x/test-cases/self-installer.sh)


1、下载脚本

wget --no-check-certificate https://github.com/oldratlee/useful-scripts/archive/release-2.x.zipunzip release-2.x.zip

分享一个实用脚本--一键定位服务器CPU占用100%问题


2、运行脚本--show-busy-java-threads

 ./show-busy-java-threads

可以看到,一键直接定位异常代码行

分享一个实用脚本--一键定位服务器CPU占用100%问题


3、常用的几个命令

#从所有JAVA线程找出最消耗CPU的线程,默认5个

show-busy-java-threads.sh

show-busy-java-threads.sh -c <要显示的线程栈数>

show-busy-java-threads.sh -c <要显示的线程栈数> -p <指定的JAVA process>

show-busy-java-threads.sh -a <输出记录到文件>

show-busy-java-threads.sh -t <重复执行的次数> -i <重复执行的间隔秒数>


觉得有用的朋友多帮忙转发哦!后面会分享更多devops和DBA方面的内容,感兴趣的朋友可以关注下~

分享一个实用脚本--一键定位服务器CPU占用100%问题

本文地址:https://www.js83188.com/news-1-1805-0.html

版权声明:本网站一直无私为提供优秀知识类文章,对于不当转载或引用本网内容而引起的民事纷争、行政处理或其他损失,本网不承担责任。

猜你喜欢