Spring事务传播机制-REQUIRES_NEW

本文探讨了Spring中@Transactional注解在类级别可能导致的事务滥用问题,并重点解析了REQUIRES_NEW的事务传播行为。通过示例展示了如何在多个并发HTTP请求中使用此传播级别,确保每个请求都在独立的事务中执行。

@Transactional
如果加在class上,则默认没个方法都会有起作用、也就是说每个方法都会开启一个事务,包括查询
所以尽量不要加在class上

先看第一个propagation REQUIRES_NEW的用法

/**
     * REQUIRES_NEW 如果该方法update已经开启了老事务,则新事务会被挂起,直到老事务执行完成以后才执行新的事务<br/>
     * 注意: 并不是新事务等着老事务把update方法的所有code都执行完才开始执行新事物的update方法<br/>
     * 因为只有执行到userMapper.update(userParam)才开启事务, 此时才会挂起老的事务
     */
    @Transactional(propagation = Propagation.REQUIRES_NEW)
    @Override
    public Integer update(UserRecord userParam) {
        logger.info("开始执行 update {}, {}", userParam.getId(), userParam.getPhone());
        int result = userMapper.update(userParam);
        try {
            logger.info("update 完成---数据库中的值为 {} 开始 sleep");
            Thread.sleep(1000 * 10);
            logger.info("sleep结束");
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        return result;
    }

测试 执行三个http请求, 每个请求间隔大概2秒钟
http://localhost:9082/coffee.controller/update?phone=15210712345
http://localhost:9082/coffee.controller/update?phone=15210712346
http://localhost:9082/coffee.controller/update?phone=15210712347

2017-12-23 18:15:22 [http-nio-9082-exec-4] INFO  c.c.service.impl.UserServiceImpl2 - 开始执行 update 28, 15210712345
2017-12-23 18:15:22 [http-nio-9082-exec-4] INFO  c.c.service.impl.UserServiceImpl2 - update 完成---数据库中的值为 {} 开始 sleep 
## 执行到这的时候  事务1已经开启了
2017-12-23 18:15:24 [http-nio-9082-exec-6] INFO  c.c.service.impl.UserServiceImpl2 - 开始执行 update 28, 15210712346
## 第二个请求已经到达,注意一下,此时还未开启事务2, 所以update方法的第一行代码 是执行的
## 因为事务1已经开启,所以此时挂起事务2
2017-12-23 18:15:26 [http-nio-9082-exec-5] INFO  c.c.service.impl.UserServiceImpl2 - 开始执行 update 28, 15210712347
## 请求3到达,原理同上
2017-12-23 18:15:32 [http-nio-9082-exec-4] INFO  c.c.service.impl.UserServiceImpl2 - sleep结束
## 此时,事务1已经执行完毕, 这时候轮到事务2了
2017-12-23 18:15:32 [http-nio-9082-exec-6] INFO  c.c.service.impl.UserServiceImpl2 - update 完成---数据库中的值为 {} 开始 sleep
## 事务2执行中
2017-12-23 18:15:42 [http-nio-9082-exec-6] INFO  c.c.service.impl.UserServiceImpl2 - sleep结束
## 事务2执行完毕,接着轮到事务3开始了
2017-12-23 18:15:42 [http-nio-9082-exec-5] INFO  c.c.service.impl.UserServiceImpl2 - update 完成---数据库中的值为 {} 开始 sleep
2017-12-23 18:15:52 [http-nio-9082-exec-5] INFO  c.c.service.impl.UserServiceImpl2 - sleep结束
## 事务三执行完毕
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值