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

[经验分享] python第五十七天------补上笔记

[复制链接]

尚未签到

发表于 2017-12-9 17:32:25 | 显示全部楼层 |阅读模式
  direct_client:广播接收


DSC0000.gif DSC0001.gif


#!/usr/bin/env python
#_*_coding:utf-8_*_
import pika,time,sys

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

channel.exchange_declare(exchange='direct_logs',#定义一个接收的频道
                          type='direct')

reult=channel.queue_declare(exclusive=True)#随机生成唯一的队列名,会在消息接收后自动删除
queuename=reult.method.queue#队列名 自动生成

severities = sys.argv[1:]
if not severities:
     sys.stderr.write("Usage: %s [info] [warning] [error]\n" % sys.argv[0])#启动接收的消息级别
     sys.exit(1)

for severity in severities:#循环接收各级别的消息
     channel.queue_bind(exchange='direct_logs',
                        queue=queuename,
                        routing_key=severity)

def callback(ch, method, properties, body):#回调函数
     print('接收消息中…………')
     #time.sleep(5)
     print(" [x] Received %r" % body.decode())
     ch.basic_ack(delivery_tag=method.delivery_tag)

channel.basic_qos(prefetch_count=1)#同时只处理一个消息
channel.basic_consume(callback,#接收到消息调用回调函数 callback
                       queue=queuename,
                       #no_ack=True
                        )

print('
  • 接收消息中. To exit press CTRL+C')

    channel.start_consuming()#启动消息接收
    View Code  rabbitmq_server_direct 服务端 广播





    #!/usr/bin/env python
    #{data} {time}
    #_*_coding:utf-8_*_
    import pika,sys,time
    connection = pika.BlockingConnection(pika.ConnectionParameters(
                    'localhost'))
    channel = connection.channel()#管道

    severity = sys.argv[1] if len(sys.argv) > 1 else 'info'#启动参数 默认无参数为 info 级别
    msg=''.join(sys.argv[2:]) or  'info:消息默认发送………'#启动参数 为空,发默认消息
    for i in range(10):
         time.sleep(1)
         channel.basic_publish(exchange='direct_logs',#绑定频道
                               routing_key=severity,#默认的消息队列级别
                               body=msg+str(i),
                               #properties=pika.BasicProperties(delivery_mode=2)#持久化 广播不能使用
                                )
         print(msg,severity)
    connection.close()
    #channel.close()
    View Code  rabbitmq_server:


    View Code  rabbitmq_server_2: 消息持久化





    import pika
    connection = pika.BlockingConnection(pika.ConnectionParameters(
                    'localhost'))
    channel = connection.channel()#管道
    #声明queue
    #channel.queue_declare(queue='hello')#队列名 hello
    channel.queue_declare(queue='hello',durable=True)#队列名 hello,持久化队列
    for i in range(10):

         channel.basic_publish(exchange='',
                               routing_key='hello',
                               body='Hello World!%s'%i,
                               properties=pika.BasicProperties(delivery_mode=2))
         print(" [x] Sent 'Hello World!'",i)
    connection.close()
    View Code  rabbitmq_server_fanout.   fanout 模式发送端





    import pika,sys,time
    connection = pika.BlockingConnection(pika.ConnectionParameters(
                    'localhost'))
    channel = connection.channel()#管道
    #声明queue 广播模式不用声明队列
    #channel.queue_declare(queue='hello')#队列名 hello
    #channel.queue_declare(queue='hello',durable=True)#队列名 hello,持久化队列
    argv=input('输入消息')
    msg=''.join(sys.argv[1:]) or  'info:消息默认发送………'
    for i in range(10):
         time.sleep(1)
         channel.basic_publish(exchange='logs',#绑定频道
                               #routing_key='hello',
                               routing_key='',
                               body=msg+str(i),
                               #properties=pika.BasicProperties(delivery_mode=2)#持久化 广播不能使用
                                )
         print(msg,i)
    #connection.close()
    View Code  rabbitmq_client_fanout   fanout 接收端





    #!/usr/bin/env python
    #{data} {time}
    #_*_coding:utf-8_*_
    import pika,time

    connection = pika.BlockingConnection(pika.ConnectionParameters(
                    'localhost'))
    channel = connection.channel()
    #channel.queue_declare(queue='hello2')#服务端与客户端的设置需一致,不然会报错
    #channel.queue_declare(queue='hello2',durable=True)#队列名 hello,持久化队列
    channel.exchange_declare(exchange='logs',#绑定频道
                              type='fanout')#接收类型
    reult=channel.queue_declare(exclusive=True)#随机生成唯一的队列名,会在消息接收后自动删除
    queuename=reult.method.queue#队列名 自动生成
    channel.queue_bind(exchange='logs',#先要绑定频道
                        queue=queuename
                        )

    def callback(ch, method, properties, body):#回调函数
         print('接收消息中…………')
         #time.sleep(5)
         print(" [x] Received %r" % body.decode())
         ch.basic_ack(delivery_tag=method.delivery_tag)

    channel.basic_qos(prefetch_count=1)#同时只处理一个消息
    channel.basic_consume(callback,#接收到消息调用回调函数 callback
                           queue=queuename,
                           #no_ack=True
                            )

    print('
  • 接收消息中. To exit press CTRL+C')

    channel.start_consuming()#启动消息接收
    View Code

  • 运维网声明 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-422469-1-1.html 上篇帖子: 架构设计:系统间通信(20)——MQ:消息协议(下) 下篇帖子: Exchanger学习
    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

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

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

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

    扫描微信二维码查看详情

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


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


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


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



    合作伙伴: 青云cloud

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