RabbitMQ五大模式轻松理解

简要概括RabbitMQ工作模式:

1、简单模式 HelloWorld

一个生产者、一个消费者,不需要设置交换机(使用 默认的交换机)

2、工作队列模式 Work Queue

一个生产者、多个消费者(竞争关系),不需要设置交换机(使用默认 的交换机)

3、发布订阅模式 Publish/subscribe

需要设置类型为fanout的交换机,并且交换机和队列进行绑定, 当发送消息到交换机后,交换机会将消息发送到绑定的队列

4、路由模式 Routing

需要设置类型为direct的交换机,交换机和队列进行绑定,并且指定routing key,当发送消息到交换机后,交换机会根据routing key将消息发送到对应的队列

5、通配符模式 Topic

需要设置类型为topic的交换机,交换机和队列进行绑定,并且指定通配符方式的 routing key,当发送消息到交换机后,交换机会根据routing key将消息发送到对应的队列

1、简单模式 HelloWorld

 一个生产者

RabbitMQ五大模式轻松理解_第1张图片

 一个消费者Consumer

RabbitMQ五大模式轻松理解_第2张图片

交换机名称为空,未设置交换机,使用默认交换机 RabbitMQ五大模式轻松理解_第3张图片

2、工作队列模式 Work Queue

一个生产者

RabbitMQ五大模式轻松理解_第4张图片

消费者1

RabbitMQ五大模式轻松理解_第5张图片

消费者2

RabbitMQ五大模式轻松理解_第6张图片 两个消费者互为竞争关系,争抢消息的接收,“你一条我一条” 

3、发布订阅模式 Publish/subscribe

设置交换机,类型为FANOUT,发送消息到多个队列

 /**
         * 声明交换机
         * 参数1: 交换机名称
         * 参数2 : 交换机类型  fanout  topic direct  headers
         */
        channel.exchangeDeclare(FANOUT_EXCHANGE, BuiltinExchangeType.FANOUT);

  生产者

RabbitMQ五大模式轻松理解_第7张图片

队列1的消费者

RabbitMQ五大模式轻松理解_第8张图片

 队列2的消费者

RabbitMQ五大模式轻松理解_第9张图片

 交换机绑定队列为并列关系,两个消费者都收到生产者发布的所有消息,不存在竞争关系

4、路由模式 Routing

设置交换机,类型为DIRECT,绑定多个队列并设置RoutingKey

 /**
         * 声明交换机
         * 参数1: 交换机名称
         * 参数2 : 交换机类型  fanout  topic direct  headers
         */
        channel.exchangeDeclare(DIRECT_EXCHANGE, BuiltinExchangeType.DIRECT);

生产者发布两种类型RoutingKey的消息

RabbitMQ五大模式轻松理解_第10张图片

       // 发送信息
            String message = "新增商品  routing模式--" ;
    /**
     * 参数1:交换机名称,如果没有指定则使用默认Default Exchage
     * 参数2:路由key,简单模式可以传递队列名称
     * 参数3:消息其它属性
     * 参数4:消息内容
     */
            channel.basicPublish(DIRECT_EXCHANGE,"insert", null, message.getBytes());
            System.out.println("已发送消息:" + message);


            message = "修改商品  routing模式--";


            channel.basicPublish(DIRECT_EXCHANGE,"update",null,message.getBytes());
            System.out.println("已发送消息:" + message);

对应的RoutingKey的队列接收交换机发送的对应RoutingKey消息

RabbitMQ五大模式轻松理解_第11张图片

 RabbitMQ五大模式轻松理解_第12张图片

5、通配符模式 Topic

设置交换机,类型为TOPIC,绑定多个队列并设置RoutingKey,且RoutingKey中带有通配符*、#;*表示可以匹配一个词,#表示可以匹配一个或多个词,例子:item.java 、item.java.sout

item.*只能匹配到item.java,item.#可以匹配到item.java和item.java.sout

RabbitMQ五大模式轻松理解_第13张图片

   // 发送信息
            String message = "新增商品  topic模式--routingkey=insert" ;
    /**
     * 参数1:交换机名称,如果没有指定则使用默认Default Exchage
     * 参数2:路由key,简单模式可以传递队列名称
     * 参数3:消息其它属性
     * 参数4:消息内容
     */
            channel.basicPublish(TOPIC_EXCHANGE,"item.insert", null, message.getBytes());
            System.out.println("已发送消息:" + message);


            message = "修改商品  topic模式--routingkey=update";


            channel.basicPublish(TOPIC_EXCHANGE,"item.update",null,message.getBytes());
            System.out.println("已发送消息:" + message);


            message = "删除商品  topic模式--routingkey=delete";

            channel.basicPublish(TOPIC_EXCHANGE,"item.delete.delete",null,message.getBytes());
            System.out.println("已发送消息:" + message);

 RoutingKey设置为item.*的队列的消费者接收到的消息为

RabbitMQ五大模式轻松理解_第14张图片

  RoutingKey设置为item.#的队列的消费者接收到的消息为

RabbitMQ五大模式轻松理解_第15张图片

总结:

RabbitMQ的五种工作模式区别在于:

问:是否设置交换机?设置的交换机类型是什么?

答:前两种没有设置交换机,后三者设置了交换机,其类型分别为FANOUT,DIRECT,TOPIC,类型不同,实现的功能也不同。

RabbitMQ分析的结果:首先,设置了交换机,模式多样,功能更强;在设置了交换机的基础上,设置交换机的类型不同,实现的功能也不同。如果没有设置交换机,即使用默认交换机,其模式简单,功能有限。

你可能感兴趣的:(Java企业级,RabbitMQ,linux,rabbitmq,分布式,java,架构)