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

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

[复制链接]

尚未签到

发表于 2017-12-9 18:34:33 | 显示全部楼层 |阅读模式
  rabbitmq_server_topic    topic模式


DSC0000.gif DSC0001.gif


#!/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 级别
routing_key= sys.argv[1] if len(sys.argv) > 1 else 'anorrymous.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,#默认的消息队列级别
                           routing_key=routing_key,#默认的消息队列级别
                           body=msg+str(i),
                           #properties=pika.BasicProperties(delivery_mode=2)#持久化 广播不能使用
                            )
     #print(msg,severity)
     print(msg,routing_key)
connection.close()
#channel.close()
View Code  topic_client:  可按级别来接收  广播





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

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

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

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

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

#for severity in severities:#循环接收各级别的消息
for severity in binding_key:#循环接收各级别的消息
     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

  • 运维网声明 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-422483-1-1.html 上篇帖子: 选择排序 下篇帖子: C++字符串操作二
    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

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

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

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

    扫描微信二维码查看详情

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


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


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


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



    合作伙伴: 青云cloud

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