spring事务注解中timeout配置

本文揭示了Spring事务超时设置的潜在误区,指出事务超时从开始到最后一个Statement创建的时间加上Statement执行时间。当设置@Transactional(timeout=1)时,期望事务在1秒内完成。然而,案例分析表明,如果查询数据库后有高耗时操作,如case2所示,可能不会触发事务超时异常,导致事务执行时间超出预期。因此,建议避免在事务方法中在数据库查询后进行长时间运行的操作。
摘要由CSDN通过智能技术生成

要点
Spring事务超时 = 事务开始 到 最后一个Statement创建之间的时间 + 最后一个Statement的执行的时间(即其queryTimeout)


设置@Transactional(timout = 1)时,希望是当前方法在一个事务中,且事务执行时间应小于1秒中,若超过1秒则应抛出异常:
 Transaction timed out: deadline was Mon Jul 05 00:02:18 CST 2021

但这其中有一个坑:

  • case1: 抛出Transaction timed out 异常
    @Transactional(timeout = 1)
    public List<ResourceEntity> findAll2() throws InterruptedException {
        TimeUnit.SECONDS.sleep(2);
        List<ResourceEntity> resourceEntities = resourceMapper.rangeQueryResources(1, 20);
        return resourceEntities;
    }
  • case2: 不会抛出 Transaction timed out 异常
    @Transactional(timeout = 1)
    public List<ResourceEntity> findAll3() throws InterruptedException {
        List<ResourceEntity> resourceEntities = resourceMapper.rangeQueryResources(1, 20);
        TimeUnit.SECONDS.sleep(2);
        return resourceEntities;
    }

case2可能导致代码中的坑,所以在一个事务方法中,在查询数据库之后不要有耗时过高的操作

具体分析可参考:
Spring事务超时时间可能存在的错误认识

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值