线上问题排查方法

文章目录

  • 查看栈信息
  • 查看堆信息
  • 排查cpu占用最高的线程从而定位代码位置

查看栈信息

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

  • top查看进程列表

  • 查看线程占用排行top -Hp 1 (查看进程pid为1 下面的线程列表情况)
    线上问题排查方法_第1张图片

  • 查看进程id为1的各线程情况jstack -l 1
    线上问题排查方法_第2张图片

  • 可以将栈信息生成文件jstack -l 1 > 2.log
    线上问题排查方法_第3张图片

  • 查看对应进程号的信息,比如要看线程id是28的,那么28的16进制是1C,则检索栈文件里ox1C的位置
    线上问题排查方法_第4张图片

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

查看堆信息

  • 安装java的jdk文件里的bin文件目录的工具可导入堆快照文件
    线上问题排查方法_第5张图片
  • 通过查看类的实例数 分析定位问题
    线上问题排查方法_第6张图片

排查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]

你可能感兴趣的:(实操,java)