最近弄个http服务,传入xml,然后可以执行xml中定义的sql,并且在事务中执行。
本来用了spring的TransactionTemplate写的编程式事务,后来使用下来发现有数据库连接泄漏。。
百思不得其解,居然怀疑了spring的这种事务支持方式是不是会有点问题。于是改成了自己比较熟悉的org.springframework.transaction.interceptor.TransactionProxyFactoryBean
来代理需要有事务支持的类,确保应该没问题。。结果测试下来还是有泄漏。。没调用一次就少一个连接。。。
google了好一会,看到有说spring事务连接泄漏的文章,讲到spring所管理的连接是在当前线程中的
引用IBM developerWorks里面找到的一段
Spring 事务管理高级应用难点剖析: 第 3 部分 写道
Spring DAO 对所有支持的数据访问技术框架都使用模板化技术进行了薄层的封装。只要您的程序都使用 Spring DAO 模板(如 JdbcTemplate、HibernateTemplate 等)进行数据访问,一定不会存在数据连接泄漏的问题 ―― 这是 Spring 给予我们郑重的承诺!因此,我们无需关注数据连接(Connection)及其衍生品(Hibernate 的 Session 等)的获取和释放的操作,模板类已经通过其内部流程替我们完成了,且对开发者是透明的。
但是由于集成第三方产品,整合遗产代码等原因,可能需要直接访问数据源或直接获取数据连接及其衍生品。这时,如果使用不当,就可能在无意中创造出一个魔鬼般的连接泄漏问题
。
我们知道:当 Spring 事务方法运行时,就产生一个事务上下文,该上下文在本事务执行线程中针对同一个数据源绑定了一个唯一的数据连接(或其衍生品),所有被该事务上下文传播的方法都共享这个数据连接。这个数据连接从数据源获取及返回给数据源都在 Spring 掌控之中,不会发生问题。如果在需要数据连接时,能够获取这个被 Spring 管控的数据连接,则使用者可以放心使用,无需关注连接释放的问题。
于是我看了下自己代码。。。发现在刚调用进来时候,我会有个判断当前数据库类型的操作,是为了如果是oracle,需要alter session一下,问题就出在这个判断当前数据库类型的地方:
if(jt.getDataSource().getConnection().getMetaData().getDriverName().toLowerCase().indexOf("oracle")>=0){
这里从JdbcTemplate里面获取一个数据库的Connection,而这个connection不在spring的管理范围内。。
所以这里的这个connection需要手动释放,这样就没有问题了。
分享到:
相关推荐
Potential resource leak in DataSourceUtils.doGetConnection [SPR-17559] #22091 SpEL, error parsing big InlineMap [SPR-17605] #22137 @Value Optional<...> field injection fails in case of registered ...
**AngularJS内存泄漏问题在IE8中的测试** 在前端开发中,AngularJS是一个非常流行的JavaScript框架,用于构建交互式和动态的Web应用。然而,由于AngularJS的设计特性,尤其是在旧版浏览器如Internet Explorer 8(IE...
《Visual Leak Detector 2.23:高效精准的内存泄漏检测利器》 在软件开发过程中,内存泄漏是一个常见的问题,它可能导致程序性能下降,甚至崩溃。为了确保软件的稳定性和可靠性,开发者需要对内存泄漏进行有效的...
visual leak detector 2.2 VS2010 VS2008检测内存泄露
Potential resource leak in DataSourceUtils.doGetConnection [SPR-17559] #22091 HibernateTransactionManager (unintentionally) bound to Hibernate 5.2 SharedSessionContractImplementor [SPR-17557] #22089 ...
【Visual Leak】是一款专为C++开发者设计的内存检测工具,它的主要功能是帮助程序员定位并修复程序中的内存泄漏问题。内存泄漏是编程中常见的错误,尤其是在动态内存管理较为复杂的C++环境中,它可能导致程序运行...
java
**Visual Leak Detector V2.0** 是一款专为开发者设计的高效内存泄漏检测工具,尤其适用于使用Microsoft Visual Studio开发C++应用程序的环境。这个工具的主要目的是帮助程序员在软件开发过程中定位并消除内存泄漏...
【标题】"leak_detector_c" 是一个针对C语言编程的内存泄漏检测工具,它包含两个C++源文件和一个头文件。这个工具的核心目的是帮助程序员跟踪和管理内存分配,以便更好地防止内存泄漏问题。 【描述】中提到,"leak_...
This program is a tool that help you positioning memory leak locations of an QUALCOMM BREW application on simulator. It can give the call stack of memory leaks (including the locations that MALLOC/...
Visual Leak Detector是一款强大的内存泄漏检测工具,专为C++开发者设计,用于帮助找出程序中的内存泄漏问题。内存泄漏是编程中常见的错误,当程序分配了内存但未能正确释放时,就会发生内存泄漏,长时间运行可能...
Leak_monitor for Firefox 4.0-18
VLD 内存泄露检测工具 Visual Leak Detector 2.3.0
Visual Leak Detector,防止C++内存泄露的工具,解压后将.h文件拷贝到VC的默认include目录下,将.lib文件拷贝到VC默认的lib目录下。 使用方法:只要在包含入口函数(比如main()函数)的.cpp中包含vld.h就可以了...
本文将详细介绍如何利用Xcode内置的Leak工具来检测和解决内存泄漏。 Leak是Xcode性能工具套件的一部分,它可以帮助开发者识别程序中未释放的内存块。以下是使用Leak工具检查内存泄漏的步骤: 1. 首先,在Xcode的...
内存泄漏是程序在申请内存后,无法释放已申请的内存空间,一次小的内存泄漏可能看似无足轻重,但随着时间推移,大量的内存泄漏会消耗掉系统可用内存,导致性能下降甚至系统崩溃。在C++编程中,由于手动管理内存的...
Visual Leak Detector for Visual C++ 是一个专为C++开发者设计的工具,用于检测和定位内存泄漏问题。在C++编程中,内存管理是程序员的重要职责,而内存泄漏往往是导致程序性能下降甚至崩溃的关键因素。Visual Leak ...
**BREW Memory Leak Checker** 是一个专为BREW(Binary Runtime Environment for Wireless)平台设计的工具,用于检测和定位BREW应用程序中的内存泄漏问题。在移动设备开发中,内存管理是至关重要的,因为有限的资源...
leak monitorleak monitor leak monitor leak monitor leak monitor leak monitor