Spring @transactional注解和synchronized同时使用出现的并发问题(可重复读问题)和解决办法

主要原因:事务范围大于锁

@Override
@Transactional
public synchronized CouponsH5Respons getACoupons() {
 		.....
}

用jmeter进行压力测试的时候,发现优惠券超发
当时很疑惑,synchronized已经放在了方法级别,不应该出现并发的问题

正常情况

  • 每个线程的事物都是不同的,T1修改后commit T2读取到新数据

超发场景

  • 出现超发的情况,T2 读取到了旧数据
  • 可以分析出T2在T1没commit之前读取的数据,因为两者在不同事务,T2读取的一定是旧数据
  • 从而分析出synchronized没生效

问题原因(事务范围大于锁)

  • 因为spring的AOP的特性,会在进入方法之前开启事务,之后再加锁,当锁住的代码执行完成后,再提交事务,如果在T1执行commit之前 有其他线程进来,读取的一定是旧数据

如下图:
同步代码块是在事务的内部

在这里插入图片描述

解决方式:
将synchronized关键字加入到Controller层,使synchronized锁的范围大于事务控制的范围。
目的是让同步代码在事务的外面

Object mLock = new Object();
@RequestMapping(value = "test")
@ResponseBody
public void test() throws Exception {
    synchronized (mLock) {
       service.test();
    }
    responseMessage(ModelResult.CODE_200,ModelResult.SUCCESS);
}
  • 5
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 8
    评论
回答: 要使用@Transactional注解和@EnableTransactionManagement注解,首先需要在Spring配置文件中配置事务管理器。然后,在需要进行事务管理的类或方法上添加@Transactional注解。@Transactional注解可以应用在类级别或方法级别,用于标识需要进行事务管理的代码。当代码执行到被@Transactional注解标识的方法时,Spring会自动开启一个事务,并在方法执行完毕后根据事务的执行结果进行提交或回滚。@EnableTransactionManagement注解则用于启用Spring的事务管理功能,通常在配置类上添加该注解。它会扫描带有@Transactional注解的类或方法,并为其创建代理对象,实现事务的管理。\[1\] 具体实现中,AnnotationTransactionAttributeSource类用于解析@Transactional注解,获取事务的属性信息。TransactionAspectSupport类中的commitTransactionAfterReturning方法则是事务提交的相关处理,它会根据事务的状态进行提交操作。\[2\] 另外,还有一些与事务相关的类,如TransactionalEventListenerFactoryBean、FactoryTransactionAttributeSourceAdvisor、TransactionAttributeSource和TransactionInterceptor等,它们在事务管理的过程中起到了重要的作用。\[3\] #### 引用[.reference_title] - *1* *3* [详解 Spring 注解@Transactional事务Aop实现原理](https://blog.csdn.net/heikeb/article/details/126594817)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [【Spring源码】Spring事务原理](https://blog.csdn.net/p793049488/article/details/129967258)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值