面试题:使用过 Redis 做异步队列么,你是怎么用的?
2023-09-11 14:16:49 时间
使用过 Redis 做异步队列么,你是怎么用的?
一般使用 list 结构作为队列,rpush 生产消息,lpop 消费消息。当 lpop 没有消息的时候,要适当 sleep 一会再重试。不但客户端的 CPU 能降下来,Redis 的 QPS 也降下来了。
如果对方追问可不可以不用 sleep 呢?
用 blpop/brpop 替代前面的 lpop/rpop,list 还有个指令叫 blpop阻塞读在队列没有数据的时候,会立即进入休眠状态,一旦数据到来,则立刻醒过来。消息的延迟几乎为零。
如果对方追问能不能生产一次消费多次呢?
使用 pub/sub 主题订阅者模式,可以实现1:N 的消息队列。
如果对方追问 pub/sub 有什么缺点?
在消费者下线的情况下,生产的消息会丢失,得使用专业的消息队列如 RabbitMQ等。Redis5.0 新增了 Stream 数据结构,这个功能给 Redis 带来了持久化消息队列。
如果对方追问 redis 如何实现延时队列?
延时队列可以通过 Redis 的 zset(有序列表) 来实现。我们将消息序列化成一个字符串作为 zset 的 value,这个消息的到期处理时间作为 score,然后用多个线程轮询 zset 获取到期的任务进行处理,多个线程是为了保障可用性,万一挂了一个线程还有其它线程可以继续处理。
相关文章
- redis实战笔记(10)-第10章 扩展Redis
- redis实战笔记(4)-第4章 数据安全与性能保障
- redis安装与使用(windows端)+Redis设置Auth认证保护+redis的管理工具:Redis Desktop Manager
- 2022 最新 Redis 面试题
- Redis开发与运维. 3.5 Bitmaps
- [转]windows下redis的下载安装
- Redis - 查看一个 KEY 剩多久过期
- Redis分布式锁
- 这 20 道 Redis 经典面试题你还不会,就别去面试了!
- 这 20 道 Redis 经典面试题你还不会,就别去面试了!
- Redis 客户端工具
- 面试题:redis事务
- 面试题:Redis常见性能问题和解决方案?
- redis 查看key 类型
- 缓存技术比拼:Redis与Memcached的同与不同
- windows redis 取消auth验证(包含linux)
- Redis支持的数据类型
- PHP+Redis 实例 页面缓存
- 2023年redis面试题开胃菜(10道)
- windows下体验Redis
- Redis 经典面试题合集详解
- Redis数据库相关指令大合集
- 【转】Redis概念原理、redis面试
- Redis(1.1)redis安装,linux下安装redis
- [转] rabbitMQ、activeMQ、zeroMQ、Kafka、Redis 比较
- Redis学习系列五Set(集合)
- redis-CRC16