Java定位问题线程解析

 更新时间:2022年11月22日 09:19:28   作者:思想永无止境  
这篇文章主要介绍了Java定位问题线程,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

前言

  • ps命令的作用是显示进程信息的。
  • |符号,是个管道符号,表示左右两边两个命令同时执行。
  • grep命令是查找(Global Regular Expression Print),能使用正则表达式搜索文本,然后把匹配的行显示出来。

命令参数如果前面的参数没有输入值,那么可以多个合并在一起,如-mp等同于-m -p。

grep -A -B -C 属于上下文控制(Context control),使用规则如下:

  • grep -A 显示匹配指定内容及之后的n行
  • grep -B 显示匹配指定内容及之前的n行
  • grep -C 显示匹配指定内容及其前后各n行

查看是哪个进程占用了CPU

通过top命令,查看CPU使用率高的进程,看看COMMAND是不是java。

查看这个进程号对应的是哪个java程序

此步骤主要是在服务器部署多个java程序时,查看进程具体的包名,如果服务器只部署了一个jar可以忽略此步骤。

方案1

使用jps显示所有的java应用程序

jps -l

方案2

使用ps|grep搜索所有的java应用程序

ps -ef|grep java

查看这个进程中哪个线程占用了CPU 方案1,使用pidstat查看线程CPU占用率

pidstat -t -p pid

通过top获取的pid,使用pidstat -t -p pid查询进程下的线程。

方案3

使用ps查看线程CPU使用时长

ps -mp pid -o THREAD,tid,time

参数含义:

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

将这个线程号转16进制(如果是java程序)

将CPU占有率高或CPU使用时间长的线程号转换为16进制(因为后面的jstack里的线程号是16进制),并且将其中的字母转成小写字母。

System.out.println(Integer.toHexString(10003999).toLowerCase());

在jstack中找到这个线程的堆栈信息

使用jstack [进程号] 打印当前的进程堆栈;

jstack 39836

返回值说明:

  • prio,表示线程优先级,就是Thread中定义的线程优先级。
  • os_prio,表示线程在操作系统的优先级。
  • tid,表示Java内的线程ID,同样在Thread类中。
  • nid,表示线程在操作系统的线程ID,16进制,我们要的就是这个。

从打印的信息中,找到之前拿到的线程号

看看这个线程在做什么

jstack 39836 | grep tid -A60 #tid为小写的16进制线程ID

可以将CPU占有率高的线程都看一下。

jstack打印的信息可以多关注:Java stack information for the threads listed above:,如果有发现Found 1 deadlock就是死锁导致的。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 解决java页面URL地址传输参数乱码的方法

    解决java页面URL地址传输参数乱码的方法

    这篇文章主要介绍了解决java页面URL地址传输参数乱码的方法,URL地址参数乱码问题,算是老话重谈了吧!需要的朋友可以参考下
    2015-09-09
  • Java简单实现对一串数字采用相应的加密策略后传输

    Java简单实现对一串数字采用相应的加密策略后传输

    下面小编就为大家带来一篇Java简单实现对一串数字采用相应的加密策略后传输。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-09-09
  • Java中的transient关键字介绍

    Java中的transient关键字介绍

    这篇文章主要介绍了Java中的transient关键字介绍,需要的朋友可以参考下
    2015-03-03
  • 浅谈用SpringBoot实现策略模式

    浅谈用SpringBoot实现策略模式

    本文主要介绍了SpringBoot实现策略模式,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-10-10
  • java使用Base64编码实例

    java使用Base64编码实例

    这篇文章主要介绍了java使用Base64编码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-03-03
  • Java虚拟机JVM性能优化(一):JVM知识总结

    Java虚拟机JVM性能优化(一):JVM知识总结

    这篇文章主要介绍了Java虚拟机JVM性能优化(一):JVM知识总结,本文是系列文章的第一篇,后续篇章请继续关注脚本之家,需要的朋友可以参考下
    2014-09-09
  • java打印日志的几种方式总结

    java打印日志的几种方式总结

    这篇文章主要介绍了java打印日志的几种方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-11-11
  • Springboot配置过滤器实现过程解析

    Springboot配置过滤器实现过程解析

    这篇文章主要介绍了Springboot配置过滤器实现过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-08-08
  • SpringBoot项目整合Log4j2实现自定义日志打印失效问题解决

    SpringBoot项目整合Log4j2实现自定义日志打印失效问题解决

    这篇文章主要介绍了SpringBoot项目整合Log4j2实现自定义日志打印失效问题解决,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2024-01-01
  • 关于idea2020.3升级lombok不能使用的问题

    关于idea2020.3升级lombok不能使用的问题

    这篇文章主要介绍了关于idea2020.3升级lombok不能使用的问题,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-12-12

最新评论