• RabbitMQ(五)【AMQP协议】


    五、AMQP 协议


    上一篇文章Docker安装

    什么是 AMQP

    AMQP全程:Advanced Message Queuing Protocol(高级消息队列协议)。应用层协议的一个开发标准,为面向消息的中间件设计

    5.1 消息队列中的生产者和消费者流转

    AMQP 生产者流转过程

    在这里插入图片描述

    AMQP 消费者流转过程

    在这里插入图片描述

    5.2 RabbitMQ 的核心组成部分

    在这里插入图片描述

    核心概念:

    • Server:又称为Broker,接受客户端的连接,实现 AMQP 实体服务。安装 rabbitmq-server
    • Connection:连接,应用程序与 Broker 的网络连接 TCP/IP 三次握手和四次握手
    • Channel:网络信道,几乎所有的操作都在 Channel 中进行,Channel 是进行消息读写的通道,客户端可以建立对各 Channel,每个Channel代表一个会话任务
    • Message:消息,服务于应用程序之间传送的数据,由 Properties 和 body 组成,Properties 可对消息进行修饰,比如消息的优先级,延迟等高级特性,body就是消息体的内容
    • Virtual Host:虚拟地址,用于进行逻辑隔离,最上层的消息路由,一个虚拟机里可以有多个 Exchange 和 Queue,同一个虚拟主机里面不能有相同名字的 Exchange
    • Exchange:交换机,接收消息,根据路由键发送消息到绑定队列(不具备消息存储能力
    • Bindings:Exchange 和 Queue 之间的虚拟连接,binding 中可以保护多个 routing key
    • Routing key:是一个路由规则,虚拟机可以用它来确定如何路由一个特定消息
    • Queue:队列,也称为 Message Queue 消息队列,保存消息并将它们发送给消费者

    Bindings

    在这里插入图片描述

    在这里插入图片描述

    在这里插入图片描述

    在这里插入图片描述

    在这里插入图片描述

    推荐:建议指定交换机,不要使用默认交换机

    Routing key

    当交换机接收到信道里的消息之后,队列可根据路由,选择性地将消息发送给消费者

    RabbitMQ 的运行流程

    在这里插入图片描述

    代码过程
    在这里插入图片描述

    5.3 RabbitMQ 支持消息的模式

    参考官网:https://www.rabbitmq.com/getstarted.html

    1)简单模式 Simple

    2)工作模式 Work

    3)发布订阅模式

    4)路由模式

    5)主题 Topics 模式

    6)参数模式

    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

    界面化发送消息

    在这里插入图片描述

    界面化接收消息

    在这里插入图片描述
    下一篇文章入门案例

  • 相关阅读:
    Linux开机自动挂载
    【Vue】描述项目中两个功能模块的业务(一点见解)
    RFID电子标签实现仓储物流托盘智能化管理
    [Emeuelc]DC模拟器Flycast按键设置相关研究
    标准C库IO函数和Linux系统IO函数
    [附源码]计算机毕业设计JAVA婴幼儿玩具共享租售平台
    大数据架构设计理论与实践
    Android Jetpack学习系列——WorkManager
    docker入门教程
    GitHub的原理及应用详解(一)
  • 原文地址:https://blog.csdn.net/Wei_Naijia/article/details/126576431