我刚刚找到了一个恼人的错误,它基本上是一个竞争条件。为了论证,我们假设一个非常简单的文档结构,例如 { _id : 'XXX', amount : 100 }
。
这些文档中有数百个存在于一个集合中,并被多个作者访问,这些作者有效地尝试将数量降低任何值但从不低于 0。目前这是通过两个查询完成的:
- 第一个查询确定当前金额。
- 仅当金额大于要减去的值并减少当前金额时才会触发第二个查询。
当多个线程同时执行此操作时,这当然容易导致困惑。但是有没有办法在原子操作中做到这一点?我在文档中找不到类似 test-and-set
操作的内容。
如果相关:运行这些操作的代码是使用多个 Node.js 实例和 mongodb
npm 包运行的服务器端 JavaScript。
最佳答案
限定更新以仅在 amount
大于 0 时更新文档:
db.coll.update({_id: 'XXX', amount: {$gt: 0}}, {$inc: {amount: -1}})
关于javascript - 在原子操作中测试和递减?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14463189/