如何排查线上CPU过高的问题(Java程序篇)

4 篇文章 0 订阅
1 篇文章 0 订阅

相信大家都会碰到这样的问题,突然某一天服务器CPU直接拉满,导致服务响应超时或者服务宕机,碰到这种问题,掌握排查方法是解决问题的关键,下面列举一下这个问题的排查方法。

1.使用top命令查看对应的程序进程

在这里插入图片描述

2.使用 top -H -p 进程号 查找对应CPU较高的线程

top -H -p 进程号

在这里插入图片描述

3.由于我们是Java程序,Java的 jstack 命令 需要提供16进制的线程Id(查出来的线程号是十进制的),使用下面的命令获取线程号的16进制数

printf '0x%x\n' 线程号
结果:0x520

4.拿到线程号的十六进制数后,使用 jstack 来分析Java进程的线程堆栈信息,命令如下:

jstack 进程号 | grep 十六进制的线程数 -A 显示的行数
例如:
jstack 1312 | grep 0x520 -A 30

命令会生成进程ID为 1312 的Java进程的线程堆栈跟踪信息,并搜索其中的 30 行,然后将这些信息打印到屏幕上,便于去分析是哪几行代码造成的CPU过高。

  • 8
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值