Java_tomcat thread dump 分析
- 前言
Java Thread Dump 是一个非常有用的应用诊断工具, 通过thread dump出来的信息, 可以定位到你需要了解的线程, 以及这个线程的调用栈. 如果配合linux的top命令, 可以找到你的系统中的最耗CPU的线程代码段, 这样才能有针对性地进行优化.
- 场景和实践
2.1. 后台系统一直是在黑盒运行, 除了能暂停一部分任务的执行, 根本无法知道哪些任务耗CPU过多。所以一直以为是业务代码的问题, 经过各种优化(删减没必要的逻辑, 合并写操作)等等优化, 系统负载还是很高. 没什么访问量, 后台任务处理也就是每天几百万的级别, load还是达到了15以上. CPU只有4核,天天收到load告警却无从下手, 于是乎就被迫来分析一把线程.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
|
2012 - 04 - 13 16 : 30 : 41 Full thread dump OpenJDK 64 -Bit Server VM ( 1.6 . 0 -b09 mixed mode): "TP-Processor12" daemon prio= 10 tid= 0x00000000045acc00 nid= 0x7f19 in Object.wait() [ 0x00000000483d0000 .. 0x00000000483d0a90 ] java.lang.Thread.State: WAITING (on object monitor) at java.lang.Object.wait(Native Method) - waiting on < 0x00002aaab5bfce70 > (a org.apache.tomcat.util.threads.ThreadPool$ControlRunnable) at java.lang.Object.wait(Object.java: 502 ) at org.apache.tomcat.util.threads.ThreadPool$ControlRunnable.run(ThreadPool.java: 662 ) - locked < 0x00002aaab5bfce70 > (a org.apache.tomcat.util.threads.ThreadPool$ControlRunnable) at java.lang.Thread.run(Thread.java: 636 ) "TP-Processor11" daemon prio= 10 tid= 0x00000000048e3c00 nid= 0x7f18 in Object.wait() [ 0x00000000482cf000 .. 0x00000000482cfd10 ] java.lang.Thread.State: WAITING (on object monitor) .... "VM Thread" prio= 10 tid= 0x00000000042ff400 nid= 0x77de runnable "GC task thread#0 (ParallelGC)" prio= 10 tid= 0x000000000429c400 nid= 0x77d9 runnable "GC task thread#1 (ParallelGC)" prio= 10 tid= 0x000000000429d800 nid= 0x77da runnable "GC task thread#2 (ParallelGC)" prio= 10 tid= 0x000000000429ec00 nid= 0x77db runnable "GC task thread#3 (ParallelGC)" prio= 10 tid= 0x00000000042a0000 nid= 0x77dc runnable "VM Periodic Task Thread" prio= 10 tid= 0x0000000004348400 nid= 0x77e5 waiting on condition JNI global references: 815 Heap PSYoungGen total 320192K, used 178216K [ 0x00002aaadce00000 , 0x00002aaaf1800000 , 0x00002aaaf1800000 ) eden space 303744K, 55 % used [ 0x00002aaadce00000 , 0x00002aaae718e048 , 0x00002aaaef6a0000 ) from space 16448K, 65 % used [ 0x00002aaaf0690000 , 0x00002aaaf110c1b0 , 0x00002aaaf16a0000 ) to space 16320K, 0 % used [ 0x00002aaaef6a0000 , 0x00002aaaef6a0000 , 0x00002aaaf0690000 ) PSOldGen total 460992K, used 425946K [ 0x00002aaab3a00000 , 0x00002aaacfc30000 , 0x00002aaadce00000 ) object space 460992K, 92 % used [ 0x00002aaab3a00000 , 0x00002aaacd9f6a30 , 0x00002aaacfc30000 ) PSPermGen total 56192K, used 55353K [ 0x00002aaaae600000 , 0x00002aaab1ce0000 , 0x00002aaab3a00000 ) object space 56192K, 98 % used [ 0x00002aaaae600000 , 0x00002aaab1c0e520 , 0x00002aaab1ce0000 ) |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
Tasks: 118 total, 2 running, 116 sleeping, 0 stopped, 0 zombie Cpu(s): 92.6 %us, 2.3 %sy, 0.0 %ni, 3.8 %id, 0.7 %wa, 0.1 %hi, 0.7 %si, 0.0 %st Mem: 4054168k total, 3892212k used, 161956k free, 115816k buffers Swap: 4192956k total, 294448k used, 3898508k free, 2156024k cachedPID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND 8091 admin 16 0 1522m 814m 9660 R 22.3 20.6 4 : 05.61 java 8038 admin 16 0 1522m 814m 9660 R 10.3 20.6 2 : 46.31 java 8043 admin 15 0 1522m 814m 9660 S 3.7 20.6 1 : 52.04 java 8039 admin 15 0 1522m 814m 9660 S 0.7 20.6 2 : 10.98 java 8041 admin 15 0 1522m 814m 9660 S 0.7 20.6 1 : 39.66 java 8009 admin 15 0 1522m 814m 9660 S 0.3 20.6 0 : 27.05 java 8040 admin 15 0 1522m 814m 9660 S 0.3 20.6 0 : 51.46 java 7978 admin 25 0 1522m 814m 9660 S 0.0 20.6 0 : 00.00 java 7980 admin 19 0 1522m 814m 9660 S 0.0 20.6 0 : 05.05 java 7981 admin 16 0 1522m 814m 9660 S 0.0 20.6 0 : 06.31 java 7982 admin 15 0 1522m 814m 9660 S 0.0 20.6 0 : 06.50 java 7983 admin 15 0 1522m 814m 9660 S 0.0 20.6 0 : 06.66 java 7984 admin 15 0 1522m 814m 9660 S 0.0 20.6 0 : 06.87 java 7985 admin 15 0 1522m 814m 9660 S 0.0 20.6 0 : 33.82 java |
1
2
3
4
5
|
"链路检测" prio= 10 tid= 0x00002aaafa498000 nid= 0x1F9B runnable [ 0x0000000045fac000 .. 0x0000000045facd10 ]</div> java.lang.Thread.State: RUNNABLE at cn.emay.sdk.communication.socket.AsynSocket$CheckConnection.run(AsynSocket.java: 112 ) at java.lang.Thread.run(Thread.java: 636 ) |

