`
zuimeitulip
  • 浏览: 58494 次
  • 性别: Icon_minigender_2
社区版块
存档分类
最新评论

出现小bug,以此警戒

 
阅读更多

异常Transaction rolled back because it has been marked as rollback-only  

 

 
 
今天系统中突然出现了下面这个异常:

org.springframework.transaction.UnexpectedRollbackException: Transaction rolled back because it has been marked as rollback-only。

然后跟踪到代码里面去看了下,伪代码大致如下:
begin transaction;
for(……)
{
    doSomething();//抛出了异常或者明确设置了事务为RollbackOnly
}
commit;
end;

doSomething()伪代码:
try
{
         
begin transaction;
          /**  do anything  */
          commit;
          end;

}
catch()
{
}


分析原因:
这个是一个事务嵌套事务的例子,在spring里面我们配置了
事务的传播机制是REQUIRED,所以这两个事务最终会合并成一个事务。程序中doSomething()中由于某某原因导致抛出异常(或者明确将该事务设置为了RollbackOnly),但是由于其内部已经捕获了这个异常,所以不会影响外面for循环的继续执行,当外面的for循环继续执行完 且准备提交(commit)这个事务时,发现之前这个事务的状态位已经被设置为了RollbackOnly,此时spring就会抛出一个ransaction rolled back because it has been marked as rollback-only。
解决方法:我是把主方法中的事物去掉,调用方法的事物不变,形成局部的事物回归。
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics