RabbitMQ三种Exchange模式(fanout,direct,topic)的性能比较
- RabbitMQ中,除了Simple Queue和Work Queue之外的所有生产者提交的消息都由Exchange来接受,然后Exchange按照特定的策略转发到Queue进行存储。
- RabbitMQ提供了四种Exchange:fanout,direct,topic,header
- header模式在实际使用中较少
-
**性能排序:fanout>direct>>topic。比例大约为11:10:6
Direct Exchange
-
任何发送到Direct Exchange的消息都会被转发到RouteKey中指定的queue
- 一般情况下可以使用rabbitMQ自带的Exchange:“”(该Exchange的名字为空字符串,下文称其为defaultExchange)。
- 这种模式下不需要将Exchange进行任何绑定(binding)操作。
- 消息传递时需要一个“RouteKey(其实是QueueName)”,可以简单的理解为要发送的队列名字。相当于上面提到的Simple Queue和Work Queue.
-
如果vhost中不存在RouteKey中指定的队列名,则该消息被抛弃。
Fanout Exchange
-
任何发送到Fanout Exchange的消息都会被转发到与该Exchange绑定(Binding)的Queue上
- 可以理解为路由表的模式
- 这种模式不需要RouteKey
- 这种模式需要提前将Exchange与Queue进行绑定,一个Exchange可以绑定多个Queue,一个Queue可以同多个Exchange进行绑定
- 如果接受消息的Exchange没有和任何Queue绑定,则消息被抛弃
Topic Exchange
-
任何发送到Topic Exchange的消息都会被转发到所有关心RouteKey中指定话题的Queue上
- 这种模式较为复杂,简单来说,就是每个队列都有其关心的主题(通过BindingKey来说明),所有的消息都带有一个“标题”(Route Key),Exchange会将消息转发到所有关注主题能够和RouteKey模糊匹配的队列。匹配规则使用通配符“#”和“*”。
- 这种模式需要RouteKey,也要提前绑定Exchange与Queue。绑定之后Exchange才能够判断队列关心的主题是否与RouteKey匹配。
- 在进行绑定时,需要提供一个该队列关系的主题,如“#.log.#”表示该队列关系所有涉及log的消息(一个RouteKey为“MQ.log.error”的消息就会被转发给该队列)
- 同样,如果Exchange没有任何发现能够与RouteKey匹配的Queue,则会抛弃该消息。