Windows平台下tomcat+java的web程序持续占cpu问题调试

1、问题

Tomcat服务器跑了一段时间后,发现Tomcat进程占用的CPU资源在80%-100%间,加上其它的进程,整个服务器的CPU处理100%运行状态。

2、通过process explorer查看Tomcat进程下的线程

process explorer下载:https://technet.microsoft.com/en-us/sysinternals/bb896653/
我使用的是汉化后的版本:http://download.csdn.net/detail/p_3er/9169985

下载后直接打开就可以了。

这里写图片描述

点开tomcat进程:

这里写图片描述
这时候发现6596、12200两个TID线程占用CPU最高。
下面我们要找到这两个线程在我们程序中的位置。

3、通过jstack把进程下所以的Java线程栈的内容打印出文本中。

如我们的Tomcat进程PID为900。

jstack -l 900  > c:/java.stack

注:通过tomcat的windows服务启动的tomcat是无法使用此命令获取线程栈的内容(如下图),必须通过startup.bat来启动。

这里写图片描述

4、分析stack文本

打开c:/java.stack文件。
这里写图片描述

通过process explorer获取到的线程TID对应的是stack文本线程栈描述内容中的nid的十进制值。

我们把TID为6596转成十六进制为19c4,然后根据19c4在stack文本中找到此线程栈的描述内容为:

这里写图片描述

根据描述,我们可以看到,此线程是处理到了SocketThread类的91行处。

这里写图片描述

91行代码是线程下的socket在阻塞状态下等待读取客户端发送过来的数据。

后面几个TID线程也是同样的问题。

5、解决

经分析+谷哥+度娘后,socket服务器每与一个客户连接都产生一条线程来处理事务的做法比较耗资源。
使用用NIO非阻塞的方式重写了socket后,问题得到解决。

本课程详细讲解了以下内容:    1.jsp环境搭建及入门、虚拟路径和虚拟主机、JSP执行流程    2.使用Eclipse快速开发JSP、编码问题、JSP页面元素以及request对象、使用request对象实现注册示例    3.请求方式的编码问题、response、请求转发和重定向、cookie、session执行机制、session共享问题     4.session与cookie问题及application、cookie补充说明及四种范围对象作用域     5.JDBC原理及使用Statement访问数据库、使用JDBC切换数据库以及PreparedStatement的使用、Statement与PreparedStatement的区别     6.JDBC调用存储过程和存储函数、JDBC处理大文本CLOB及二进制BLOB类型数据     7.JSP访问数据库、JavaBean(封装数据和封装业务逻辑)     8.MVC模式与Servlet执行流程、Servlet25与Servlet30的使用、ServletAPI详解与源码分析     9.MVC案例、三层架构详解、乱码问题以及三层代码流程解析、完善Service和Dao、完善View、优化用户体验、优化三层(加入接口和DBUtil)    1 0.Web调试及bug修复、分页SQL(Oracle、MySQL、SQLSERVER)     11.分页业务逻辑层和数据访问层Service、Dao、分页表示层Jsp、Servlet     12.文件上传及注意问题、控制文件上传类型和大小、下载、各浏览器下载乱码问题     13.EL表达式语法、点操作符和中括号操作符、EL运算、隐式对象、JSTL基础及set、out、remove     14.过滤器、过滤器通配符、过滤器链、监听器     15.session绑定解绑、钝化活化     16.以及Ajax的各种应用     17. Idea环境下的Java Web开发
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值