设为首页 收藏本站
查看: 792|回复: 0

[经验分享] RabbitMQ(python实现)学习之二:Producer发送消息至多个消息队列queue(广播消息)

[复制链接]

尚未签到

发表于 2015-12-1 12:02:34 | 显示全部楼层 |阅读模式
  1.1本部分内容简介
  这部分我们将要发送一个消息到多个Consumer,这部分称之为“publish/subscribe”
  我们实现的方式就是发送端,发送一个消息,与此同时,多个接收端将同时接收到消息并打印在屏幕上面。
  1.2exchange简介
  在前面的博文中,我们的讲解是:发送端发送消息至消息队列,接收端从消息队列获取消息。现在我们来介绍一下rabbitmq的完整消息传送模型。
  >Producer:用来发送消息的应用程序
  >queue:用来存储消息的缓存
  >Consumer:用来接收消息的应用程序
  消息传送模型的核心是,Producer从不会直接将消息传送给queue,而是,将消息传送给exchange,exchange是个很简单的东西,在一侧,他接收来自Producer的消息,另一侧将消息传送给queue。exchange将消息传送给你个queue,还是传送给多个queue,这主要是由exchange的type决定。模型图如下:
           DSC0000.png
  
  exchange有很多type可用,如下:direct、topic、headers、fanout。本博客针对fanout讲解,后续博文对其他类型有所讲解,让我们创建一个exchange,type为fanout,名字为logs,代码如下:



channel.exchange(exchange='logs',type='fanout')
  对于type为fanout的exchange,理解起来非常简单,它将接收到的消息,广播给他所知道的所有的queue,即所有和他建立连接的queue。前面的博文降到了命令行查看list_exchanges的命令如下:



$ :sudo rabbitmqctl list_exchanges
Listing exchanges ...
logs      fanout
amq.direct      direct
amq.topic       topic
amq.fanout      fanout
amq.headers     headers
...done.
  对于上图中,你会看到很多amq.*的exchange,这些是系统默认建立的,在你不建立exchange时,系统默认建立上面几个。
  对于消息的发布函数basic_publish()也随之变为:



channel.basic_publish(exchange='logs',routing_key='',body=message)
  1.3临时queue
  正如你前面学到的,对于一个queue,会有自己的名字(hello什么的),
  首先:



result = channel.queue_declare()
  然后通过result.method.queue,系统会随机给queue命名。
  如果我们想Producer与Consumer断开连接时,队列queue删除,那么需要改成下面的代码:



result = channel.queue_declare(exclusive=True)
  1.4Bingings(将queue与exchange绑定)
  模型图如下:
DSC0001.png
  我们已经创建了一个type为fanout的exchange,现在,我们要告诉exchange,将消息发送给我们自己定义的queue,在exchange与queue之间建立连接的是binding,代码如下:



channel.queue_bind(exchange='logs',queue=result.method.queue)
  在命令行查看binding的列表,命令如下:



$: sudo rabbitmqctl list_bindings
   1.5最终代码
  最终的模型如下:
DSC0002.png
  send.py代码如下:



import pika
import sys
connection = pika.BlockingConnection(pika.ConnectionParameters(
host='localhost'))
channel = connection.channel()
channel.exchange_declare(exchange='logs',
type='fanout')
message = ' '.join(sys.argv[1:]) or "info: Hello World!"  #如果键盘有输入,message为键盘输入,如果键盘没有输入,消息message="info: Hello World!";
channel.basic_publish(exchange='logs', routing_key='', body=message) print " [x] Sent %r" % (message,) connection.close()
  
  receive.py代码



import pika
connection = pika.BlockingConnection(pika.ConnectionParameters(
host='localhost'))
channel = connection.channel()
channel.exchange_declare(exchange='logs',
type='fanout')
result = channel.queue_declare(exclusive=True)
queue_name = result.method.queue
channel.queue_bind(exchange='logs',
queue=queue_name)
print '
  • Waiting for logs. To exit press CTRL+C'
    def callback(ch, method, properties, body):
    print " [x] %r" % (body,)
    channel.basic_consume(callback,
    queue=queue_name,
    no_ack=True)
    channel.start_consuming()
      1.6代码测试
      开启一个命令行窗口,运行send.py:



    $: python send.py   #(此时你传送的内容为info: Hello World!)或者  
    $: python send.py message #message为你想发送的内容
      开启两个命令行窗口,分别运行receive.py,两个窗口你会看到有相同的消息输出:



    $: python receive.py
      

  • 运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
    2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
    3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
    4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
    5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
    6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
    7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
    8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

    所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-145840-1-1.html 上篇帖子: 径向基(RBF)神经网络python实现 下篇帖子: 再议使用Python批量裁切栅格
    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    扫码加入运维网微信交流群X

    扫码加入运维网微信交流群

    扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

    扫描微信二维码查看详情

    客服E-mail:kefu@iyunv.com 客服QQ:1061981298


    QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


    提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


    本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



    合作伙伴: 青云cloud

    快速回复 返回顶部 返回列表