基于redis消费队列的一个使用

本文涉及的产品
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
云原生内存数据库 Tair,内存型 2GB
云数据库 Redis 版,倚天版 1GB 1个月
简介: 基于redis消费队列的一个使用

为什么要用消息队列



  • 业务之间的解耦 每个业务模块只负责自己单独的业务逻辑
  • 队列先到先得的原则
  • 因为系统资源有限,为了提高系统的性能,这里可以用队列削峰进行异步处理。


用redis实现一个简单的排队功能



redis的List常用命令


命令 说明 时间复杂度
[BLPOP key [key ...] timeout] 删除,并获得该列表中的第一元素,或阻塞,直到有一个可用 O(1)
[BRPOP key [key ...] timeout] 删除,并获得该列表中的最后一个元素,或阻塞,直到有一个可用 O(1)
[BRPOPLPUSH source destination timeout] 弹出一个列表的值,将它推到另一个列表,并返回它;或阻塞,直到有一个可用 O(1)
[LINDEX key index] 获取一个元素,通过其索引列表 O(N)
[LINSERT key BEFORE] AFTER pivot value在列表中的另一个元素之前或之后插入一个元素 O(N)
[LLEN key] 获得队列(List)的长度 O(1)
[LPOP key] 从队列的左边出队一个元素 O(1)
[LPUSH key value [value ...]] 从队列的左边入队一个或多个元素 O(1)
[LPUSHX key value] 当队列存在时,从队到左边入队一个元素 O(1)
[LRANGE key start stop] 从列表中获取指定返回的元素 O(S+N)
[LREM key count value] 从列表中删除元素 O(N)
[LSET key index value] 设置队列里面一个元素的值 O(N)
[LTRIM key start stop] 修剪到指定范围内的清单 O(N)
[RPOP key] 从队列的右边出队一个元 O(1)
[RPOPLPUSH source destination] 删除列表中的最后一个元素,将其追加到另一个列表 O(1)
[RPUSH key value [value ...]] 从队列的右边入队一个元素 O(1)
[RPUSHX key value] 从队列的右边入队一个元素,仅队列存在时有效 O(1)


简单的流程大概如下


网络异常,图片无法展示
|


  • demo效果


网络异常,图片无法展示
|


  • 消费线程


/**
   * 消费测试
   * @param key   队列名称
   * @param jedis
   * @param count 消费多少笔数据
   * @param isEnd 活动是否结束
   */
  public void consumeTest(String key, Jedis jedis, AtomicInteger count,AtomicBoolean isEnd)
复制代码


实际使用还有很多细节需要考虑,例如退单后的消费流程是否继续。

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
3月前
|
消息中间件 NoSQL Java
别再用 Redis List 实现消息队列了,Stream 专为队列而生
别再用 Redis List 实现消息队列了,Stream 专为队列而生
123 0
|
3月前
|
存储 NoSQL API
【小小思考】Redis实现去重任务队列
【2月更文挑战第1天】思考一下如何用Redis实现去重的任务队列,主要有List 、List + Set/Hash/Bloom Filter、ZSet、Lua和开源库等方式。
192 1
|
8月前
|
NoSQL Redis
redis队列
redis队列
37 0
|
10月前
|
消息中间件 NoSQL Java
Redis实现延迟队列,我研究了两种方案,发现并不简单
前段时间有个小项目需要使用延迟任务,谈到延迟任务,我脑子第一时间一闪而过的就是使用消息队列来做,比如RabbitMQ的死信队列又或者RocketMQ的延迟队列,但是奈何这是一个小项目,并没有引入MQ,我也不太想因为一个延迟任务就引入MQ,增加系统复杂度,所以这个方案直接就被pass了。
|
NoSQL Go Redis
Asynq: 基于Redis实现的Go生态分布式任务队列和异步处理库
Asynq: 基于Redis实现的Go生态分布式任务队列和异步处理库
404 0
|
存储 NoSQL Go
基于redis实现延迟队列
基于redis实现延迟队列
|
12月前
|
NoSQL Go Redis
Redis与异步队列
使用Redis可以很方便地实现异步队列。
84 0
|
消息中间件 监控 NoSQL
RocketMq普通消息,死信队列,消息幂等性(redis)
RocketMQ作为一款纯java、分布式、队列模型的开源消息中间件,支持事务消息、顺序消息、批量消息、定时消息、消息回溯等。
207 0
|
消息中间件 NoSQL JavaScript
用 Redis 实现延迟队列,我研究了两种方案,发现并不简单 下
用 Redis 实现延迟队列,我研究了两种方案,发现并不简单 下
|
消息中间件 NoSQL JavaScript
用 Redis 实现延迟队列,我研究了两种方案,发现并不简单 上
用 Redis 实现延迟队列,我研究了两种方案,发现并不简单 上