redis加锁控制

1.redis加锁 需要看 加锁的是什么方法 ,比如买标的, 加锁的就是要 加锁标的 id,加锁活动 加锁活动的id
其他的类似, 共享数据 需要加锁,防止用户过多造成并发问题
2.由于Spring事务是通过AOP实现的,所以在luckDraw方法执行之前会有开启事务,
之后会有提交事务逻辑。而redis加锁代码块执行是在事务之内执行的
,可以推断在redis加锁代码块执行完时,
事务还未提交,其他线程进入redis加锁的代码块后,读取的库存数据不是最新的。
3.如果spring设置事务自己提交 需要 把@Transactional 去掉, 然后
@Autowired
private DataSourceTransactionManager txManager;
DefaultTransactionDefinition def = new DefaultTransactionDefinition();
def.setPropagationBehavior(TransactionDefinition.PROPAGATION_REQUIRES_NEW);// 事物隔离级别,开启新事务
TransactionStatus status = txManager.getTransaction(def); // 获得事务状态
txManager.commit(status); //提交事务

  1. 也就是说 redis加锁 需要在controller 层加锁
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值