RabbitMQ三种Exchange

来源:互联网 发布:ubuntu能做什么 编辑:程序博客网 时间:2024/05/16 16:16

1.Direct Exchange

    Direct Exchange是一种点对点模式。当消息发送到Direct Exchange时,如果routingkey匹配的话,消息就被投递到对应的队列。


  注意有一个默认的direct类型交换器

   


  默认交换器名称是一个空白字符串,当声明一个队列时,他会自动绑定到默认交换器,并以队列名作为routingkey。


 所以通过channel.basicPublish("", "queue-name", null, "msg".getBytes());可以将消息发送的队列queue-name中。

 RabbitMQ RPC实现将消息返回给客户端就是通过此特性实现的。


2.Fanout Exchange

   Fanout Exchange会忽略routingkey,它将收到的消息广播到绑定的队列上。这是我们最常见的发布订阅模式。

3.Topic Exchagne

   topic exchange也是一种发布订阅模式,只是它只把消息发往那些routingkey模式匹配的队列上。单个"." 把路由键分为了几部分,"*" 匹配特定位置的任意文本。为了实现匹配所有规则,你可以使用"#"字符:channel.queueBind("all-logs-queue", "logs-exchange", "#");