文档章节

hibernate数据库无法获取连接导致系统运行故障

xiaoqqq
 xiaoqqq
发布于 2015/02/27 13:11
字数 441
阅读 25
收藏 0

起因:

某银行上线很久的系统, 每隔一个月左右就会宕机一次。其他同事排查后发现是因为数据库连接超过最大值, 后续用户登陆的时候获取不到连接,导致系统处于假死状态。

问题分析:

出现这种问题基本可以确定是数据库连接泄漏,但是具体是什么原因导致的连接泄漏需要从代码中查找。

排查后

1. 发现web.xml中配置了openSessionInView, 这个配置允许所有线程使用同一个session, 但是 singleSession却是false, 这个配置又不允许所有线程使用同一个session, 这样就相当于没有配置。

<filter>
		<filter-name>hibernateFilter</filter-name>
		<filter-class>
			org.springframework.orm.hibernate3.support.OpenSessionInViewFilter
		</filter-class>
		<init-param>
			<param-name>singleSession</param-name>
			<param-value>false</param-value>
		</init-param>
	</filter>

2. 公共事务中配置了

<prop key="*">PROPAGATION_REQUIRED</prop>
这个配置的作用是 如果当前没有事务,就新建一个事务,如果已经存在一个事务中,加入到这个事务中。
说明不会出现因为没有事务, 而导致的在service中直接调用getCurrentSession()后连接不会自动释放的问题。

3. 部分代码如下:


Session session = this.getHibernateTemplate().getSessionFactory().openSession();



问题就出在这里了, openSession()新开一个hibernate session后, 他是不受spring事务管理的, 必须手动进行关闭, 而项目之所以一个月要重启一次, 就是因为这里的连接没有释放, 导致其他线程无法获取链接。



© 著作权归作者所有

共有 人打赏支持
上一篇: 查外网ip
下一篇: 易语言操作91vpn
xiaoqqq
粉丝 9
博文 50
码字总数 28582
作品 0
渝中
程序员
私信 提问
sql server数据库错误数据恢复-数据库数据恢复

1.服务器硬件设备清单 2.故障描述 需要进行数据恢复的服务器是一台r520型号存储,共有7块SAS硬盘分别组成raid1和raid5两组磁盘阵列。主要sql server数据库存放在C盘中,在使用过程中,客户发...

宋国建
03/27
0
0
风险提醒之Oracle RAC高可用失效

前言 不知不觉,技术人生·我和数据中心的故事来到了第二期,有朋友开始关心小y是谁,这不重要,我们更关心的是技术层面的分享以及给客户带来的实际的风险提示。后续我们还会继续分享中包括操...

DBA小y
2017/07/19
0
0
sql server数据库附加错误 / 数据库无法附加解决过程

故障描述 本案例中涉及一台装有SqlServer数据库的某品牌r520型号的服务器存储,这台存储中又包含有两组磁盘阵列,raid级别都是raid5。正常情况下用户的SqlServer数据库存放在D盘中,后因为数...

宋国建
06/01
0
0
扩展 Hibernate 对各类数据源支持

Hibernate内嵌了对C3P0,Proxool,JNDI数据源等数据库连接池的支持。但当我们需要使用除了这几个数据源外的其他数据源的时 候就有问题了,例如我们需要用Apache的开源连接池项目DBCP,或者说我...

红薯
2008/10/05
1K
0
Oracle常见故障——Listener类:Hang、Crash及连接风暴的判断

目录 监听状态正常,应用反馈时断时连 Listener进程crash ORA-12514 TNS 监听程序当前无法识别连接描述符中请求服务 11G SCAN LISTENER无法注册服务故障 Listener hang TNS-12535 TNS-00505处...

杨志洪 胡杰
2015/12/23
0
0

没有更多内容

加载失败,请刷新页面

加载更多

EOS官方钱包keosd

EOS官方钱包的名称是keosd,它负责管理你的私钥,并且帮你进行交易的签名。 不过不幸的是,keosd钱包对普通用户并不友好,它是一个命令行程序,目前还没有像以太坊的mist那样的图形化界面,而...

汇智网教程
今天
20
0
ArrayList的实现原理以及实现线程安全

一、ArrayList概述 ArrayList是基于数组实现的,是一个动态的数字,可以自动扩容。 ArrayList不是线程安全的,效率比较高,只能用于单线程的环境中,在多线程环境中可以使用Collections.syn...

一看就喷亏的小猿
今天
20
0
Netty 备录 (一)

入职新公司不久,修修补补1个月的bug,来了点实战性的技术---基于netty即时通信 还好之前对socket有所使用及了解,入手netty应该不是很难吧,好吧,的确有点难,刚看这玩意的时候,可能都不知道哪里...

_大侠__
昨天
31
0
Django简单介绍和用户访问流程

Python下有许多款不同的 Web 框架。Django是重量级选手中最有代表性的一位。许多成功的网站和APP都基于Django。 Django是一个开放源代码的Web应用框架,由Python写成。 Django遵守BSD版权,初...

枫叶云
昨天
39
0
Spring Cloud Stream消费失败后的处理策略(四):重新入队(RabbitMQ)

应用场景 之前我们已经通过《Spring Cloud Stream消费失败后的处理策略(一):自动重试》一文介绍了Spring Cloud Stream默认的消息重试功能。本文将介绍RabbitMQ的binder提供的另外一种重试...

程序猿DD
昨天
21
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部