RabbitMQ 和消息传递经常使用一些术语

0.写在前面

RabbitMQ 是一个消息代理:它接受和转发消息。你能够把它想象成一个邮局:当你把你想要投寄的邮件放在一个邮箱里时,你能够肯定收信人先生或女士最终会把邮件寄给你的收件人。在这个类比中,RabbitMQ是一个邮箱、一个邮局和一个邮递员。spa

RabbitMQ 与邮局的主要区别在于它不处理纸张,而是接收、存储和转发二进制数据块——消息。代理

1.Producer

producer

生产就是发送,发送消息的程序是生产者。code

2.Queue

queue

队列是位于 RabbitMQ 内的邮箱的名称。尽管消息流经 RabbitMQ 和应用程序,但它们只能存储在队列中。队列只受主机的内存和磁盘限制,它本质上是一个大的消息缓冲区。许多生产者能够向一个队列发送消息,许多消费者能够尝试从一个队列接收数据。cdn

3.Consumer

consumer

消费与接受有着类似的含义。消费者是一个主要等待接收消息的程序。blog

4.Exchange

exchange

交换器必须确切地知道如何处理接收到的消息。它应该附加到特定的队列吗?它应该附加到许多队列中吗?或者它应该被丢弃。这些规则由 Exchange Types 类型定义。队列

Exchange Types:direct, topic, headers,fanout
复制代码

5.Bindings

绑定是用于将消息路由到队列的交换规则。为了指示Exchange E将消息路由到队列Q,Q必须绑定到E。某些 Exchange Type 能够使用一个可选的路由键属性。routing key 的目的是指定这个消息的路由规则。换句话说,routing key 键就像一个过滤器。内存

若是AMQP消息不能路由到任何队列(例如,由于它发布到的交换器没有绑定),那么它要么被删除,要么返回给发布者,这取决于发布者设置的消息属性。路由

6.Routing Key

生产者在将消息发送给 Exchange 的时候,通常会指定一个 routing key,来指定这个消息的路由规则,而这个 routing key 须要与 Exchange Type 及 binding key 联合使用才能最终生效。在 Exchange Type 与 binding key 固定的状况下(在正常使用时通常这些内容都是固定配置好的),咱们的生产者就能够在发送消息给 Exchange 时,经过指定 routing key 来决定消息流向哪里。RabbitMQ 为 routing key 设定的长度限制为255 bytes。it

相关文章
相关标签/搜索