liunx的top命令,jvm的jstack

top指令

 top命令相当于我们window系统的任务管理器,可以通过top命令很清楚查看到每个进程占用了多少系统资源,如
 cpu占用率,内存占用多大

在这里插入图片描述

top进程信息

在这里插入图片描述
进程参数含义

PID进程id
USER父进程id
PR优先级
NI谦让度值 nice值。负值表示高优先级,正值表示低优先级
VIRT进程使用的虚拟内存总量,单位kb。VIRT=SWAP+RES
SHR共享内存大小,单位kb
S进程状态。D=不可中断的睡眠状态 R=运行 S=睡眠 T=跟踪/停止 Z=僵尸进程
%CPU上次更新到现在的CPU时间占用百分比
%MEM进程使用的物理内存百分比
TIME+进程使用的CPU时间总计,单位1/100秒
COMMAND命令名/命令行

原文链接:https://blog.csdn.net/shugyin/article/details/127450462

查看线程信息

2,ps H -eo pid,tid,%cpu | grep 进程编号
这个命令的意思是,进程里的线程分别占用了多少cpu
在这里插入图片描述

ps H :查看对应线程信息
-eo : 可以输出指定的信息
| grep :使用管道符查询进程信息
pid : 进程id
tid : 线程id
%cpu :占cpu的百分之几

jstack

1. 简介

jstack主要用于生成java虚拟机当前时刻的线程快照。
  线程快照是当前java虚拟机内每一条线程正在执行的方法堆栈的集合,
  主要目的是定位线程出现长时间停顿的原因,如线程间死锁、死循环、请求外部资源导致的长时间等待等

jstack 命令格式如下

jstack [option] <pid>  // 打印某个进程的堆栈信息

option参数说明如下:

选项 作用
-F 当正常输出的请求不被响应时,强制输出线程堆栈
-m 如果调用到本地方法的话,可以显示C/C++的堆栈
-l 除堆栈外,显示关于锁的附加信息,在发生死锁时可以用jstack -l pid来观察锁持有情况
  • jstack
    在这里插入图片描述
    在这里插入图片描述

在这里插入图片描述
Dump文件的线程状态一般其实就以下3种:

  1. RUNNABLE,线程处于执行中
  2. BLOCKED,线程被阻塞
  3. WAITING,线程正在等待
  • jstack -l
    在这里插入图片描述

案例:

java中cpu占用100%排查

第一步:使用top命令查看进程占用cpu资源情况

在这里插入图片描述

第二步:使用占用cpu 100%的pid(进程id),查找进程对应线程占用cpu的资源情况

ps H -eo pid,tid,%cpu | grep 进程id(pid)

在这里插入图片描述

第三步:使用java的jstack查看进程的执行情况

jstack 进程id(pid)

在这里插入图片描述
从第二步图中可以得知占用cpu最高的线程id是 28 ,但是这个是10进制的。jstack命令中的nid(线程id)是十六进制的。所以将28转成十六进制是 1c。最终的排查出得到是上图出的代码有问题

  • liunx中十进制转十六进制
[root@localhost opt]# printf "%x\n" 28
1c

在这里插入图片描述

在这里插入图片描述

第四步:生成thread dump文件

生成dump文件,再生产环境时不方便排查,

jstack -l [pid] >/xx/xx.txt

在这里插入图片描述

jstack 分析死锁问题

Docker 容器 CPU 和内存占用过高问题排查

第一步:使用top命令查找cpu占用过高的pid

在这里插入图片描述

第二步:通过进程id找到,容器id

cat /proc/108146/cgroup

在这里插入图片描述

第三步:根据容器ID获取Docker容器名称

docker inspect --format '{{.Name}}' "<containerid>"

在这里插入图片描述
或者
1、查看docker的cpu占用率:docker stats

2、进入cpu占用高的docker容器:docker exec -it 容器编号 /bin/bash

3、查看容器中具体进程cpu占用率,执行top,(如top命令无法使用,执行:export TERM=dumb ,然后在执行:top)

4、查看进程中线程cpu占用率:top -H -p 进程号

5、将异常线程号转化为16进制: printf “%x\n” 线程号

6、查看线程异常的日志信息:jstack 进程号|grep 16进制异常线程号 -A90
在这里插入图片描述

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值