公司要做一个抢购的功能
如何避免并发带来的订单多出?
因为数据库是mongo 无法像mysql那样进行锁
不知道有什么好的解决方案?
我所想的就是用redis强行让他排队 但是这个太扯了..
每次创建的时候都会去查 但是害怕有那一点并发..
公司要做一个抢购的功能
如何避免并发带来的订单多出?
因为数据库是mongo 无法像mysql那样进行锁
不知道有什么好的解决方案?
我所想的就是用redis强行让他排队 但是这个太扯了..
每次创建的时候都会去查 但是害怕有那一点并发..
首先你得有个设计容量。你的项目准备容纳多少人抢多少产品。然后才决定用什么技术。
如果就10个人抢,别纠结了随便找个关系型数据库一怼就完事了。
再多一些,可以把压力直接压到mongodb上。顺便提下mongodb并不是没有锁,合理使用一样可以锁住不多卖,使用$inc操作符。比如:
db.product.update({sku: 'xxx', qty: {$gt: 0}}, {$inc: {qty: -1}})
如果这样不够你用的,那该考虑队列了
4 回答968 阅读
1 回答649 阅读✓ 已解决
2 回答619 阅读
604 阅读
用消息队列可以解决这个问题