python - mongodb 高并发写入 覆盖原有数据

查看:926
本文介绍了python - mongodb 高并发写入 覆盖原有数据的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

问 题

我有一个product表数据, 它会产生10个coupon, 我在product表的字段里存了coupon_count的字段为10, 如果抢红包的话根据coupon_count的剩余数来生成红包(抢红包coupon_count 减一)。

当1秒内并发上百的话, 会因为多个进程并发写入问题产生超过总是得红包。有什么方案可以解决这个问题?

  1. web框架: flask

  2. 数据库: mongodb 3.2.6

  3. 使用orm框架: mongoengine

解决方案

会,mongodb没有事务,不会锁表,在你查询数量到写入的过程并非原子性的,所以高并发必然出问题。
建议修改数据和查询接口,去适配一些mongodb的原子性操作来处理,比如先生成红包,抢红包时用findAndModify来查询并同步修改红包状态。

这篇关于python - mongodb 高并发写入 覆盖原有数据的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