出现小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。
解决方法:我是把主方法中的事物去掉,调用方法的事物不变,形成局部的事物回归。

猜你喜欢

转载自zuimeitulip.iteye.com/blog/1831139