RabbitMQ中的不同exchange类型及其使用场景

    在RabbitMQ中,主要存在三种类型的exchange,本文将对这三种类型的exchange的定义及其使用场景进行说明。

   一、Fanout类型

        如果把exchange比作门卫,那么这种exchange类型可以算是最清闲的门卫,它对任何消息均敞开大门,俗话说 "通吃",见下图。

RabbitMQ中的不同exchange类型及其使用场景_第1张图片

        适应场景: 若任意一个消费者对所有从exchange流出的消息均进行消费,则fanout类型是这种场景的不二之选,类似于广播,大家伙都会收到相同的消息。

 

    二、Direct类型

          Direct类型的exchange需要把每一条来到的消息路由到该消息希望进入的队列。和邮递信类似,邮局是exchange,收到的信会根据目的地的不同投入到不同的信箱中,分管不同地区的邮递员(消费者)从不同的信箱中取信投递。见下图,把orange、black和green分别比作寄信场景中不同的目的地。

RabbitMQ中的不同exchange类型及其使用场景_第2张图片

        适用场景:当消费端出现比较挑剔的消费者时,这时候就需要用到direct类型了,我想一个邮递员肯定不想同时负责两个或两个以上地区的邮寄业务吧~。

 

    三、Topic类型

         这种类型是最为复杂,其本质实现了在direct类型基础上更为精细的分发机制,应用场景类似direct类型。见下图。

RabbitMQ中的不同exchange类型及其使用场景_第3张图片

        该类型更为深入的学习可参考链接:https://www.rabbitmq.com/tutorials/tutorial-five-python.html

你可能感兴趣的:(分布式,RabbitMQ,exchange,routing,key,路由,交换机)