美文网首页
任务队列,rabbitmq 交换机的三种模式

任务队列,rabbitmq 交换机的三种模式

作者: 樊海鹏 | 来源:发表于2017-07-07 09:58 被阅读0次

    Exchange中durable参数指定exchange是否持久化,exchange参数指定exchange名称,type指定exchange类型。Exchange类型有direct,fanout和topic。
    Bind是将exchange与queue进行关联,exchange参数和queue参数分别指定要进行bind的exchange和queue,routing_key为可选参数。

    Exchange的三种模式:

    Direct:

    任何发送到Direct Exchange的消息都会被转发到routing_key中指定的Queue
    1.一般情况可以使用rabbitMQ自带的Exchange:””(该Exchange的名字为空字符串);
    2.这种模式下不需要将Exchange进行任何绑定(bind)操作;
    3.消息传递时需要一个“routing_key”,可以简单的理解为要发送到的队列名字;
    4.如果vhost中不存在routing_key中指定的队列名,则该消息会被抛弃。
    Demo中虽然声明了一个exchange='yanfa'和queue='anheng'的bind,但是在后面发送消息时并没有使用该exchange和bind,而是采用了direct的模式,没有指定exchange,而是指定了routing_key的名称为队列名,消息将发送到指定队列。
    如果一个exchange 声明为direct,并且bind中指定了routing_key,那么发送消息时需要同时指明该exchange和routing_key.

    Fanout:

    任何发送到Fanout Exchange的消息都会被转发到与该Exchange绑定(Binding)的所有Queue上
    1.可以理解为路由表的模式
    2.这种模式不需要routing_key
    3.这种模式需要提前将Exchange与Queue进行绑定,一个Exchange可以绑定多个Queue,一个Queue可以同多个Exchange进行绑定。
    4.如果接受到消息的Exchange没有与任何Queue绑定,则消息会被抛弃。
    Demo中创建了一个将一个exchange和一个queue进行fanout类型的bind.但是发送信息时没有用到它,如果要用到它,只要在发送消息时指定该exchange的名称即可,该exchange就会将消息发送到所有和它bind的队列中。在fanout模式下,指定的routing_key是无效的 。

    Topic:

    任何发送到Topic Exchange的消息都会被转发到所有关心routing_key中指定话题的Queue上
    1.这种模式较为复杂,简单来说,就是每个队列都有其关心的主题,所有的消息都带有一个“标题”(routing_key),Exchange会将消息转发到所有关注主题能与routing_key模糊匹配的队列。
    2.这种模式需要routing_key,也许要提前绑定Exchange与Queue。
    3.在进行绑定时,要提供一个该队列关心的主题,如“#.log.#”表示该队列关心所有涉及log的消息(一个routing_key为”MQ.log.error”的消息会被转发到该队列)。
    4.“#”表示0个或若干个关键字,“”表示一个关键字。如“log.”能与“log.warn”匹配,无法与“log.warn.timeout”匹配;但是“log.#”能与上述两者匹配。
    5.同样,如果Exchange没有发现能够与routing_key匹配的Queue,则会抛弃此消息。

    相关文章

      网友评论

          本文标题:任务队列,rabbitmq 交换机的三种模式

          本文链接:https://www.haomeiwen.com/subject/gjrlhxtx.html