jstack使用教程
2016-12-07 18:20
127 查看
1. qmq是部署在tomcat中的应用名
ps -ef | grep qmq | grep -v grep
拿到进程号, 例如上面对应的是3192
2. 第二步找出该进程内最耗费CPU的线程,可以使用ps -Lfp pid或者ps -mp pid -o THREAD, tid, time或者top -Hp pid
例如用第三个 top -Hp 3192
3. TIME列就是各个Java线程耗费的CPU时间,CPU时间最长的是线程ID为3551的线程,用
printf "%x\n" 3551
得到ddf
4. sudo -u tomcat jstack 3192 | grep ddf
ps -ef | grep qmq | grep -v grep
拿到进程号, 例如上面对应的是3192
2. 第二步找出该进程内最耗费CPU的线程,可以使用ps -Lfp pid或者ps -mp pid -o THREAD, tid, time或者top -Hp pid
例如用第三个 top -Hp 3192
Tasks: 123 total, 0 running, 123 sleeping, 0 stopped, 0 zombie Cpu(s): 0.3%us, 0.4%sy, 0.0%ni, 99.3%id, 0.0%wa, 0.0%hi, 0.0%si, 0.0%st Mem: 3922688k total, 3272588k used, 650100k free, 432768k buffers Swap: 4194296k total, 0k used, 4194296k free, 596488k cached PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND 3494 tomcat 20 0 4905m 1.1g 11m S 0.3 28.4 0:51.91 java 3551 tomcat 20 0 4905m 1.1g 11m S 0.3 28.4 4:46.32 java 3588 tomcat 20 0 4905m 1.1g 11m S 0.3 28.4 0:07.35 java 3192 tomcat 20 0 4905m 1.1g 11m S 0.0 28.4 0:00.00 java 3194 tomcat 20 0 4905m 1.1g 11m S 0.0 28.4 0:00.82 java
3. TIME列就是各个Java线程耗费的CPU时间,CPU时间最长的是线程ID为3551的线程,用
printf "%x\n" 3551
得到ddf
4. sudo -u tomcat jstack 3192 | grep ddf
"New I/O worker #30" daemon prio=10 tid=0x00007f44fd525800 nid=0xde4 runnable [0x00007f4530ddf000] "DubboResponseTimeoutScanTimer" daemon prio=10 tid=0x00007f44fca88000 nid=0xddf waiting on condition [0x00007f45322e5000]
相关文章推荐
- jstack jstat 简易使用教程
- JSP教程(三)--JSP中”预定义变量”的使用
- Win32汇编教程五 菜单和加速键的使用
- Win32汇编教程六 工具栏和状态栏的使用
- Win32汇编教程三 一个简单的对话框 --- 兼谈资源文件的使用
- 关于肉鸡的一些使用教程
- JSP入门初级教程之plugin的使用
- ECHO命令使用教程
- 软件架构训练基础教程之层次及使用
- 世嘉土星模拟器GIRI GIRI & Loader的使用教程
- JSP入门初级教程之预定义变量的使用
- DirectX5.0最新游戏编程指南 DirectDraw教程篇 四、使用覆盖表面
- JSP教程(七)-pluginAction的使用
- [翻译教程]使用JBOSS和ECLIPSE构建J2EE应用程序教程--第一章
- 使用ASP站长助手6.0提升webshll中cmd权限图文教程
- 使用VS.NET开发Web Services 简明教程
- InstallShield简明使用教程
- 使用VS.NET开发Web Services 简明教程
- JSP教程(五)-JSP Actions的使用下
- [软件架构训练基础教程-7]层次及使用