线上问题排查方法

查看栈信息

先进入docker容器,docker exec -it 容器号 bash

  • top查看进程列表

  • 查看线程占用排行top -Hp 1 (查看进程pid为1 下面的线程列表情况)
    在这里插入图片描述

  • 查看进程id为1的各线程情况jstack -l 1
    在这里插入图片描述

  • 可以将栈信息生成文件jstack -l 1 > 2.log
    在这里插入图片描述

  • 查看对应进程号的信息,比如要看线程id是28的,那么28的16进制是1C,则检索栈文件里ox1C的位置
    在这里插入图片描述

  • 查找对应线程的信息cat 2.log | grep 0x1c
    在这里插入图片描述

查看堆信息

  • 安装java的jdk文件里的bin文件目录的工具可导入堆快照文件
    在这里插入图片描述
  • 通过查看类的实例数 分析定位问题
    在这里插入图片描述

排查cpu占用最高的线程从而定位代码位置

  • pid是进程id,tid是线程id

  • 查看占用cpu的进程

top 
  • 查看指定进程里的线程占用cpu情况
ps -mp [pid] -O THREAD,tid,time |sort -k2r |head -10
  • 打印 16进制转换后的线程id
printf "%x\n" [tid]
  • 查看16进制转换后的线程id的 栈信息,查看对应代码位置
jstack [tid] 

或者

 jstack -l 1 | grep [tid]

调试时手动更改传参值|查看执行方法情况

在这里插入图片描述

  • 在框内可以提前执行自己想要查看的方法
    在这里插入图片描述
  • 在此框更改传参值后,再此框可以再执行想要执行的方法,查看自己手动改了传参值后的方法情况

在这里插入图片描述

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值