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

Redis 延迟队列

延时队列的实现可以利用Redis的有序集合(zset),其中消息被序列化为字符串并存储为zset的成员(member)。消息的到期时间被设置为zset的分数(score)。通过多个线程轮询zset以检索并处理到期的任务,保证了系统的高可用性,即使某个线程失败,其他线程也能接管处理。然而,由于存在多个线程,必须确保并发访问时任务不会被多次执行,这可能需要实现适当的并发控制机制。

一个简单的延迟队列示例:

import redis
import time
import uuid
import threading
import random# 链接 redis
r = redis.Redis(host='localhost', port=6379, db=0)def handle_task(task_id):print('handle task', task_id)def process_delay_queue():
# 开启线程后,循环去查询是否有任务存在,有则取出执行,这里有个特殊的点,就是zrem操作while True:task_list = r.zrangebyscore('delay_queue', 0, time.time())if not task_list:# 没有任务print('cost 1s')time.sleep(1)continue# 队列中有任务时,取出首个任务,然后这里用redis里的zrem# 如果将其删除后则返回 true, 若删除失败(也就是已经被删除过了,其他线程在来删除的会肯定会失败),则返回false# 这里能够保证一个任务只能被执行一次task_id = task_list[0]task = r.zrem('delay_queue', task_id) # 删除任务if task: # 防止多线程同时执行任务handle_task(task_id)if __name__ == '__main__':t = threading.Thread(target=process_delay_queue)t.start() # 开启线程for i in range(10):task_id = str(uuid.uuid4()) # 创建任务delay_time = random.randint(10,20) # 延时时间r.zadd('delay_queue', {task_id: time.time() + delay_time}) # 将任务添加到队列中

Redis的ZREM方法在多线程或多进程环境中处理任务争抢时扮演着关键角色。它的返回值表明当前实例是否成功抢到任务。由于process_delay_queue方法可能由多个线程和进程调用,同一任务可能被多个进程或线程尝试获取。通过使用ZREM,可以确保每个任务只有一个唯一的处理者。此外,确保对handle_task方法进行异常捕获是至关重要的,以防止因个别任务处理异常导致整个循环异常退出,从而维护系统的稳定性和可靠性。

相关文章:

  • 电脑如何保养才能用得更久
  • AI 眼镜新纪元:贴片式TF卡与 SOC 芯片的黄金组合破局智能穿戴
  • Axure设计案例——科技感立体柱状图
  • ppt一键制作:ai自动生成PPT,便捷高效超级精美!
  • 从 API 调用到智能 Agent:面向未来产品的插件化 AI 中台设计
  • ChatGPT Plus/Pro 订阅教程(支持支付宝)
  • 《Discuz! X3.5开发从入门到生态共建》第3章 Discuz! X3.5 核心目录结构解析-优雅草卓伊凡
  • Mysql数据库mycat部署与mha高可用实例解析
  • Windows Server 2019--10 网络地址转换
  • allWebPlugin中间件VLC专用版之录像功能介绍
  • 车载通信网络 --- 车载以太网
  • 配置rsync daemon模式进行文件同步
  • C学习-头文件
  • 20250529-C#知识:静态类、静态构造函数和拓展方法
  • AI 工具赋能并列图制作:从数据输入到可视化的零门槛流程
  • Unity 快捷键
  • 1.测试过程之需求分析和测试计划
  • 在容器里运行go程序报错:/bin/sh: ./manager: not found
  • TensorFlow深度学习实战(18)——K-means 聚类详解
  • window安装nginx
  • 红酒商城网站建设/茂名seo顾问服务
  • 网站做的好的公司/推广普通话文字素材
  • 成都网站建设与网站制作/百度账号客服人工电话
  • 郑州哪家网站建设好/百度的营销策略
  • 网站备案登陆/厦门seo搜索排名
  • 中国智能机器人大会2021/网站如何优化排名软件