druid + spring 事务 + removeAbandonedTimeout 超时回收导致的问题
今天使用上述组合 做项目。。
在做一个需要较长时间使用数据库的 请求时,项目日志没有任何报错,但是数据库也没有插入代码。
初步猜测是 数据库连接超过 removeAbandonedTimeout 时间导致数据库连接被强制回收,但是为什么没有报错呢(由于开发环境数据较少,没有这个现象,
但是生产环境数据较多,当时数据也没插入成功,日志也没报错,一脸懵)。。
没办法,只有在开发模拟数据,然后跟踪代码,超时时间到后,会走到这么一段代码:
try {
                // This is an around advice: Invoke the next interceptor in the chain.
                // This will normally result in a target object being invoked.
                retVal = invocation.proceedWithInvocation();
            }
            catch (Throwable ex) {
                // target invocation exception
                completeTransactionAfterThrowing(txInfo, ex);
                throw ex;
            }
            finally {
                cleanupTransactionInfo(txInfo);
            }
进入 catch 中 执行
completeTransactionAfterThrowing(txInfo, ex); (看方法名:事务完成后抛出错误)
if (txInfo != null && txInfo.hasTransaction()) {
            if (logger.isTraceEnabled()) {
                logger.trace("Completing transaction for [" + txInfo.getJoinpointIdentification() +
                        "] after exception: " + ex);
            }   // 这个ex 就是我们要的错误信息,但是这里的日志级别却是 trace ,无语啊。。我<logger name="org.springframework" level="error"/>是error ,,好吧,日志是打印不出来。。靠
if (txInfo.transactionAttribute.rollbackOn(ex)) { 
  
   try { txInfo.getTransactionManager().rollback(txInfo.getTransactionStatus()); } 
catch (TransactionSystemException ex2) {
   logger.error("Application exception overridden by rollback exception", ex); ex2.initApplicationException(ex); throw ex2; 
}
druid + spring 事务 + removeAbandonedTimeout 超时回收导致的问题的更多相关文章
- 使用druid连接池的超时回收机制排查连接泄露问题
		
在工程中使用了druid连接池,运行一段时间后系统出现异常: Caused by: org.springframework.jdbc.CannotGetJdbcConnectionException: ...
 - 使用druid连接池的超时回收机制排查连接泄露
		
起因:系统连接池满了 Exception wait millis 60012, active 2000, maxActive 2000, creating 0 加配置排查: <!-- 超过时间限 ...
 - 一文搞定 Spring事务
		
Spring 事务 上文 使用SpringJDBC 1.JDBC事务控制  不管你现在使用的是那一种ORM开发框架,只要你的核心是JDBC,那么所有的事务处理都是围绕着JDBC开展的,而JDBC之中 ...
 - Spring(二十二):Spring 事务
		
事务简介: 事务管理是企业级应用程序开发中必不可少的技术,用来确保数据的完整性和一致性. 事务就是一系列的动作,它们被当做一个单独的工作单元.这些动作要么全部完成,要么全部不起作用. 事务的是四个关键 ...
 - 【转】Spring事务超时时间可能存在的错误认识
		
1.先看代码 1.1.spring-config.xml <bean id="dataSource" class="org.springframework.jdbc ...
 - Spring事务超时、回滚的相关说明
		
事务超时: @Transactional(timeout = 60) 如果用这个注解描述一个方法的话,线程已经跑到方法里面,如果已经过去60秒了还没跑完这个方法并且线程在这个方法中的后面还有涉及到对数 ...
 - Spring事务超时时间可能存在的错误认识
		
摘自:http://jinnianshilongnian.iteye.com/blog/1986023, 感谢作者. 1.先看代码 1.1.spring-config.xml <bean id= ...
 - Spring事务隔离级别与传播机制详解,spring+mybatis+atomikos实现分布式事务管理
		
原创说明:本文为本人原创作品,绝非他处转载,转账请注明出处 1.事务的定义:事务是指多个操作单元组成的合集,多个单元操作是整体不可分割的,要么都操作不成功,要么都成功.其必须遵循四个原则(ACID). ...
 - Spring 使用介绍(七)—— Spring事务
		
一.数据库事务概述 1.基本介绍 事务必需满足ACID(原子性.一致性.隔离性和持久性)特性,缺一不可: 原子性(Atomicity):即事务是不可分割的最小工作单元,事务内的操作要么全做,要么全不做 ...
 
随机推荐
- 阿里云 配置ssl 在nginx上
			
写给自己的备忘录: 很乱 如果你也是 配置nginx ssl 可以给我留言 ,我是为了 捣鼓微信小程序后台 需要https 阿里云有免费一年的 ssl服务 链接 https://www.aliyun. ...
 - JAVA Maven 安装 jar 包到本地仓库,以 Oracle11g 的访问包 为例
			
maven 作为 java 的首选包管理工具,使我们在创建和维护项目的时候变得十分简单,但是 maven 仓库并不是拥有的一切 jar 包的, 很多 jar 包由于收费或者版权什么的其他原因,并不存在 ...
 - leetcode4
			
public class Solution { public double FindMedianSortedArrays(int[] nums1, int[] nums2) { var nums = ...
 - Python 程序下载经办人照片
			
进行图片下载,需要提前准备好下载图片的存放文件夹: python在与文件.目录打交道时,少不了os模块.os模块包含普遍的操作系统功能. os.path.exists(filepath)——检验指定的 ...
 - GIL计算python 2 和 python 3 计算密集型
			
首先我画了一张图来表示GIL运行的方式: Python 3执行如下计算代码:#-*-conding:utf-8-*-import threading import timedef add(): n = ...
 - js 模拟css3 动画1
			
<html> <head> <title> javaScript缓动入门 </title> </head> <body> < ...
 - jmeter 的安装与配置
			
环境配置: 操作系统:win10 JDK:1.8 jmeter:5.0 jmeter 是 java 程序.所以要运行 jmeter 需要先安装配置 jdk. 1.安装配置 jdk 官方网站下载 jdk ...
 - suse linux安装lrzsz
			
1.从下面的网站下载 lrzsz-1.12.20.tar.gz http://www.filewatcher.com/m/lrzsz-0.12.20.tar.gz.280938.0.0.html 2. ...
 - springboot+mybatis+freemark+oauth开发环境搭建
			
一.创建springboot工程 1.环境介绍: a:jdk版本:1.7 b:Springboot版本:1.5.6(使用1.5.9的版本整合mybatis会报错:java.lang.NoClassDe ...
 - Linux命令行报错 bash: cannot create temp file for here-document: No space left on device
			
今天Linux服务器出问题了,使用"tab"补全命令时,提示 bash: cannot create temp file for here-document: No space l ...