@Transactional和@Synchronized的冲突

@Transactional和@Synchronized的冲突

场景

方法是先进行检查,然后新增,添加了事务注解,为了保证检查(要求业务上唯一),添加了@Synchronized注解

想法很简单,事务注解保证方法原子性,锁注解控制并发,实际结果不符合预期

结论

在这里插入图片描述
上述save方法,是新增一个apple,要求size和color唯一

通过编译后的class文件,可以看出,事务在锁之前(事务是切面),锁注解实际是方法内的代码块,实际效果是并发请求都开启事务,第一个请求占用锁,开始业务处理,后续请求开启事务,被锁阻塞,等到占用锁进行业务处理时,采取默认的RR隔离级别,读取快照,发现可以新增,实际另外一个事务已经新增并提交了,但是没用

如何解决?

  1. 缩小事务范围,改为代码块事物而非注解,较为麻烦
  2. 移除事务注解,默认新增操作是原子性,可以保证
  3. 修改隔离级别为RC
    在这里插入图片描述ps:syn语句块结束,到事务提交,有延迟,所以获取锁要睡眠一个很短时间(不睡眠的流程可能是:请求1开事务-占用锁-处理-释放锁,请求2开事务-占用锁-处理,请求1提交完成。请求2处理即使是RC也得请求1的事务提交)

自测日志

在这里插入图片描述

  • 4
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
回答: 当使用@Async和@Transactional注解时,可能会出现冲突的情况。\[1\]这是因为@Async注解会将方法的执行放在一个新的线程中,而@Transactional注解会开启一个事务来管理方法的执行。由于@Async注解会创建一个新的线程,事务的上下文可能无法正确传递给新的线程,导致事务无法生效。解决这个冲突的方法是将需要事务管理的方法放到另一个类中,然后在该方法上添加@Transactional注解,而不是在使用@Async注解的方法上添加@Transactional注解。\[1\]这样可以确保事务的正确生效。例如,在给定的例子中,可以将需要事务管理的方法dd()放到类B中,并在该方法上添加@Transactional注解,而将使用@Async注解的方法test()保持不变。\[1\]这样就可以避免@Async和@Transactional注解的冲突。 #### 引用[.reference_title] - *1* [@Transactional和@Async一起使用,事务失效问题解决](https://blog.csdn.net/a_hasaigei/article/details/124446118)[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_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [@Async,@Transational在同一个类中失效](https://blog.csdn.net/LJT666888/article/details/119418460)[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_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [同时使用 @Transactional和@Async出现的报错](https://blog.csdn.net/qq_39002724/article/details/113615229)[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_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值