Java_tomcat thread dump 分析的更多相关文章
- 性能分析之-- JAVA Thread Dump 分析综述
性能分析之-- JAVA Thread Dump 分析综述 一.Thread Dump介绍 1.1什么是Thread Dump? Thread Dump是非常有用的诊断Java应用问题的工 ...
- tomcat thread dump 分析【转载】
前言 Java Thread Dump 是一个非常有用的应用诊断工具, 通过thread dump出来的信息, 可以定位到你需要了解的线程, 以及这个线程的调用栈. 如果配合linux的top命令, ...
- 性能分析之– JAVA Thread Dump 分析
最近在做性能测试,需要对线程堆栈进行分析,在网上收集了一些资料,学习完后,将相关知识整理在一起,输出文章如下. 一.Thread Dump介绍 1.1什么是Thread Dump? Thread Du ...
- (转)性能分析之-- JAVA Thread Dump 分析综述
原文链接:http://blog.csdn.net/rachel_luo/article/details/8920596 最近在做性能测试,需要对线程堆栈进行分析,在网上收集了一些资料,学习完后,将相 ...
- 通过 thread dump 分析找到高CPU耗用与内存溢出的Java代码
http://heylinux.com/archives/1085.html通过 thread dump 分析找到高CPU耗用与内存溢出的Java代码 首先,要感谢我的好朋友 钊花 的经验分享. 相信 ...
- java jvm heap dump及 thread dump分析
一.概念: 在进行java应用故障分析时,经常需要分析内存和cpu信息,也就说所谓的heap dump 和 thread dump heap dump: heap dump文件是一个二进制文件,需要工 ...
- tomcat thread dump 分析
前言 Java Thread Dump 是一个非常有用的应用诊断工具, 通过thread dump出来的信息, 可以定位到你需要了解的线程, 以及这个线程的调用栈. 如果配合linux的top命令, ...
- java之Thread Dump分析
什么是Thread Dump Thread Dump是非常有用的诊断Java应用问题的工具.每一个Java虚拟机都有及时生成所有线程在某一点状态的thread-dump的能力,虽然各个 Java虚拟机 ...
- jstack生成的Thread Dump日志线程 分析
文章转载自: https://www.javatang.com/archives/2017/10/25/36441958.html 前面文章中只分析了Thread Dump日志文件的结构,今天针对日志 ...
随机推荐
- mybatis 易百练习笔记
1. session.commit() 增删改需要提交 session.close() session需要关闭 2. insert into t() values() 不用写i ...
- three.js是什么,能干嘛,和webgl什么关系
如今浏览器的功能越来越强大,而且这些功能可能通过JavaScript直接调用.你可以用HTML5标签轻松地添加音频和视频,而且可以在HTML5画布上创建各种交互组件.现在这个功能集合里又有了一个新成员 ...
- (一)问候 HtmlUnit
第一节: HtmlUnit 简介 htmlunit 是一款开源的java 页面分析工具,读取页面后,可以有效的使用htmlunit分析页面上的内容.项目可以模拟浏览器运行,被誉为java浏览器的开源实 ...
- sqlserver中的循环遍历(普通循环和游标循环)(转载)
sql 经常用到循环,下面介绍一下普通循环和游标循环 1.首先需要一个测试表数据Student
- Ansible实战:部署分布式日志系统
本节内容: 背景 分布式日志系统架构图 创建和使用roles JDK 7 role JDK 8 role Zookeeper role Kafka role Elasticsearch role My ...
- TypeScript学习笔记(四) - 类和接口
本篇将介绍TypeScript里的类和接口. 与其他强类型语言类似,TypeScript遵循ECMAScript 2015标准,支持class类型,同时也增加支持interface类型. 一.类(cl ...
- window服务器上搭建git服务,window server git!!!
先给大家看一个高大上的,这是我给我公司配置的,小伙伴们都说好! 阿里云的2012server 基于这篇大神的教程,我把服务端搭建好了. 传送门,当然我还是自己做个笔记的好. 1.下载java,并安装 ...
- Action(8):Error -27728:Step download timeout(120 seconds)has expired when downloading
Action(8):Error -27728:Step download timeout(120 seconds)has expired when downloading 出现如下图所示对话框上的 ...
- Filter的应用--权限过滤
因为项目比较长,需要一步步进行实现,所以分解成一个一个需求. 一:需求一 1.需求一 可以看某人的权限,同时,可以对这个用户进行权限的修改. 2.程序实现 3.程序目录 4.User.java pac ...
- Web安全漏洞深入分析及其安全编码
摘自:http://blog.nsfocus.net/web-vulnerability-analysis-coding-security/ 超全Web漏洞详解及其对应的安全编码规则,包括:SQL注入 ...