举例,假设有100个请求node服务器,每个请求会执行一次查询,修改数据库操作。假设10个请求按顺序被node接收处理 等待各自判定库存查询数据库io操作,但是库存只有5个,问题来了,这时候10个查询都判定库存还有,然后继续下面的下单操作。当100个请求甚至更多时,问题会被更加放大 又不能同步加锁,哪位朋友有比较合理的思路 不吝赐教~
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号
站内搜“抢购”
https://segmentfault.com/sear...
极端情况为“秒杀”
https://segmentfault.com/sear...
你这种情况应该加上事务
----- 更新下答案 -----
查询和实际数据不一致的问题是无法避免的,我的理解题主的意思应该是在更新callback之前有其他用户购买成功的情况会导致购买失败的问题,因此可以通过加锁解决,其实如果异步操作都使用 promise 的情况下,可以通过Promise 模拟顺序调用来实现类似java方法加锁的特性
通过 decorator 对返回 promise 的方法实现类似java synchronized 关键字的同步调用
chrome 下运行通过。。
----- 再更新 ----
github 上已经有类似工具
https://github.com/sindresorh...
谢谢楼上两位,首先我描述的场景是正常商品销售,如果是抢购倒好办 直接用redis队列可以解决,但是商品种类多的时候 这种方式不可取。
事务 + 条件更新 从设计上避免了超卖。