有一位小伙伴说让我去A站写博客可能会有很多人喜欢,真是搞不懂,北方哪里有卖萌?北方默认状态就是这么萌的!再者说了,这明明就是很专注于技术的博客嘛,能不能严肃点!知不知道什么叫帧?

学习到了数据库的相关操作,真是B了狗了,这个破玩意真是无孔不入啊,从第一次接触到现在一直都对数据库处于抵抗状态!好讨厌!所以最后决定,只写rabbitmq相关的博客,数据库什么的,拉黑!

总的来说10.1学习计划还是很失败的!docker学习进度超出了预期,openstakc学习进度超出了预期,python学习进度也超出了预期,主要是没有吃好,至出去撸了一次串,不够过瘾!后天就要上班了,连上7天,wtf!只要别叫去另一个工作地点就好,后天解决rancher,大后天解决ceph,周一看看有多少小伙伴跑路.....(第一次遇到跑路比我还积极的,而且一次还碰到一群#24)

专注RabbitMQ(pip install pika)

消息队列服务器,可以对业务进行解耦,实现业务缓解消峰,当然保证业务可靠性也有一些,具体的,去百度吧!开发帖里不写运维

1.基本的使用

  1. #!/usr/bin/env python
  2. # ########################## 消费者 ##########################
  3. import pika
  4.  
  5. connection = pika.BlockingConnection(pika.ConnectionParameters(
  6. host='172.16.5.7'))
  7. channel = connection.channel() # 与服务器创建连接
  8.  
  9. channel.queue_declare(queue='hello') # 与hello队列关联
  10.  
  11. def callback(ch, method, properties, body):
  12. print(" [x] Received %r" % body)
  13.  
  14. channel.basic_consume(callback,
  15. queue='hello',
  16. no_ack=True) # 从hello队列里取出一条消息
  17.  
  18. channel.start_consuming()
  1. #!/usr/bin/env python
  2. # ######################### 生产者 #########################
  3. import pika
  4.  
  5. connection = pika.BlockingConnection(pika.ConnectionParameters(
  6. host='172.16.5.7'))
  7. channel = connection.channel() # 与服务器创建连接
  8.  
  9. channel.queue_declare(queue='hello') # 与hello队列关联
  10.  
  11. channel.basic_publish(exchange='', # 向hello队列里放入消息'Hello World!'
  12. routing_key='hello',
  13. body='Hello World!')
  14. connection.close()

2.在消费者端出现状况时保证消息不丢失,只有收到ack回文后该消息才会被确认消费消除,否则仍然会存在于队列当中,会影响性能,自行取舍

  1. #!/usr/bin/env python
  2. # ########################## 消费者 ##########################
  3. import pika
  4.  
  5. connection = pika.BlockingConnection(pika.ConnectionParameters(
  6. host='172.16.5.7'))
  7. channel = connection.channel()
  8.  
  9. channel.queue_declare(queue='hello')
  10.  
  11. def callback(ch, method, properties, body):
  12. print(" [x] Received %r" % body)
  13. ch.basic_ack(delivery_tag=method.delivery_tag) # 这里
  14.  
  15. channel.basic_consume(callback,
  16. queue='hello',
  17. no_ack=False) # 这里
  18.  
  19. channel.start_consuming()

3.生产者在产生消息时可决定是否将此消息持久化到磁盘上,可保证消息队列服务器本身出现问题时消息不丢失

  1. #!/usr/bin/env python
  2. # ######################### 生产者 #########################
  3. import pika
  4.  
  5. connection = pika.BlockingConnection(pika.ConnectionParameters(
  6. host='172.16.5.7'))
  7. channel = connection.channel()
  8.  
  9. channel.queue_declare(queue='hello', durable=True) # 这里
  10.  
  11. channel.basic_publish(exchange='',
  12. routing_key='hello',
  13. body='Hello World!',
  14. properties = pika.BasicProperties(delivery_mode=2,)) # 这里
  15. connection.close()

4.rmq默认是由消费者个数来各自消费自己对应的任务,为防止某任务消费时间过长卡服务

  1. #!/usr/bin/env python
  2. # ########################## 消费者 ##########################
  3. import pika
  4.  
  5. connection = pika.BlockingConnection(pika.ConnectionParameters(
  6. host='172.16.5.7'))
  7. channel = connection.channel()
  8.  
  9. channel.queue_declare(queue='hello')
  10.  
  11. def callback(ch, method, properties, body):
  12. print(" [x] Received %r" % body)
  13. ch.basic_ack(delivery_tag=method.delivery_tag)
  14.  
  15. channel.basic_qos(prefetch_count=1) # 谁来谁取任务,一个接一个
  16.  
  17. channel.basic_consume(callback,
  18. queue='hello',
  19. no_ack=False)
  20.  
  21. channel.start_consuming()

5.发布订阅(上面的功能也是支持的哦):发布订阅会将收到的任务消息放入所有订阅者,而普通的被消费一次就gg思密达了

此时就要用到exchange功能了,由他来关联对应的队列,关联方式有三种(完全发布fanout,关键字发布direct,模糊匹配关键字发布topic)

完全发布模式

  1. #!/usr/bin/env python
  2. # ########################## 消费者 ##########################
  3. import pika
  4.  
  5. connection = pika.BlockingConnection(pika.ConnectionParameters(
  6. host='172.16.5.7'))
  7. channel = connection.channel()
  8.  
  9. channel.exchange_declare(exchange='logs', # exchange的名称
  10. type='fanout') # exchange的类型,完全发布
  11.  
  12. result = channel.queue_declare(exclusive=True)
  13. queue_name = result.method.queue # 随机生成一个队列名(对于我这种起名困哪户简直是福音...)
  14.  
  15. channel.queue_bind(exchange='logs',
  16. queue=queue_name) # 将刚才的队列绑定到exchange中
  17.  
  18. def callback(ch, method, properties, body):
  19. print(" [x] %r" % body)
  20.  
  21. channel.basic_consume(callback,
  22. queue=queue_name,
  23. no_ack=True)
  24.  
  25. channel.start_consuming()
  1. #!/usr/bin/env python
  2. # ######################### 生产者 #########################
  3. import pika
  4.  
  5. connection = pika.BlockingConnection(pika.ConnectionParameters(host='172.16.5.7'))
  6. channel = connection.channel()
  7. channel.exchange_declare(exchange='logs', type='fanout')
  8. message = ''
  9. channel.basic_publish(exchange='logs', routing_key='', body=message) # 向exchange里发布消息
  10. print('[x] send %s' % message)
  11. connection.close()

关键字模式

  1. #!/usr/bin/env python
  2. # ######################### 消费者 #########################
  3. import pika
  4.  
  5. connection = pika.BlockingConnection(pika.ConnectionParameters(host='172.16.5.7'))
  6. channel = connection.channel()
  7. channel.exchange_declare(exchange='direct_logs', type='direct') # 关键字模式
  8. result = channel.queue_declare(exclusive=True)
  9. queue_name = result.method.queue
  10. severities = ['info', 'error', 'warning'] # 关键字3个
  11.  
  12. for severity in severities:
  13. channel.queue_bind(exchange='direct_logs',
  14. queue=queue_name,
  15. routing_key=severity)
  16.  
  17. def call_back(ch, method, properties, body):
  18. print(" [x] %r:%r" % (method.routing_key, body))
  19.  
  20. channel.basic_consume(call_back,
  21. queue=queue_name,
  22. no_ack=True)
  23.  
  24. channel.start_consuming()
  1. #!/usr/bin/env python
  2. # ######################### 消费者 #########################
  3. import pika
  4.  
  5. connection = pika.BlockingConnection(pika.ConnectionParameters(host='172.16.5.7'))
  6. channel = connection.channel()
  7. channel.exchange_declare(exchange='direct_logs', type='direct')
  8. result = channel.queue_declare(exclusive=True)
  9. queue_name = result.method.queue
  10. severities = ['error'] # 关键字1个
  11.  
  12. for severity in severities:
  13. channel.queue_bind(exchange='direct_logs',
  14. queue=queue_name,
  15. routing_key=severity)
  16.  
  17. def call_back(ch, method, properties, body):
  18. print(" [x] %r:%r" % (method.routing_key, body))
  19.  
  20. channel.basic_consume(call_back,
  21. queue=queue_name,
  22. no_ack=True)
  23.  
  24. channel.start_consuming()
  1. #!/usr/bin/env python
  2. # ########################## 生产者 ##########################
  3. import pika
  4.  
  5. connection = pika.BlockingConnection(pika.ConnectionParameters(host='172.16.5.7'))
  6. channel = connection.channel()
  7.  
  8. channel.exchange_declare(exchange='direct_logs',
  9. type='direct')
  10.  
  11. severity = 'info' # 关键字'info'只有一个队列收取
  12. # severity = 'error' # 关键字'error'都收取
  13. message = ''
  14. channel.basic_publish(exchange='direct_logs',
  15. routing_key=severity,
  16. body=message)
  17. print(" [x] Sent %r:%r" % (severity, message))
  18. connection.close()

模糊匹配模式(我不用....)

# 表示可以匹配 0 个 或 多个 单词

*  表示只能匹配 一个 单词

abc.aaaaa    abc.# 不匹配

abc.aaaaa    abc.* 匹配

想要吃好吃的食物

python第十二天-----RabbitMQ的更多相关文章

  1. Python第二十二天 stat模块 os.chmod方法 os.stat方法 pwd grp模块

    Python第二十二天   stat模块  os.chmod方法  os.stat方法  pwd  grp模块 stat模块描述了os.stat(filename)返回的文件属性列表中各值的意义,根据 ...

  2. python 学习分享-rabbitmq

    一.RabbitMQ 消息队列介绍 RabbitMQ也是消息队列,那RabbitMQ和之前python的Queue有什么区别么? py 消息队列: 线程 queue(同一进程下线程之间进行交互) 进程 ...

  3. 孤荷凌寒自学python第二十二天python类的继承

    孤荷凌寒自学python第二十二天python类的继承 (完整学习过程屏幕记录视频地址在文末,手写笔记在文末) python中定义的类可以继承自其它类,所谓继承的概念,我的理解 是,就是一个类B继承自 ...

  4. 19.python笔记之Rabbitmq

    RabbitMQ是一个在AMQP基础上完整的,可复用的企业消息系统.他遵循Mozilla Public License开源协议. MQ全称为Message Queue, 消息队列(MQ)是一种应用程序 ...

  5. Python并发编程-RabbitMQ消息队列

    RabbitMQ队列 RabbitMQ是一个在AMQP基础上完整的,可复用的企业消息系统.他遵循Mozilla Public License开源协议. MQ全称为Message Queue, 消息队列 ...

  6. Python中使用RabbitMQ

    一 RabbitMQ简介 RabbitMQ是一个在AMQP基础上完整的,可复用的企业消息系统.他遵循Mozilla Public License开源协议. MQ全称为Message Queue, 消息 ...

  7. python中使用rabbitmq消息中间件

    上周一直在研究zeromq,并且也实现了了zeromq在python和ruby之间的通信,但是如果是一个大型的企业级应用,对消息中间件的要求比较高,比如消息的持久化机制以及系统崩溃恢复等等需求,这个时 ...

  8. python网络编程--RabbitMQ

    一:RabbitMQ介绍 RabbitMQ是AMPQ(高级消息协议队列)的标准实现.也就是说是一种消息队列. 二:RabbitMQ和线程进程queue区别 线程queue:不能跨进程,只能用于多个线程 ...

  9. python 消息队列-rabbitMQ 和 redis介绍使用

    1.rabbitMQ 与ptyhon 进程queue 区别.进程queue 主要用户Python父子进程之间或者统一进程不同子进程.rabbit可以用户不同语言之前的相互交流,socket可以实现同样 ...

随机推荐

  1. MongoDB学习笔记三:查询

    MongoDB中使用find来进行查询.查询就是返回一个集合中文档的子集,子集合的范围从0个文档到整个集合.find的第一个参数决定了要返回哪些文档,其形式也是一个文档,说明要执行的查询细节.空的查询 ...

  2. mysql命令行工具

    mysql包相关命令行工具 [root@manage ~]# rpm -qa|grep mysql mysql-server-5.1.73-5.el6_7.1.x86_64 mysql-5.1.73- ...

  3. 快速使用node.js进行web开发

    首先关于node.js的学习,这里推荐一本比较好的教程,nodejs web开发指南,该书通俗易懂地将node.js语言特性讲解完之后,又从一个项目角度带领读者使用node.js学习web开发.相信这 ...

  4. chrome常用配置

    插件类: Gestures for Google Chrome 增加鼠标手势 安装后需重启 JSONView 自动格式化页面输出的json数据

  5. JSP页面的隐含对象和Servlet程序里的对象之间的关联和区别

    首先,有两个概念: 1.JSP页面的域对象:pageContext,request,session,application对象(四个) void setAttribute(String name,Ob ...

  6. CrashHandler: java.lang.NullPointerException

    08-29 20:33:47.305 20636-20636/com.tongyan.subway.inspect D/AndroidRuntime: Shutting down VM 08-29 2 ...

  7. JavaScript 在不刷新或跳转页面的情况下改变当前浏览器地址栏上的网址

    JavaScript 在不刷新或跳转页面的情况下改变当前浏览器地址栏上的网址 var stateObject = {}; var title = "改变后的网址的标题"; var ...

  8. Linux 下没有conio.h 已解决

    原文:http://blog.sina.com.cn/s/blog_6a95e00b0100zqvf.html #include <stdio.h>//#include <conio ...

  9. JavaScript list 去重复

    function unique(arr) { var result = [], hash = {}; for (var i = 0, elem; (elem = arr[i]) != null; i+ ...

  10. unity3d c#脚本定义Transform

    Transform n = Instantiate(newobject,transform.position,transform.rotation) as Transform;Instantiate返 ...