使用lua+redis解决发多张券的并发问题
程序员文章站
2022-08-26 22:40:16
前言公司有一个发券的接口有并发安全问题,下面列出这个问题和解决这个问题的方式。业务描述这个接口的作用是给会员发多张券码。涉及到4张主体,分别是:用户,券,券码,用户领取记录。下面是改造前的伪代码。主要...
前言
公司有一个发券的接口有并发安全问题,下面列出这个问题和解决这个问题的方式。
业务描述
这个接口的作用是给会员发多张券码。涉及到4张主体,分别是:用户,券,券码,用户领取记录。
下面是改造前的伪代码。
主要是因为查出券码那行存在并发安全问题,多个线程拿到同几个券码。以下都是基于如何让取券码变成原子的去展开。
改造过程
因为券码是多张,想用lua+redis的list结构去做弹出。为什么用这种方案是因为for update直接被否了。
这是写的lua脚本。。
这是写的执行lua脚本的client。。其实主要的解决方法就是在redis的list里rpush(存),lpop(取)取数据
当然这种操作需要去提前把所有券的券码丢到redis里去,这里我们也碰到了一些问题(券码量比较大的情况下)。比如开始直接粗暴的用@postconstruct去放入redis,导致项目启动需要很久很久。。这里就不展开了,说一下我们尝试的几种方法
- @postconstruct注解
- commandlinerunner接口
- redis的pipeline技术
- 先保证每个卡券有一定量的券码在redis,再用定时任务定时(根据业务量)去补
到此这篇关于使用lua+redis解决发多张券的并发问题的文章就介绍到这了,更多相关redis多张券的并发内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
推荐阅读
-
C#解决SQlite并发异常问题的方法(使用读写锁)
-
使用lua+redis解决发多张券的并发问题
-
C#使用读写锁三行代码简单解决多线程并发的问题
-
Go使用sync.Map来解决map的并发操作问题
-
C#解决SQlite并发异常问题的方法(使用读写锁)
-
使用lua+redis解决发多张券的并发问题
-
微服务使用的phprpc,但是最近发现phprpc依赖的fsockopen 高并发下阻塞问题很严重,有解决的好办法吗?
-
C#使用读写锁三行代码简单解决多线程并发的问题
-
使用Redis来存储PHP的session如何解决并发一致性的问题
-
使用Redis来存储PHP的session如何解决并发一致性的问题