首页 > 后端开发 > php教程 > 如何处理并发情况下涉及多个表下数据的操作?

如何处理并发情况下涉及多个表下数据的操作?

WBOY
发布: 2016-06-06 20:31:28
原创
1174 人浏览过

产品给的需求是: 做一个抽奖活动,用户每天的抽奖次数有限(根据其当天的消费行为获得),用户如果中奖,那么就要修改用户今天抽了几次,修改用户资产(发放奖励),增加一条log。

这里就涉及多个表需要防止并发,log表要防止并发insert, 用户表要防止并发update, 资产表要防止并发insert与update。

现在的问题是如何防止高并发时(包括恶意攻击)出现重复操作?

用队列处理只适合被抽奖的奖品有限的情况,但坑爹的产品还提出一种奖品数量没有限制的抽奖(抽奖发虚拟币)-_-#

回复内容:

产品给的需求是: 做一个抽奖活动,用户每天的抽奖次数有限(根据其当天的消费行为获得),用户如果中奖,那么就要修改用户今天抽了几次,修改用户资产(发放奖励),增加一条log。

这里就涉及多个表需要防止并发,log表要防止并发insert, 用户表要防止并发update, 资产表要防止并发insert与update。

现在的问题是如何防止高并发时(包括恶意攻击)出现重复操作?

用队列处理只适合被抽奖的奖品有限的情况,但坑爹的产品还提出一种奖品数量没有限制的抽奖(抽奖发虚拟币)-_-#

保证一致性和原子性就需要使用事务,我之前碰到这类问题的解决方案是写入队列,后台进程异步处理并使用事务来保证

redis inc数量,判断数量然后再插log

相关标签:
来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板