Rabbit 交换机四种类型
RabbitMQ 常用的交换器类型有fanout 、direct、topic 、headers 这四种。AMQP 协议里还提到另外两种类型: System 和自定义。
目录
fanout (广播)
fanout
它会把所有发送到该交换器的消息路由到所有与该交换器绑定的队列中。
fanout 就是传说中的广播模型,只要是连接在频道内的所有用户,都能在生产者发送消息后接收到消息。
详细内容请看我的 另一篇博客 RabbitMQ->fanout(广播模型)
direct
direct 类型的交换器路由规则也很简单,它会把消息路由到那些 BindingKey 和 RoutingKey 完全匹配的队列中。
详细讲解以及代码实现可 参考我得另一篇博客 RabbitMQ-HelloWorld
topic
前面讲到direct 类型的交换器路由规则是完全匹配BindingKey 和RoutingKey ,但是这种严格的匹配方式在很多情况下不能满足实际业务的需求。topic 类型的交换器在匹配规则上进行了扩展,它与direct 类型的交换器相似,也是将消息路由到BindingKey 和RoutingKey 相匹配的队列中,但这里的匹配规则有些不同,它约定:
-
RoutingKey 为一个点号"."分隔的字符串(被点号"."分隔开的每一段独立的字符串成为一个单词),如"com.rabbitmq.client"、"java.util.concurrent"、"com.hidden.client"
-
BindingKey 和 RoutingKey 一样也是点号"."分割的字符串
-
BindingKey 中可以存在两种特殊的字符串""、"#",用于做模糊匹配,其中"#"用于匹配一个单词,""用于匹配多规格单词(可以是零个)。
headers
headers 类型的交换器不依赖于路由键的匹配规则来路由消息,而是根据发送的消息内容中的headers 属性进行匹配。在绑定队列和交换器时制定一组键值对, 当发送消息到交换器时,RabbitMQ 会获取到该消息的headers (也是一个键值对的形式) ,对比其中的键值对是否完全匹配队列和交换器绑定时指定的键值对,如果完全匹配则消息会路由到该队列,否则不会路由到该队列。headers 类型的交换器性能会很差,而且也不实用,基本上不会看到它的存在。