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

RabbitMQ-TTL/死信队列/延迟队列高级特性

文章目录

  • TTL
  • 死信队列
    • 消息成为死信的三种情况
    • 队列如何绑定死信交换机
  • 延迟队列
    • RabbitMQ如何实现延迟队列

总结来源B站黑马程序员

TTL

TTLTTL(Time To Live):存活时间/过期时间当信息到达存活时间后,还没有被消费,会被自动清除。RabbitMQ可以对消息设置过期时间,也可以对整个队列(Queue)设置过期时间

死信队列

DLX(Dead Letter Exchange):死信交换机,当消息成为Dead Message后,可以被重新发送到另一个交换机,这个交换机就是DLX死信队列原理:当给正常的队列设置过期时间后,在这个过期时间内消息没有被消费的消息会被丢弃,但如果这个正常的队列绑定了一个死信交换机,那么队列里过期没有被消费的消息将不会直接被丢弃而是被直接发送给死信交换机死信交换机再将过期的信息发送给其他的队列(死信队列),从而过期的消息又可以被重新消费了。

截图来自黑马程序员

消息成为死信的三种情况

死信的三种情况1.队列消息长度达到限制2.消费者拒绝消费消息,basicNack/basicReject并且不把消息重新放入原目标队列,requeue=false3.原队列存在消息过期设置,消息到达超时时间未被消费。

队列如何绑定死信交换机

队列绑定死信交换机给对垒设置参数:x-dead-letter-exchage和x-dead-letter-routing-key

在这里插入图片描述

延迟队列

延迟队列:即消息进入队列后不会立即被消费,只有到达指定时间(过期时间TTL)后,才会被消费。需求场景:1.下单后,30分钟未支付,取消订单,回滚库存2.新用户注册成功7天后,发送消息问候。

在这里插入图片描述

RabbitMQ如何实现延迟队列

RabbitMQ本身并未直接提供延迟队列的功能。但我们可以将"TTL"+"死信队列"的组合方式实现延迟队列的效果.

在这里插入图片描述

http://www.lryc.cn/news/311455.html

相关文章:

  • docker安装php7.4安装(swoole)
  • 身份证识别系统(安卓)
  • Python教程——最后一波来喽
  • 学生管理系统(python实现)
  • Java读取文件
  • 曾桂华:车载座舱音频体验探究与思考| 演讲嘉宾公布
  • 面试题HTML+CSS+网络+浏览器篇
  • wordpress外贸独立站
  • [python] 构建数据流水线(pipeline)
  • 计算机网络-网络互连和互联网(五)
  • 【深度学习】Pytorch基础
  • C++模拟揭秘刘谦魔术,领略数学的魅力
  • JAVA语言编写一个方法,两个Long参数传入,使用BigDecimal类,计算相除四舍五入保留2位小数返回百分数。
  • SQL教学:掌握MySQL数据操作核心技能--DML语句基本操作之“增删改查“
  • 【性能测试】Jmeter性能压测-阶梯式/波浪式场景总结(详细)
  • 前端面试 跨域理解
  • JetBrains TeamCity 身份验证绕过漏洞复现(CVE-2024-27198)
  • 设计模式—单例模式
  • Android在后台读取UVC摄像头的帧数据流并推送
  • vue单向数据流介绍
  • OpenMMlab AI实战营第四期培训
  • React轻松开发平台:实现高效、多变的应用开发范本
  • 多域名SSL证书:保护多个网站的安全之选
  • HarmonyOS—HAP唯一性校验逻辑
  • 金三银四,程序员如何备战面试季
  • VUE3项目学习系列--项目配置(二)
  • idea:springboot项目搭建
  • 如何保证某个程序系统内只运行一个,保证原子性
  • golang常见面试题
  • 探索Python编程世界:从入门到精通