• 简述RabbitMQ的架构设计


    Broker:

            rabbitmq的服务节点

    Queue:

             队列 ,是RabbitMQ的内部对象,⽤于 存储消息 。RabbitMQ中消息只能存储在队列中。⽣产者投递消息到队列,消费者从队列中获取消息并消费。多个消费者可以订阅同⼀个队列,这时队列中的消息会被平均分摊(轮询)给多个消费者进⾏消费,⽽不是每个消费者都收到所有的消息进⾏消费。(注意: RabbitMQ不⽀持队列层⾯的⼴播消费,如果需要⼴播消费,可以采⽤⼀个交换器通过路由Key绑定多个队列,由多个消费者来订阅这些队列的⽅式

    Exchange:

             交换器 。⽣产者将消息发送到Exchange,由交换器将消息路由到⼀个或多个队列中。如果路由不到,或返回给⽣产者,或直接丢弃,或做其它处理。

    RoutingKey:

             路由Key ⽣产者将消息发送给交换器的时候,⼀般会指定⼀个 RoutingKey ,⽤来指定
    这个消息的路由规则。这个路由Key需要与交换器类型和绑定键( BindingKey )联合使⽤才能最终⽣效。在交换器类型和绑定键固定的情况下,⽣产者可以在发送消息给交换器时通过指定RoutingKey来决定消息流向哪⾥。

    Binding:

            通过绑定将交换器和队列关联起来,在绑定的时候⼀般会指定⼀个绑定键,这样RabbitMQ就可以指定如何正确的路由到队列了。

            交换器和队列实际上是多对多关系。就像关系数据库中的两张表。他们通过BindingKey做关联(多对多关系表)。在投递消息时,可以通过ExchangeRoutingKey(对应BindingKey)就可以找到相对应的队列。

    信道:

             信道是建⽴在Connection 之上的虚拟连接 。当应⽤程序与Rabbit Broker建⽴TCP连接的时候,客户端紧接着可以创建⼀个AMQP 信道(Channel) ,每个信道都会被指派⼀个唯⼀的ID。RabbitMQ 处理的每条AMQP 指令都是通过信道完成的。信道就像电缆⾥的光纤束。⼀条电缆内含有许多光纤束,允许所有的连接通过多条光线束进⾏传输和接收

     

  • 相关阅读:
    Nvidia GPU 入门教程之 10 如何通过TensorFlow Datasets 下载海量数据集?
    css3英文文字换行,超过两行...展示
    企业级自定义表单引擎解决方案(十四)--表单模板2
    一起Talk Android吧(第五百五十七回:如何获取文件读写权限)
    Nacos Discovery--服务治理
    Error: Cannot find module ‘@dcloudio/uni-cli-i18n‘
    【Qt之Model/View】编程
    面试官:Java池化技术你了解多少?
    Idea远程debug操作步骤(连接服务器)
    HashMap底层数据是如何存储的呢?
  • 原文地址:https://blog.csdn.net/m0_70734549/article/details/128112596