spring aop事务支持与synchronized的问题

在国土交易系统的网上出价场景中,为防止幻读,使用了synchronized修饰Service层方法,但仍出现问题。分析指出,synchronized应放在Controller层或更高调用层,因为Spring AOP的事务在Service方法执行完毕后才提交,可能导致并发问题。解决方案是调整锁的粒度以配合事务管理。
摘要由CSDN通过智能技术生成

环境:国土交易系统网上出价、限时竞价阶段同一个时间点多人出价,需要保证金额大的竞买人一定能出价,并且时间在排序列表中也最大。

为了防止幻读在service层方法上加了synchronized还是出现了幻读的情况

解决办法 把synchronized加到Controller层或者大于事务边界的调用层

原因 使用了spring aop事务,事务提交在一个service方法执行完毕后,可能事务还没有提交,

这时候另外一个线程开始执行synchronized方法导致并发问题出现

代码片段如下:Controller

	private static Object lock=new Object();
		//保存出价信息
				synchronized(lock){
					saveFlag=limitBidBiz.saveBusLimitBidInfo(user.getPkId(), moneyDouble, busId,cert,user.getOrgId(), getRequest(
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值