码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • RabbitMQ实践——最大长度队列


    大纲

    • 抛弃消息
      • 创建最大长度队列
      • 绑定
      • 实验
    • 转存死信
      • 创建死信队列
      • 创建可重写Routing key的最大长度队列
      • 创建绑定关系
      • 实验

    在一些业务场景中,我们只需要保存最近的若干条消息,这个时候我们就可以使用“最大长度队列”来满足这个需求。该队列在收到消息后,如果达到长度上限,会将队列头部(最早的)的信息从队列中移除。
    在进行实验之前,我们先创建一个交换器direct.max.length,用于接收消息。
    在这里插入图片描述

    抛弃消息

    创建最大长度队列

    我们创建一个名字叫queue.max.length的队列,并且配置属性x-max-length的值为3。这就意味着这条队列最大消息个数是3,超过3个消息时,老消息会被移除。
    在这里插入图片描述

    绑定

    我们定义Routing key是to.queue.max.length时,向上述创建的队列queue.max.length发布消息。
    在这里插入图片描述

    实验

    我们依次发送消息内容是:1、2、3、4的消息。
    在这里插入图片描述
    但是该队列最多只保存了3条消息
    在这里插入图片描述
    最早的一条消息1被抛弃掉了
    在这里插入图片描述

    转存死信

    如果我们不希望消息被抛弃,则可以将其转存到死信中。
    转存到死信有两个方案,在《RabbitMQ实践——使用死信机制对异常消息进行处理》中已经有探讨:

    • 使用独立的死信交换器
    • 重写Routing key

    本文我们将使用相对简单的“重写Routing key”方案,这样可以让我们少创建一个交换器。

    创建死信队列

    我们创建一个用于保存死信的队列queue.dead.letter。没做什么特殊配置。
    在这里插入图片描述

    创建可重写Routing key的最大长度队列

    我们创建一个新的队列queue.max.length.with.dead.letter.routing.key。
    在这里插入图片描述
    它制定了下面几个属性

    • x-max-length:队列最多保存3条消息。
    • x-dead-letter-exchange:使用direct.max.length交换器进行消息路由。这个交换器也是原始消息的交换器。
    • x-dead-letter-routing-key:修改从队列顶部移除的消息的Routing key为to.queue.dead.letter,以供交换器路由。

    创建绑定关系

    在之前案例创建的交换器direct.max.length上,我们将上述队列绑定。
    在这里插入图片描述

    实验

    我们使用Routing key:to.queue.max.length.with.dead.letter.routing.key向queue.max.length.with.dead.letter.routing.key队列发送了4条消息,最终它只保存了后3条,最早的一条会被转存到死信队列中。
    在这里插入图片描述
    在这里插入图片描述

  • 相关阅读:
    要想不踩SaaS那些坑,得先了解“SaaS架构”
    go开发环境安装和小知识
    【NR 物理资源】
    自学Python 39 使用OS对象
    Vue3-vscode代码片段
    flutter多版本管理fvm使用
    LeetCode 92. Reverse Linked List II【链表,头插法】中等
    java基于springboot+vue的公务员考研资料分享交流系统
    [开发浏览器实战]关于Firefox火狐浏览器的说明一二(国内版 国际版区别 账号切换 插件-恢复关闭的标签页 插件-tempermonkey油猴)
    linux驱动学习笔记(1)
  • 原文地址:https://blog.csdn.net/breaksoftware/article/details/139723713
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号