在rabbiqmq中消息生产者其实并不关心消息队列,消息都是推送到exchange中,再有exchange通过routingKey路由到指定的队列。

exchange有四种类型:fanout、direct、topic、headers。很好区分记忆,headers通常用不着,直接忽略。

fanout:广播式推送消息,生产者只要把消息推送至fanout交换器中,无需指定routingKey,只要exchange绑定的队列,都会收到消息。一句话记忆,无脑广播至交换器下所有队列。

rabbitmq消息推送exchange类型_java
direct:一对一推送消息,时刻谨记消息都是通过exchange和routingKey路由到队列的,这里的一对一是指一个消息到一个指定的routingKey。(一个routingKey可以只对应一个队列;一个routingKey也可以对应多个队列,此时类似fanout广播;多个routingKey可以对应到一个相同的队列,貌似没啥用,多个key和一个key的价值一样)。
rabbitmq消息推送exchange类型_java_02

topic:topic本质和direct类似,只是routingKey使用点号分隔, 支持了通配符 ==*==匹配一个字符, # 匹配零个或多个。so,如果只使用一个#作为routingKey,等价于没有routingKey,所有绑定此topic的队列都会收到消息,等同于fanout。当然如果未使用通配符,那和direct并无区别。rabbitmq消息推送exchange类型_java_03
以上图片均引用自rabbitmq官方文档。