RabbitMQ的四种交换器类型(fanout、direct、topic、headers)

 

RabbitMQ常见的的四种交换器类型有四种:fanout、direct、topic、headers。

一、fanout

它会把所有发送到该交换器的消息路由到所有与该交换器绑定的队列中。不需要指定Routingkey和BindingKey

二、direct

它会把消息路由到Routingkey与BindingKey完全匹配的队列中。一个交换器可以与多个队列绑定,同时一个交换器与一个队列绑定的时候可以使用多个BindingKey来多次绑定。

在实践中如果一个交换器只绑定一个队列,那么可以将Routingkey和BindingKey看成一个东西。

如果一个交换器绑定多个队列,则会把消息路由到Routingkey与BindingKey完全匹配的队列中。

RabbitMQ的四种交换器类型(fanout、direct、topic、headers)

三、topic

topic与direct类型的交换器类似,也是将消息路由到Routingkey与BindingKey匹配的队列中,但它不是完全匹配,而是模糊匹配。

Routingkey和BindingKey一般使用“.”作为字符串的分隔符,例如:order.waitpay.current

BindingKey中可以存在两种用于模糊匹配的字符串:*和# ;#用于匹配一个单词,*用于匹配多个单词(可以是0个);例如:order.*.current。

四、headers

headers类型的交换器不依赖于路由键的匹配规则来路由消息,而是根据发送的消息内容中的headers属性进行匹配。

再绑定队列和交换器时制定一组键值对,当发送消息到交换器时,RabbitMQ会获取到该消息的headers,对比其中的键值对是否完全匹配队列和交换器绑定时指定的键值对。如果完全匹配,则路由该消息到此队列中。

headers类型的交换器的性能很差,不建议使用。