RabbitMQ学习:四种交换机

AMQP协议就是将生产者和消费者隔离开,生产者会不断将消息发送到消息队列中,但是发消息的过程中,生产者首先将消息发送到交换机,有Exchange交换机接收后,然后交换机通过不同的策略转发到对应的Queue队列中。

RabbitMQ提供了四种Exchange模式:fanout、direct、topic、header 。header模式在实际使用中较少,本文只对前三种模式进行比较。
RabbitMQ学习:四种交换机

1、Direct Exchange(点对点)
 可以使用rabbitMQ自带的Exchange:default Exchange。所以不需要将Exchange进行任何绑定(binding)操作 。处理路由键。需要将一个队列绑定到交换机上,要求该消息与一个特定的路由键完全匹配。这是一个完整的匹配。如果一个队列绑定到该交换机上要求路由键“hello”,则只有被标记为“hello”的消息才被转发,不会转发hello.key,也不会转发dog.key1,只会转发hello。(一对一的匹配才会转发)
RabbitMQ学习:四种交换机

2、Fanout Exchange(消息分发)
 所有发送到Fanout Exchange的消息都会被转发到与该Exchange 绑定(Binding)的所有Queue上。不需要设置route key。类似子网广播,每台子网内的主机都获得了一份复制的消息。
RabbitMQ学习:四种交换机

3、Topic Exchange(消息订阅)
 Exchange 将RouteKey 和某Topic 进行模糊匹配。需要设置好route key。此时队列需要绑定一个Topic。可以使用通配符进行模糊匹配,符号“#”匹配一个或多个词,符号“”匹配不多不少一个词。因此“log.#”能够匹配到“log.info.oa”,但是“log.” 只会匹配到“log.error”。
RabbitMQ学习:四种交换机