文档章节

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

xiaoqqq
 xiaoqqq
发布于 2015/02/27 13:11
字数 441
阅读 24
收藏 0
点赞 0
评论 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事务管理的, 必须手动进行关闭, 而项目之所以一个月要重启一次, 就是因为这里的连接没有释放, 导致其他线程无法获取链接。



© 著作权归作者所有

共有 人打赏支持
xiaoqqq
粉丝 9
博文 49
码字总数 28582
作品 0
渝中
程序员
sql server数据库错误数据恢复-数据库数据恢复

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

宋国建 ⋅ 03/27 ⋅ 0

风险提醒之Oracle RAC高可用失效

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

DBA小y ⋅ 2017/07/19 ⋅ 0

应用不停的获取数据库连接导致数据库挂掉

各位大牛们好,请教个问题,困扰几天了,救命。。。 环境:spring4.1.1+spring mvc+hibernate4.3.7,oracle11数据库,连接池druid1.0.20,fastjson1.1.34,服务器CentOS release 6.7 (Final...

CALY_浮生 ⋅ 2017/04/05 ⋅ 6

sql server数据库附加错误 / 数据库无法附加解决过程

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

宋国建 ⋅ 06/01 ⋅ 0

扩展 Hibernate 对各类数据源支持

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

红薯 ⋅ 2008/10/05 ⋅ 0

Hibernate学习笔记8,session管理,事务控制

Hibernate学习笔记8,session管理,事务控制 Hibernate的事务管理 事务(Transaction)是工作中的基本逻辑单位,可以用于确保数据库能够被正确修改,避免数据只修改了一部分而导致数据不完整...

优惠券发放 ⋅ 05/03 ⋅ 0

Oracle常见故障——Listener类:Hang、Crash及连接风暴的判断

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

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

tomcat性能优化

在Tomcat和应用程序进行了压力测试后,如果您对应用程序的性能结果不太满意,就可以采取一些性能调整措施了,当然了前提是应用程序没有问题,我们这里只讲Tomcat的调整。由于Tomcat的运行依赖...

凯文加内特 ⋅ 2014/02/11 ⋅ 0

hibernate学习笔记:hibernate中的Cache管理

Hibernate 中实现了良好的Cache 机制,我们可以借助Hibernate 内部的Cache迅速提高系统数据读取性能。 需要注意的是:Hibernate做为一个应用级的数据访问层封装,只能在其作用范围内保持Cac...

crazyinsomnia ⋅ 2010/01/10 ⋅ 0

可用性高达五个9!支付系统高可用架构设计实战

对于互联网应用和企业大型应用而言,多数都尽可能地要求做到7*24小时不间断运行,而要做到完全的不间断运行可以说“难于上青天”。 为此,对应用的可用性程度一般衡量标准有三个9到五个9。 ...

vshcxl ⋅ 2016/12/12 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

mysql in action / alter table

change character set ALTER SCHEMA `employees` DEFAULT CHARACTER SET utf8mb4 DEFAULT COLLATE utf8mb4_general_ci ;ALTER TABLE `employees`.`t2` CHARACTER SET = utf8mb4 , COLLAT......

qwfys ⋅ 今天 ⋅ 0

Java 开发者不容错过的 12 种高效工具

Java 开发者常常都会想办法如何更快地编写 Java 代码,让编程变得更加轻松。目前,市面上涌现出越来越多的高效编程工具。所以,以下总结了一系列工具列表,其中包含了大多数开发人员已经使用...

jason_kiss ⋅ 昨天 ⋅ 0

Linux下php访问远程ms sqlserver

1、安装freetds(略,安装在/opt/local/freetds 下) 2、cd /path/to/php-5.6.36/ 进入PHP源码目录 3、cd ext/mssql进入MSSQL模块源码目录 4、/opt/php/bin/phpize生成编译配置文件 5、 . ./...

wangxuwei ⋅ 昨天 ⋅ 0

如何成为技术专家

文章来源于 -- 时间的朋友 拥有良好的心态。首先要有空杯心态,用欣赏的眼光发现并学习别人的长处,包括但不限于工具的使用,工作方法,解决问题以及规划未来的能力等。向别人学习的同时要注...

长安一梦 ⋅ 昨天 ⋅ 0

Linux vmstat命令实战详解

vmstat命令是最常见的Linux/Unix监控工具,可以展现给定时间间隔的服务器的状态值,包括服务器的CPU使用率,内存使用,虚拟内存交换情况,IO读写情况。这个命令是我查看Linux/Unix最喜爱的命令...

刘祖鹏 ⋅ 昨天 ⋅ 0

MySQL

查看表相关命令 - 查看表结构    desc 表名- 查看生成表的SQL    show create table 表名- 查看索引    show index from  表名 使用索引和不使用索引 由于索引是专门用于加...

stars永恒 ⋅ 昨天 ⋅ 0

easyui学习笔记

EasyUI常用控件禁用方法 combobox $("#id").combobox({ disabled: true }); ----- $("#id").combobox({ disabled: false}); validatebox $("#id").attr("readonly", true); ----- $("#id").r......

miaojiangmin ⋅ 昨天 ⋅ 0

金山WPS发布了Linux WPS Office

导读 近日,金山WPS发布了Linux WPS Office中文社区版新版本,支持大部分主流Linux系统,功能更加完善,兼容性、稳定性大幅度提升。本次更新WPS将首次在Linux提供专业办公文件云存储服务,实...

问题终结者 ⋅ 昨天 ⋅ 0

springboot2输出metrics到influxdb

序 本文主要研究一下如何将springboot2的metrics输出到influxdb maven <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-bo......

go4it ⋅ 昨天 ⋅ 0

微信小程序 - 选择图片显示操作菜单

之前我分享过选择图片这个文章,但是我在实际开发测试使用中发现一个问题在使用 wx.chooseImage 选择照片显示出第一格是拍照,后面是相册里的图片。这种实现之前说过了,效果如下。 但是你从...

hello_hp ⋅ 昨天 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部