中了一个事务的问题

概述


昨晚2021年2月22日功能上线的时候,故障群里突然大面积保障,订单无法展示了。由于影响范围比较广,立刻让运维把服务回滚回去,10分钟后,故障消失了。

接下来开始找故障的根因,最后发现原来是事务问题导致,日志里提示了如下一个错误:

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

意思是,准备提交事务,将落地的数据库数据生效时,事务已经被设置为rollback-only了,无法提交事务。后面仔细看了一下代码,原来是开了事务的方法里,抛了一个异常,但是程序把这个异常给catch住了,没往上抛。

   @Transactional(rollbackFor = Exception.class)
    public void open() {
      try{
         //这里某段代码抛异常了,但是被catch住了。
      }
      catch(Exception e) {
      }
      
      //其他业务逻辑代码
    }

这个open方法里的某段代码抛出异常了,这里Spring已经将事务设置为rollback-only了,但是由于异常被catch住了,当线程执行完open方法后,就会开始提交事务,然后发现压根无法提交事务。

这里有个教训:

业务逻辑必须是一个事务,一起生一起死的,就放在一块,否则将对应的代码移到事务外。


小结


有时候你可能是想通过catch异常的方式,保护主流程代码,但是由于事务问题,好心做坏事了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值