如何解决电商网站超卖现象
2017-09-13 01:59
183 查看
所谓超卖现象举例:比如某商品的库存为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设计一个电商网站(九)—— 小心陷入值对象持久化的坑
- IIS服务器经常出现:目前访问网站的用户过多--该如何解决
- 如何解决安装IIS后无默认网站
- 如何解决网页中的中文乱码现象
- 网站降权有什么原因,如何解决恢复?
- 如何解决秒杀的性能问题和超卖的讨论
- 如何一步一步用DDD设计一个电商网站(十四)—— 回顾与总结
- PHP如何解决网站大流量与高并发的问题
- 电商实例、业务并发、网站并发及解决办法
- java 用redis如何处理电商平台,秒杀、抢购超卖
- PHP如何解决网站大流量与高并发
- 电商总结 如何打造一个小而精的电商网站架构
- 如何一步一步用DDD设计一个电商网站(五)—— 停下脚步,重新出发
- 如何解决秒杀商品时,商品超卖的情况
- Vickate_多线程的小方法以及如何使用多线程解决同步请求图片的卡顿现象