排查一次CPU100%的情况

1:查找cpu 使用情况   top -c

2:查看具体进程的 线程使用cpu情况  top -Hp 18884

3:watch pstack 18890   或者  pstack 18890 > a.txt

由于ubuntu 中的pstack 命令有问题 网上找了代码 另存为 mypstack 

  1 #!/bin/sh
  2 
  3 if test $# -ne 1; then
  4     echo "Usage: `basename $0 .sh` <process-id>" 1>&2
  5     exit 1
  6 fi
  7 
  8 if test ! -r /proc/$1; then
  9     echo "Process $1 not found." 1>&2
 10     exit 1
 11 fi
 12 
 13 # GDB doesn't allow "thread apply all bt" when the process isn't
 14 # threaded; need to peek at the process to determine if that or the
 15 # simpler "bt" should be used.
 16 
 17 backtrace="bt"
 18 if test -d /proc/$1/task ; then
 19     # Newer kernel; has a task/ directory.
 20     if test `/bin/ls /proc/$1/task | /usr/bin/wc -l` -gt 1 2>/dev/null ; then
 21         backtrace="thread apply all bt"
 22     fi
 23 elif test -f /proc/$1/maps ; then
 24     # Older kernel; go by it loading libpthread.
 25     if /bin/grep -e libpthread /proc/$1/maps > /dev/null 2>&1 ; then
 26         backtrace="thread apply all bt"
 27     fi
 28 fi
 29 
 30 GDB=${GDB:-/usr/bin/gdb}
 31 
 32 if $GDB -nx --quiet --batch --readnever > /dev/null 2>&1; then
 33     readnever=--readnever
 34 else
 35     readnever=
 36 fi
 37 
 38 # Run GDB, strip out unwanted noise.
 39 $GDB --quiet $readnever -nx /proc/$1/exe $1 <<EOF 2>&1 | 
 40 set width 0
 41 set height 0
 42 set pagination no
 43 $backtrace
 44 EOF
 45 /bin/sed -n \
 46     -e 's/^\((gdb) \)*//' \
 47     -e '/^#/p' \
 48     -e '/^Thread/p'
 49 #end

 

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
引用\[1\]:前几天线上服务器某个Tomcat进程突然间歇性CPU占用率100%,这个并不是突然性的,而是有规律的,Top了一下基本每隔30s飙升一次,坐等5s左右回落。虽然这酱紫,由于是多核CPU,外加其实并没有多少真实用户在访问,也并不影响什么。\[1\] 问题:windows tomcat cpu 100% 回答: 如果在Windows上运行的Tomcat进程出现CPU占用率100%的问题,可以尝试以下步骤进行排查和解决。首先,可以通过任务管理器查看Tomcat进程的详细信息,包括PID(进程ID)。然后,可以使用jstack命令保存Tomcat进程的线程现场信息,例如jstack <PID> > <文件路径>。接下来,可以使用文本编辑器打开保存的文件,搜索高CPU占用的线程ID(通常以16进制表示)。最后,根据搜索到的线程ID,可以进一步分析和解决CPU占用率高的问题。\[2\] #### 引用[.reference_title] - *1* [记一次懵比的Tomcat进程CPU使用率100%](https://blog.csdn.net/weixin_28759725/article/details/119228133)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [线上Java项目cpu突然100%或Tomcat的cpu占用100%](https://blog.csdn.net/Blueeyedboy521/article/details/124145088)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值