线上java生产环境服务器变慢,诊断思路和方法

生产环境变慢,出现了服务器卡顿,那么就需要进行排查了,一般定位出问题的步骤如下:

1.使用top命令找出CPU占比最高的

ps -ef 或者 jps 进一步定位,得知是一个怎么样的后台程序出的问题,定位到具体线程或者代码

2.找出此进程pid下最耗cpu的线程

ps -mp 进程号(pid) -o THREAD,tid,time

参数解释

  • -m:显示所有的线程
  • -p:pid进程使用CPU的时间
  • -o:该参数后是用户自定义格式

  也可以利用top -Hp pid 可以查看到指定进程的线程情况(不过不好用)。

3.将需要的线程ID转换为16进制格式(英文小写格式)

printf “%x” 有问题的线程ID

4.定位问题代码行

jstack 进程ID(pid) | grep tid(16进制线程ID小写英文) -A60(显示60行)

精准定位到错误的地方

5.具体的场景:

场景:

package OOM;
import java.util.Random;

public class while1 {
    public static void main(String[] args) {
        while (true){
            Random random = new Random();
            int i = random.nextInt() * 1000;
            System.out.println("==== :"+ i);
        }
    }
}

5.1.查找cpu

定位到此java程序是占用了25.7%的cpu,pid是95594,然后使用jps查询具体程序信息:

使用

ps -ef|grep 95594|grep -v grep

5.2定位到具体线程

ps -mp 95594 -o THREAD,tid,time

5.3转换16进制

tid是95595,转换16进制

printf "%x"  95595

得到结果:1756b

5.4找到问题处

jstack 95594 | grep 1756b -A60

直接定位到出问题的代码位置:

至此,问题代码找出,接下来就是定位程序了

 

 

  • 0
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值