jstack: Java占用高CPU分析之- GC Task Thread
来源:互联网 发布:ios怎么修改游戏数据 编辑:程序博客网 时间:2024/06/08 16:40
jstack 是JDK自带的堆栈跟踪工具,作用有两个:
- 为Java 进程或者核心文件打印出线程的堆栈信息;
- 远程调试服务器。
查看用法:
jstack -help
Usage:
jstack [-l] <pid>
(to connect to running process)
jstack -F [-m] [-l] <pid>
(to connect to a hung process)
jstack [-m] [-l] <executable> <core>
(to connect to a core file)
jstack [-m] [-l] [server_id@]<remote server IP or hostname>
(to connect to a remote debug server)
Options:
-F to force a thread dump. Use when jstack <pid> does not respond (process is hung)
-m to print both java and native frames (mixed mode)
-l long listing. Prints additional information about locks
-h or -help to print this help message
下面开始具体的调试步骤:
- top 命令可以看到具体的Java进程号:(注意这里的PID是进程ID)
2. 然后按 Shift + h 直接列出线程号:注意这里的PID是线程ID(对应的是native 线程的id, 即nid)
3. 可以看到主要是19226和19227这两个线程消耗大量的CPU,而且时间累占用了一个小时左右,需要把线程号转换成十六进制,因为打印出来的堆栈信息里面的线程号是十六进制形式: printf “%x/n” 19226
4. 获得占用CPU的Java进程号和线程号后可以用jstack工具来打印堆栈信息了:
(1) 先把整个进程堆栈信息打印预览: jstack 19214
(2)如果要快速定位线程造成的问题用:jstack [PID(进程号)] | grep [PID(线程号十六进制)] -A 10
5. 从进程和线程的堆栈信息可以看出是JVM的GC线程一直在占用大量CPU, 定位代码得出的结论是:Java程序连MySQL频繁new connection而且没有调用close方法,导致GC线程一直占用CPU。
- jstack: Java占用高CPU分析之- GC Task Thread
- jstack: Java占用高CPU分析之- C2 Compiler Thread
- jstack:分析linux下java程序占用CPU高
- Jstack分析CPU占用高问题
- jstack分析cpu占用100%
- 利用jstack分析JAVA应用CPU占用过高的问题
- jstack分析cpu占用100%(转)
- cpu占用高分析
- linux下采用ps、jstack命令排查命中java应用中占用CPU高的代码
- linux下采用ps、jstack命令排查命中java应用中占用CPU高的代码
- 利用jstack命令定位占用cpu高的java线程及具体错误代码信息
- Java 高CPU占用
- Linux系统监控命令个人总结之jstack查找高度占用CPU的java代码
- Java 占用CPU使用率很高的分析
- Java 占用CPU使用率很高的分析
- Java 占用CPU使用率很高的分析 .
- Java 占用CPU使用率很高的分析
- java进程占用cpu高
- java流式布局案例
- 第六届“中国软件杯”大学生软件设计大赛赛题-QRcode
- CMakelist编译静态库和动态库
- 下划线tab切换仿手机淘宝收发货
- 曝光悠百佳黑心企业,害我散尽家财
- jstack: Java占用高CPU分析之- GC Task Thread
- 怎样在VC++动态链接库(DLL)编程之库的查看以及调试呢?
- springmvc系列(二)-自定义dispatcherservlet加载的xml配置文件
- Linux多线程面试题
- 我是数据分析师(一):假老公提Excel数据自动更新的需求——Quick BI新手使用入门篇
- 数据库
- AS开发中出现Error(六)——Error: Activity class {} does not exist.Error while Launching activity
- SourceInsight 4破解
- 一分钟了解“MAC OS 和 Windows系统的优劣对比”