`

一次web应用没有响应的原因分析

阅读更多
前几天,我们应用中遇到一个问题,在发布之后运行很短时间内某些页面就没有响应了。

开始没太当回事,因为环境的原因,从数据库查询数据缓慢是有可能的。但后来发现数据库空闲的时候仍然这样。

1、首先,分析可能的原因是页面的组件没获取到导致数据没有展示,因为组件是从另一台server获取的,早先出现过这样的情况。随后查看firebug,网络通信一切正常,前台组件也没有报错。

2、其次,有可能是JVM的垃圾回收一直在进行。因为程序中有部分模块定时从数据库查询数据。所以使用visualvm查看,如下图所示,jvm的perm和堆都正常,线程也正常。

3、再次,从visualvm中将线程日志dump出来,发现七八处这样的。是业务逻辑对应的代码正在执行过程中,一看堆栈,怀疑应该是连接池中连接耗光了,获取新的连接去了。而且阻塞在获取连接上了。

"http-8086-9" - Thread t@233
   java.lang.Thread.State: WAITING
     at java.lang.Object.wait(Native Method)
     - waiting on <3c74e871> (a com.mchange.v2.resourcepool.BasicResourcePool)
     at com.mchange.v2.resourcepool.BasicResourcePool.awaitAcquire(BasicResourcePool.java:966)
     at com.mchange.v2.resourcepool.BasicResourcePool.checkoutResource(BasicResourcePool.java:208)
     at com.mchange.v2.c3p0.impl.C3P0PooledConnectionPool.checkoutPooledConnection(C3P0PooledConnectionPool.java:232)
     at com.mchange.v2.c3p0.PoolBackedDataSource.getConnection(PoolBackedDataSource.java:94)
     at com.mchange.v2.c3p0.ComboPooledDataSource.getConnection(ComboPooledDataSource.java:521)
     at org.springframework.orm.hibernate3.LocalDataSourceConnectionProvider.getConnection(LocalDataSourceConnectionProvider.java:81)
     at org.hibernate.jdbc.ConnectionManager.openConnection(ConnectionManager.java:446)
     at org.hibernate.jdbc.ConnectionManager.getConnection(ConnectionManager.java:167)
     at org.hibernate.jdbc.JDBCContext.connection(JDBCContext.java:160)
     at org.hibernate.transaction.JDBCTransaction.begin(JDBCTransaction.java:81)
     at org.hibernate.impl.SessionImpl.beginTransaction(SessionImpl.java:1473)
     at org.springframework.orm.hibernate3.HibernateTransactionManager.doBegin(HibernateTransactionManager.java:555)
     at org.springframework.transaction.support.AbstractPlatformTransactionManager.getTransaction(AbstractPlatformTransactionManager.java:371)
     at org.springframework.transaction.interceptor.TransactionAspectSupport.createTransactionIfNecessary(TransactionAspectSupport.java:334)
     at org.springframework.transaction.interceptor.TransactionInterceptor.invoke(TransactionInterceptor.java:105)
     at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:172)
     at org.springframework.aop.framework.JdkDynamicAopProxy.invoke(JdkDynamicAopProxy.java:202)



首先看了c3p0的源码,发现确实是在获取新的数据库连接。遂建议同事将c3p0的日志放开。

但同事怀疑我定期从数据库查询数据然后写入缓存的ReadWriteLock控制有问题。对这块我相对有信心,因为本身就是最经典的读写锁控制,而且从线程堆栈看,并没有发生线程死锁。

最后要求同事将c3p0的日志放开,最后发现部分操作导致c3p0管理的连接数量不断上涨。

原来是有数据库连接没有被正常释放!


程序重度依赖spring,事务使用spring管理的,dao层大量使用hibernateTemplate进行简单的查询操作,部分复杂的场景使用了jdbcTemplate,按道理这些部分都不会出现问题,普通的操作在结束之后都被spring接管了,事务该提交或回滚,连接也被释放(因为使用连接池,所以不是关闭)。

唯一的可能就是,有人自己获取了连接或者新建了会话,通过搜索,发现果然有一处代码是这样的,

先从hibernateTemplate获取到sessionFactory,然后openSession,执行一个复杂的原生sql查询,然后方法就结束了。

这肯定是有问题的,session没有关闭,数据库连接也就没有释放。

然后将此处改为使用jdbcTemplate执行查询,提交发布,连接数量稳定了,搞定。


总结:

1、hibernate进行复杂的查询很不方便,无论是HQL还是Criteria;
2、使用spring时,可考虑使用jdbcTemplate代替hibernate执行原生sql操作,优点是:方便,清晰、不用考虑session;
3、编码规范很重要;
4、性能测试必须得做

  • 大小: 71.6 KB
  • 大小: 36.2 KB
分享到:
评论

相关推荐

    go web编程

    6.3.7 一次获取多篇帖子 146 6.4 Go与SQL的关系 147 6.4.1 设置数据库 147 6.4.2 一对多关系 150 6.5 Go与关系映射器 152 6.5.1 Sqlx 152 6.5.2 Gorm 154 6.6 小结 157 第三部分 ...

    计算机专业毕设精选-ASP.NET基于WEB的工作计划统计分析系统的设计与实现(源代码+论文).rar

    1. ASP.NET技术:本项目基于ASP.NET框架进行开发,利用其强大的Web开发能力和丰富的控件库,实现了高效、稳定的Web应用程序。 2. ADO.NET数据库访问技术:系统通过ADO.NET技术连接和操作数据库,实现了数据的增删改...

    Web应用安全:Burpsuite重放模块介绍.pptx

    Burpsuite重放模块介绍 1 Burpsuite重放模块的介绍 目录 2 使用Burpsuite重放模块实现一个CTF flag的获取 重放模块的介绍 ...使用burpsuite的重放功能完成一次CTF的flag获取,本次我们选用/的站点。 Burpsui

    HTTP协议分析报告

    第三帧是web客户端(即浏览器,源IP地址为192.168.0.250)发给web服务器端(目标IP地址为218.65.113.46)的TCP连接的第一次握手(SYN)。第四帧是web服务器端与web客户端的TCP连接的第二次握手(SYN,ACK)。第五帧...

    工程硕士学位论文 基于Android+HTML5的移动Web项目高效开发探究

    SSH 为 Struts+Spring+Hibernate的一个集成框架,是目前较流行的一种Web应用程序开源框架。其中使用Struts作为系统的整体基础架构,负责MVC的分离,在Struts框架的模型部分,控制业务跳转,利用Hibernate框架对持久...

    [完整][中文][WEB安全测试].(美)霍普.扫描版.pdf

     本书中的秘诀所覆盖的基础知识包括了从观察客户端和服务器之间的消息到使用脚本完成登录并执行Web应用功能的多阶段测试。在本书的最后,你将能够建立精确定位到Ajax函数的测试,以及适用于常见怀疑对象(跨站式脚本...

    计算机网络实验报告-实验11

    从你的主机多次访问淘宝网站Web服务器 结束捕获并分析 1、在Wireshark中捕获一对 HTTP请求 和 HTTP响应数据包,截图显示。 2、cookie 头部信息在HTTP请求 还是 HTTP响应数据包中? 内容是什么?有什么作用? 实验...

    实战Nginx:取代Apache的高性能Web服务器

    第3部分为实战篇,分析了Nginx在国内知名网站(如新浪播客、搜狐博客等)中的应用案例;第4部分为模块篇,对Nginx的基本模块和第三方模块进行了集中介绍。  本书是为对配置管理Nginx服务器感兴趣的读者准备的,...

    Road-Pulse:智能视频分析应用

    Road-Pulse Web 应用程序 Road Pulse 是一种现代解决方案,可改善交通管理并为公众恢复法律法规。 由于违反交通规则是当前的一个关键且日益严重的问题。 因此,这样的系统可以帮助执法部门实时跟踪此类事件并做出...

    goaccess:GoAccess是实时Web日志分析器和交互式查看器,可在* nix系统的终端中或通过浏览器运行

    功能包括: 完全实时所有面板和指标的时间安排为在终端输出上每200 ms更新一次,在HTML输出上每秒钟更新一次。 所需的最低配置您可以仅对访问日志文件运行它,选择日志格式,然后让GoAccess解析访问日志并向您显示...

    从零开始设计并构建“金科云盾”网站防护系统(全国云计算应用创新大赛一等奖作品),使用Nginx实现反向代理,负载均衡,统一日志

    通过脚本,每半分钟“巡逻”一次,让模型对数据实时地进行识别预测,得到识别结果并用Kibana可视化展示。针对实时的识别结果立即给于封杀IP、形成黑名单。在给出防御措施后,需及时存储相关防御日志,要求详细可溯源...

    loadrunner测试资料

     webload是RadView公司推出的一个性能测试和分析工具,它让web应用程序开发者自动执行压力测试;webload通过模拟真实用户的操作, 生成压力负载来测试web的性能。用户创建的是基于javascript的测试脚本,称为议程agenda...

    超级有影响力霸气的Java面试题大全文档

    当客户机第一次调用一个Stateful Session Bean 时,容器必须立即在服务器中创建一个新的Bean实例,并关联到客户机上,以后此客户机调用Stateful Session Bean 的方法时容器会把调用分派到与此客户机相关联的Bean实例...

    网络安全期末复习题及答案解析.doc

    假如你向一台远程主机发送特定的数据包,却不想远程主机响应你的数据包。这时你 使用哪一种类型的进攻手段?( B ) A、缓冲区溢出 B、地址欺骗 C、拒绝服务 D、暴力攻击 12. 小李在使用super scan对目标网络进行扫描...

    asp.net知识库

    ASP.NET 2.0构建动态导航的Web应用程序(TreeView和Menu ) 体验.net2.0的优雅(3) -- 为您的 SiteMap 添加 控制转发功能 GridView控件使用经验 ASP.NET 2.0:弃用 DataGrid 吧,有新的网格控件了! ASP.NET2.0控件...

    Java毕业设计-基于ssm框架开发的学生竞赛模拟系统-附毕设源代码+说明文档.rar

    它展示了如何运用SSM框架构建一个功能完善、性能优良的Web应用。同时,该系统也预留了丰富的扩展接口,可以根据实际需求进行二次开发与定制,满足不同场景下的应用需求。 总之,“基于SSM框架开发的学生竞赛模拟...

    实战Nginx.取代Apache的高性能Web服务器.2010 pdf

    第3部分为实战篇,分析了Nginx在国内知名网站(如新浪播客、搜狐博客等)中的应用案例;第4部分为模块篇,对Nginx的基本模块和第三方模块进行了集中介绍。  本书是为对配置管理Nginx服务器感兴趣的读者准备的,适用...

    用户层和传输层协议分析指导书

    然后,请求端获得服务端第一个响应封包之后,必须再响应对方一个确认封包,此时封包只带 ACK旗标(事实上,后继联机中的所有封包都必须带有 ACK 旗标); 只有当服务端收到请求端的确认( ACK )封包(也就是整个...

    网络安全协议(PPT-146页).pptx

    SYN, SEQ = x 主机 B SYN, ACK, SEQ = y, ACK= x 1 ACK, SEQ = x + 1, ACK = y 1 确认 确认 主机 A 连接请求 11 TCP安全缺陷-没有任何认证机制 TCP会话劫持 所谓会话,就是两台主机之间的一次通讯。 例如Telnet到...

    软件系统整体设计方案.docx

    拟制 绿网天下(福建)网络科技股份有限公司 修改记录 文件编号 版本号 拟制人/ 修改人 拟制/ 修改日期 更改理由 主要更改内容 (写要点即可) V1.0 蔡顺德 2016.01.12 初稿 注:文件第一次拟制时,"更改理由"、"主要...

Global site tag (gtag.js) - Google Analytics