并发安全问题(超卖问题)

一,问题解析


  • 超买问题就是,原本库存中有200件库存,结果由于并发问题售出了300件这就是炒卖问题
  • 对于买东西无非就是 查询商品,判断库存是否充足,如果充足则下单成功。
  • 这里采用的是先查询,再判断,再更新的方案,而以上三步操作并不具备原子性。单线程的情况下确实没有问题。但如果是多线程并发运行,如果N个线程同时去查询(N大于剩余库存),此时大概率查询到的库存是充足的,然后判断库存自然没问题。最后一起更新库存,自然就会超卖。

 

二,问题的解决


加锁:锁可以分为悲观锁---乐观锁

1,解决库存超卖问题

  • 何为悲观锁?

    • 每次读取数据时都上锁,防止别人操作数据,就是将并行转为串行

    • 就是通过Synchronized和ReentrantLock对代码进行加锁

    • 优点

      • 安全性非常高

    • 缺点:

      • 性能较差

  • 乐观锁

    • 不会上锁,假设多用户并发的不会产生安全问题,因此无需独占和锁定资源。但在更新数据前,会先检查是否有其他线程修改了该数据

    • 就是通过修改数据库修改语句的条件,一般就是判断当前库存是否大于0,大于0就可以更新数据


  • 悲观锁:添加同步锁,让线程串行执行

    • 优点:简单粗暴

    • 缺点:性能一般

  • 乐观锁:不加锁,在更新时判断是否有其它线程在修改

    • 优点:性能好

    • 缺点:存在成功率低的问题

 

 2,解决限制用户购买商品超卖问题

出现的问题:同一个用户同一时间使用多个线程同时购买就会导致用户抢到很多次商品。


问题解决:使用悲观锁解决,使用同步代码块解决,这样锁的就是当前对象

解决方案很简单,就是调整边界:

  • 业务开始前,先获取锁,再开启事务

  • 业务结束后:先提交事务,再释放锁

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

奋进的大马猴

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值