服务器CPU高居不下,JAVA线程占用排查方式

 更新时间:2023年09月01日 14:25:45   作者:保护我方胖虎  
这篇文章主要介绍了服务器CPU高居不下,JAVA线程占用排查方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

服务器CPU高居不下,JAVA线程占用排查

排查Java进程中确定哪个线程正在占用CPU的时间。

详细步骤

1、首先确定进程的 ID 

可以使用 jps -v 或者 top 命令直接查看

jps -v

我们这里使用进程ID (PID) 11646

2、查看该进程中哪个线程占用大量 CPU

执行 top -H -p [PID]

结果如下:

top -H -p 11646

3、接下来我们将进程中的所有线程输出到一个文件中

执行:jstack [PID] > 文件名

 jstack 11646 > test-jstack.txt

4、在进程中查找对应的线程 ID

执行:cat 输出文件名 | grep -i 16进制线程号

假设我们想看编号为 5331这个线程,首先将 5331线程号转成 16 进制是 14d3

cat test-jstack.txt |grep -i 14d3

结果是:

找到问题!

JAVA高内存占用排查

1、查看java进程

#获取进程号
ps -ef|grep java

2、使用top命令查看内存占用

# 查看占用内存最多的线程
top -Hp 进程号

3、将线程号转为16进制

printf "%x\n" 线程号

4、使用jstack打印出当前线程的信息

jstack 进程号 | grep -20 线程16进制

5、使用jstack 将线程信息输出到文本

jstack -l 进程号 >> jstack.log

总结

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

相关文章

  • 浅析scala中map与flatMap的区别

    浅析scala中map与flatMap的区别

    这篇文章主要介绍了浅析scala中map与flatMap的区别,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-06-06
  • spring的xml文件打开没有namespace等操作选项的解决方案

    spring的xml文件打开没有namespace等操作选项的解决方案

    这篇文章主要介绍了spring的xml文件打开没有namespace等操作选项的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-09-09
  • java自定义JDBC实现连接池

    java自定义JDBC实现连接池

    本文主要介绍了java自定义JDBC实现连接池,包含实现JDBC连接池以及SQLException 异常的处理,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2024-02-02
  • Mybatis 条件查询 批量增删改查功能

    Mybatis 条件查询 批量增删改查功能

    这篇文章主要介绍了mybatis 脚本处理语句之条件查询 批量增删改查功能,需要的的朋友参考下吧
    2017-06-06
  • SpringBoot中的MongoTemplate的各种条件查询示例详解

    SpringBoot中的MongoTemplate的各种条件查询示例详解

    这篇文章主要介绍了SpringBoot中的MongoTemplate的各种条件查询示例详解,本文通过示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借价值,需要的朋友参考下吧
    2024-01-01
  • Java上传文件进度条的实现方法(附demo源码下载)

    Java上传文件进度条的实现方法(附demo源码下载)

    这篇文章主要介绍了Java上传文件进度条的实现方法,可简单实现显示文件上传比特数及进度的功能,并附带demo源码供读者下载参考,需要的朋友可以参考下
    2015-12-12
  • mybatis plus动态数据源切换及查询过程浅析

    mybatis plus动态数据源切换及查询过程浅析

    这篇文章主要介绍了mybatis plus动态数据源切换及查询过程浅析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-12-12
  • Java SPEL表达式注入漏洞原理解析

    Java SPEL表达式注入漏洞原理解析

    SpEL简称Spring表达式语言,在Spring 3中引入,SpEL能在运行时构建复杂表达式、存取对象图属性、对象方法调用等等,可以与基于XML和基于注解的Spring配置还有bean定义一起使用,本文给大家介绍Java SPEL表达式注入漏洞原理研究,感兴趣的朋友一起看看吧
    2023-10-10
  • Spring Security的过滤器链机制

    Spring Security的过滤器链机制

    过滤器作为 ​Spring Security​ 的重中之重,我们需要了解其中的机制,这样我们才能根据业务需求的变化进行定制,今天来探讨一下 ​Spring Security​ 中的过滤器链机制
    2022-08-08
  • 深入理解Java中观察者模式与委托的对比

    深入理解Java中观察者模式与委托的对比

    这篇文章主要介绍了Java中观察者模式与委托的对比,观察者模式:定义了一种一对多的依赖关系,让多个观察者对象同时监听某一个主题对象,委托的实现简单来讲就是用反射来实现的,本文给大家介绍的非常详细,需要的朋友可以参考下
    2022-05-05

最新评论