当前位置: 首页 > news >正文

redis延迟队列

Redis延迟队列
Redis延迟队列是基于Redis构建的消息队列,用来处理需延迟执行的任务。

在这里插入图片描述

基本原理
它借助Redis的有序集合(Sorted Set)数据结构达成目的。会把任务及其执行时间分别当成成员与分值存进有序集合,由于执行时间作为分值,任务便会依执行时间在有序集合里自动排序。

系统会持续查询分值小于等于当下时间的任务,找到那些该立刻执行的。

实现方式

  • 任务添加:借助Redis客户端,将任务唯一标识设为成员,把任务执行时间戳当作分值,添加进有序集合。

  • 任务获取与执行:依靠定时任务,或是循环操作定时获取当前时间戳,再从有序集合捞出分值小于等于该时间戳的任务。捞出后,把任务从有序集合移除,接着执行对应的任务逻辑。

  • 任务删除与更新:要是任务延迟阶段需要取消,或是更新执行时间,直接从有序集合删去任务,或是更改任务分值即可。

在这里插入图片描述

应用场景

  • 定时任务调度:像定时发送邮件、定时产出报表这类定时执行的事务,用它实现很合适。

  • 延迟处理:处理如订单超时未支付自动取消、用户注册一段时间后发送欢迎短信这类需延迟处理的任务。

  • 异步任务处理:把耗时任务异步处理,增强系统响应速度与并发处理能力。


http://www.mrgr.cn/news/81352.html

相关文章:

  • 联想 P368-C3 thinkstation服务器介绍
  • 数据库安全-redisCouchdb
  • 如何在谷歌浏览器中设置桌面快捷方式
  • C++23新特性解析:[[assume]]属性
  • dify的ChatFlow自定义上传图片并通过HTTP请求到SpringBoot后端
  • vim多窗格
  • Java SE
  • EMS(energy managment system)从0到1
  • React里使用lodash工具库
  • 机器学习基础
  • Redis缓存数据库
  • [搜广推]王树森推荐系统笔记——矩阵补充最近邻查找
  • 自动驾驶---Parking端到端架构
  • 深度学习中的残差网络、加权残差连接(WRC)与跨阶段部分连接(CSP)详解
  • 结合实例从HCI层分析经典蓝牙连接和配对过程
  • 重温设计模式--1、设计模式七大原则
  • Shell脚本
  • 在【Arduino IDE】中在线下载和离线下载【ESP系列开发板的SDK】
  • idea配置
  • SpringBoot选择CGLIB作为默认动态代理
  • C语言结构体详细讲解
  • gateway网关
  • C语言项目 天天酷跑(上篇)
  • Pytorch分布式训练
  • Unity模型观察脚本
  • Android开发环境搭建和编译系统