zoukankan      html  css  js  c++  java
  • 5、RabbitMQ

    pytho系列之 RabbitMQ - Exchange几种模式


    RabbitMQ中,所有生产者提交的消息都由Exchange来接受,然后Exchange按照特定的策略转发到Queue进行存储

    RabbitMQ提供了四种Exchange:fanout, direct, topic, header
    header模式在实际使用中较少,本文只对前三种模式进行比较。
    性能排序:fanout > direct >> topic

    。比例大约为11:10:6



    六、关键字发送

    exchange type = direct

    之前事例,发送消息时明确指定某个队列并向其中发送消息,RabbitMQ还支持根据关键字发送,即:队列绑定关键字,发送者将数据根据关键字发送到消息exchange,exchange根据 关键字 判定应该将数据发送至指定队列。

    1.生产者:


    import pika
    import sys

    connection
    = pika.BlockingConnection(pika.ConnectionParameters(
    host='localhost'))
    channel
    = connection.channel()

    channel.exchange_declare(
    exchange='direct_logs',
    type='direct')

    result
    = channel.queue_declare(exclusive=True)
    queue_name
    = result.method.queue

    severities
    = sys.argv[1:]
    if not severities:
    sys.stderr.write("Usage: %s [info] [warning] [error] " % sys.argv[0])
    sys.exit(
    1)

    for severity in severities:
    channel.queue_bind(exchange='direct_logs',
    queue=queue_name,
    routing_key=severity)

    print(' [*] Waiting for logs. To exit press CTRL+C')

    def callback(ch, method, properties, body):
    print(" [x] %r:%r" % (method.routing_key, body))

    channel.basic_consume(callback,
    queue=queue_name,
    no_ack=True)

    channel.start_consuming()



    2、消费者

    import pika
    import sys

    connection
    = pika.BlockingConnection(pika.ConnectionParameters(
    host='localhost'))
    channel
    = connection.channel()

    channel.exchange_declare(
    exchange='direct_logs',
    type='direct')

    severity
    = sys.argv[1] if len(sys.argv) > 1 else 'info'
    message = ' '.join(sys.argv[2:]) or 'Hello World!'
    channel.basic_publish(exchange='direct_logs',
    routing_key=severity,
    body=message)
    print(" [x] Sent %r:%r" % (severity, message))
    connection.close()





    一、Direct Exchange


    任何发送到Direct Exchange的消息都会被转发到RouteKey中指定的Queue。


    1.一般情况可以使用rabbitMQ自带的Exchange:”"(该Exchange的名字为空字符串,下文称其为default Exchange)。
    2.这种模式下不需要将Exchange进行任何绑定(binding)操作
    3.消息传递时需要一个“RouteKey”,可以简单的理解为要发送到的队列名字。
    4.如果vhost中不存在RouteKey中指定的队列名,则该消息会被抛弃。


    二、Fanout Exchange 

                                      


    任何发送到Fanout Exchange的消息都会被转发到与该Exchange绑定(Binding)的所有Queue上。


    1.可以理解为路由表的模式
    2.这种模式不需要RouteKey
    3.这种模式需要提前将Exchange与Queue进行绑定,一个Exchange可以绑定多个Queue,一个Queue可以同多个Exchange进行绑定。
    4.如果接受到消息的Exchange没有与任何Queue绑定,则消息会被抛弃。


    三、Topic Exchange



    任何发送到Topic Exchange的消息都会被转发到所有关心RouteKey中指定话题的Queue上


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









    GitHub:https://github.com/ju-do-it
    个人博客:https://zhangju.lookdoc.cn
    博客园:https://www.cnblogs.com/zhangju
    Copyright ©2020 Ju-do-it
    【转载文章务必保留出处和署名,谢谢!】
  • 相关阅读:
    第二节:Java环境变量配置
    第一节:VS充当IIS的配置步骤(VS2017和VS2019)
    .Net进阶系列(21)-跨域请求
    02-Unity深入浅出(二)
    第十五节:Expression表达式目录树(与委托的区别、自行拼接、总结几类实例间的拷贝)
    01-Unity深入浅出(一)
    第十二节:SQLServer存储过程详解及EFCore调用
    Android 组件系列-----Activity的传值和回传值
    Access大数据高效分页语句
    C#清除HTML样式
  • 原文地址:https://www.cnblogs.com/zhangju/p/5720231.html
Copyright © 2011-2022 走看看