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

[经验分享] Python RabbitMQ fanout-90SirDB

[复制链接]

尚未签到

发表于 2018-8-12 08:52:19 | 显示全部楼层 |阅读模式
#########################消费者################################  
#!/usr/bin/env python
  
# -*- coding:utf-8 -*-
  
# author: Changhua Gong
  
import pika
  
'''
  
fanout模式:类似收音机的广播模式,
  
接收者(消费者)在的话,则接收;接收者不在的话,消息错过了就没有了。
  
'''
  
connection = pika.BlockingConnection(pika.ConnectionParameters(
  
    host='localhost'))
  
channel = connection.channel()
  
channel.exchange_declare(exchange='logs',  # 和生产者对绑定
  
                         type='fanout')
  
# 声明对应queue,生产者不需声明
  
# 不指定queue名字,rabbit会随机分配一个名字,exclusive=True会在使用此queue的消费者断开后,自动将queue删除
  
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()
      
    #########################生产者################################
      
    #!/usr/bin/env python
      
    # -*- coding:utf-8 -*-
      
    # author: Changhua Gong
      
    import pika
      
    import sys
      
    '''
      
    fanout: 所有bind到此exchange的queue都可以接收消息
      
    '''
      
    connection = pika.BlockingConnection(pika.ConnectionParameters(
      
        host='localhost'))
      
    channel = connection.channel()
      
    # 生产者不需要声明queue
      
    channel.exchange_declare(exchange='logs',  # 指定exchanger的名字,随意
      
                             type='fanout')  # 类型需指定fanout
      
    message = ' '.join(sys.argv[1:]) or "info: Hello World!"  # 默认输出参数,否则。。。
      
    channel.basic_publish(exchange='logs',
      
                          routing_key='', # 不需指定具体的routing_key,但是要写
      
                          body=message)
      
    print(" [x] Sent %r" % message)
      
    connection.close()

  • 运维网声明 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-550440-1-1.html 上篇帖子: python学习之多态 下篇帖子: python未完结
    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

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

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

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

    扫描微信二维码查看详情

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


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


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


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



    合作伙伴: 青云cloud

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