欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

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

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

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

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

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

回复内容:

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

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

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

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

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

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

相关标签: php mysql java