如何解决电商网站超卖现象
2017-12-19 09:47
330 查看
所谓超卖现象举例:比如某商品的库存为1,此时用户1和用户2并发购买该商品,用户1提交订单后该商品的库存被修改为0,而此时用户2并不知道的情况下提交订单,该商品的库存再次被修改为-1这就是超卖现象。
究其深层原因,是因为数据库底层的写操作和读操作可以同时进行,虽然写操作默认带有隐式锁(即对同一数据不能同时进行写操作)但是读操作默认是不带锁的,所以当用户1去修改库存的时候,用户2依然可以都到库存为1,所以出现了超卖现象。
解决方案:
可以对读操作加上显式锁(即在select ...语句最后加上for
update)这样一来用户1在进行读操作时用户2就需要排队等待了
但是问题来了,如果该商品很热门并发量很高那么效率就会大大的下降,怎么解决?
解决方案:
我们可以有条件有选择的在读操作上加锁,比如可以对库存做一个判断,当库存小于一个量时开始加锁,让购买者排队,这样一来就解决了超卖现象。
究其深层原因,是因为数据库底层的写操作和读操作可以同时进行,虽然写操作默认带有隐式锁(即对同一数据不能同时进行写操作)但是读操作默认是不带锁的,所以当用户1去修改库存的时候,用户2依然可以都到库存为1,所以出现了超卖现象。
解决方案:
可以对读操作加上显式锁(即在select ...语句最后加上for
update)这样一来用户1在进行读操作时用户2就需要排队等待了
但是问题来了,如果该商品很热门并发量很高那么效率就会大大的下降,怎么解决?
解决方案:
我们可以有条件有选择的在读操作上加锁,比如可以对库存做一个判断,当库存小于一个量时开始加锁,让购买者排队,这样一来就解决了超卖现象。
相关文章推荐
- 如何解决电商网站超卖现象
- 如何一步一步用DDD设计一个电商网站(十三)—— 领域事件扩展
- 如何解决秒杀的性能问题和超卖的讨论
- 如何一步一步用DDD设计一个电商网站(十)—— 一个完整的购物车
- PHP如何解决网站大流量与高并发
- 如何解决公司网站首页被恶意跳转的安全问题
- 什么是网站死链?如何查询网站死链?网站死链怎么解决?
- 如何解决电商系统的图片服务器和web服务器的分离
- 如何使用mysql(lamp)分离环境搭建dedecms织梦网站及apache服务器常见的403http状态码及其解决方法
- 网站被植入广告,如何解决?
- java使用mysql和redis如何解决“商品超卖”
- IE11如何解决Oracle 11g EM网站报“此网站的安全证书存在问题” (二)
- 电商网站如何推广自己呢?
- 电商网站秒杀库存超卖问题
- 当MySpace遭遇百千万用户的压力——话说如何解决拥有百千万用户网站压力问题的架构
- 如何解决秒杀的性能问题和超卖的讨论
- 如何一步一步用DDD设计一个电商网站(十四)—— 回顾与总结
- 如何解决用户添加到AD Group仍然无法访问SharePoint网站的问题?
- 关于如何取消访问https时的提示:“此网站的安全证书存在问题”的解决方法