专业的JAVA编程教程与资源

网站首页 > java教程 正文

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

temp10 2024-11-13 12:44:37 java教程 12 ℃ 0 评论

概述

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

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

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

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


传统定位方案

1、top oder by with P:1040 // 首先按进程负载排序找到  axLoad(pid)
2、top -Hp 进程PID:1073    // 找到相关负载 线程PID
3、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.zip
unzip release-2.x.zip



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

 ./show-busy-java-threads 

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



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方面的内容,感兴趣的朋友可以关注下~

Tags:

本文暂时没有评论,来添加一个吧(●'◡'●)

欢迎 发表评论:

最近发表
标签列表