【Java】服务CPU占用率100%,教你用jstack排查定位

简介: 本文详细讲解如何使用jstack排查定位CPU高占用问题。首先介绍jstack的基本概念:它是诊断Java应用程序线程问题的工具,能生成线程堆栈快照,帮助找出程序中的瓶颈。接着,文章通过具体步骤演示如何使用`top`命令找到高CPU占用的Java进程及线程,再结合`jstack`命令获取堆栈信息并进行分析,最终定位问题代码。

前言

🍊缘由

我对你的爱都没100%,你的服务却把我CPU沾满

🏀事情起因:

大家好,我是JavaDog程序狗

今天给大家来分享一下如何使用jstack排查定位CPU高占用问题

你想听的故事

🎯主要目标

实现2大重点

1. 什么是jstack
2. jstack排查定位方法步骤

🥦目标分析

一. 什么是jstack?

jstack 是一个用于诊断 Java 应用程序线程问题的工具,它主要用来生成 Java 虚拟机(JVM)在某一时刻的线程堆栈快照。
这个快照包含了JVM 内所有线程的信息,包括它们正在执行的方法调用堆栈以及可能的阻塞点

👽人话解释

jstack 就像是给你的Java 程序做的一次“体检”,特别是检查程序里的“线程”是否健康。

想象一下,你的程序就像是一个繁忙的工厂,有很多工人(线程)在同时工作,有的在搬运货物(执行任务),有的在等待机器(等待资源),还有的可能因为某些原因卡住了(死锁或挂起)。

当你发现程序运行变慢或者卡住时,jstack 就能派上用场了。它会告诉你每个工人(线程)当前在做什么,他们在哪里停下了手头的工作,或者是否在等待其他工人的帮助。这样,你就可以找出是谁在捣乱,为什么程序会变慢,然后采取措施解决问题。


二. jstack排查定位方法步骤?

1. 使用top命令

top

服务器使用top命令,查看占用cpu过高的java进程pid

如果java进程少,还可以通过jps -l 拿到java进程pid

jps -l

2. top -Hp pid

top -Hp 31411

使用top -Hp 31411,31411就是上方占用最高的java进程pid。
可以查看该进程下,各个线程的cpu使用情况,找到对应的最高占用率的pid,也就是31413

3. printf '%x\n' pid

printf '%x\n' 3141

使用printf '%x\n' 31413将线程号转化为16进制显示

4.jstack pid | grep '转化后16进制线程id' -C5 --color

jstack 31411 | grep '7ab5' -C5 --color

通过jstack打印进程31413的堆栈信息,并只过滤出线程7ab5的堆栈信息

最后查看报错提示行数,找到源码,成功定位

总结

高效利用jstack诊断Java应用性能问题

  1. 定位问题:

    • 用top或jps -l找到高CPU的Java进程。
    • top -Hp 找出最耗CPU的线程。
    • 将线程ID转为十六进制。
  2. 获取堆栈:

    • jstack | grep '' -C5获取线程堆栈信息。
  3. 分析修复:

    • 分析堆栈信息,定位并修复问题代码。

jstack是快速诊断Java应用性能瓶颈的关键工具,掌握其使用可有效提升应用稳定性


🍯猜你喜欢

文章推荐

【规范】Git分支管理,看看我司是咋整的

【工具】珍藏免费宝藏工具,不好用你来捶我

【插件】IDEA这款插件,爱到无法自拔

【规范】看看人家Git提交描述,那叫一个规矩

【工具】用nvm管理nodejs版本切换,真香!

【项目实战】SpringBoot+uniapp+uview2打造H5+小程序+APP入门学习的聊天小项目

【项目实战】SpringBoot+uniapp+uview2打造一个企业黑红名单吐槽小程序

【模块分层】还不会SpringBoot项目模块分层?来这手把手教你!

目录
相关文章
|
1月前
|
Java Maven Windows
使用Java创建集成JACOB的HTTP服务
本文介绍了如何在Java中创建一个集成JACOB的HTTP服务,使Java应用能够调用Windows的COM组件。文章详细讲解了环境配置、动态加载JACOB DLL、创建HTTP服务器、实现IP白名单及处理HTTP请求的具体步骤,帮助读者实现Java应用与Windows系统的交互。作者拥有23年编程经验,文章来源于稀土掘金。著作权归作者所有,商业转载需授权。
使用Java创建集成JACOB的HTTP服务
|
1天前
|
前端开发 Java API
JAVA Web 服务及底层框架原理
【10月更文挑战第1天】Java Web 服务是基于 Java 编程语言用于开发分布式网络应用程序的一种技术。它通常运行在 Web 服务器上,并通过 HTTP 协议与客户端进行通信。
9 1
|
3天前
|
Java 关系型数据库 MySQL
java控制Windows进程,服务管理器项目
本文介绍了如何使用Java的`Runtime`和`Process`类来控制Windows进程,包括执行命令、读取进程输出和错误流以及等待进程完成,并提供了一个简单的服务管理器项目示例。
14 1
|
3天前
|
存储 Java
深入理解java对象的访问定位
这篇文章深入探讨了Java对象的访问定位机制,比较了使用句柄和直接指针两种主流的对象访问方式,并指出了它们各自的优势,例如句柄访问在对象移动时的稳定性和直接指针访问的速度优势。
12 0
深入理解java对象的访问定位
|
17天前
|
JSON Java 数据格式
java调用服务报错400
java调用服务报错400
37 2
|
17天前
|
JSON Java 数据格式
java调用服务报错415 Content type ‘application/octet-stream‘ not supported
java调用服务报错415 Content type ‘application/octet-stream‘ not supported
45 1
|
1月前
|
Java 数据库连接 数据库
Java服务提供接口(SPI)的设计与应用剖析
Java SPI提供了一种优雅的服务扩展和动态加载机制,使得Java应用程序可以轻松地扩展功能和替换组件。通过合理的设计与应用,SPI可以大大增强Java应用的灵活性和可扩展性。
57 18
|
2月前
|
开发者 C# 自然语言处理
WPF开发者必读:掌握多语言应用程序开发秘籍,带你玩转WPF国际化支持!
【8月更文挑战第31天】随着全球化的加速,开发多语言应用程序成为趋势。WPF作为一种强大的图形界面技术,提供了优秀的国际化支持,包括资源文件存储、本地化处理及用户界面元素本地化。本文将介绍WPF国际化的实现方法,通过示例代码展示如何创建和绑定资源文件,并设置应用程序语言环境,帮助开发者轻松实现多语言应用开发,满足不同地区用户的需求。
48 0
|
16天前
|
存储 关系型数据库 MySQL
查询服务器CPU、内存、磁盘、网络IO、队列、数据库占用空间等等信息
查询服务器CPU、内存、磁盘、网络IO、队列、数据库占用空间等等信息
87 5
|
14天前
|
Prometheus Kubernetes 监控
使用kubectl快速查看各个节点的CPU和内存占用量
在Kubernetes集群中,安装metrics-server,并使用kubectl快速查看集群中各个节点的资源使用情况。
34 0