python第十二天-----RabbitMQ
有一位小伙伴说让我去A站写博客可能会有很多人喜欢,真是搞不懂,北方哪里有卖萌?北方默认状态就是这么萌的!再者说了,这明明就是很专注于技术的博客嘛,能不能严肃点!知不知道什么叫帧?
学习到了数据库的相关操作,真是B了狗了,这个破玩意真是无孔不入啊,从第一次接触到现在一直都对数据库处于抵抗状态!好讨厌!所以最后决定,只写rabbitmq相关的博客,数据库什么的,拉黑!
总的来说10.1学习计划还是很失败的!docker学习进度超出了预期,openstakc学习进度超出了预期,python学习进度也超出了预期,主要是没有吃好,至出去撸了一次串,不够过瘾!后天就要上班了,连上7天,wtf!只要别叫去另一个工作地点就好,后天解决rancher,大后天解决ceph,周一看看有多少小伙伴跑路.....(第一次遇到跑路比我还积极的,而且一次还碰到一群#24)
专注RabbitMQ(pip install pika)
消息队列服务器,可以对业务进行解耦,实现业务缓解消峰,当然保证业务可靠性也有一些,具体的,去百度吧!开发帖里不写运维
1.基本的使用
#!/usr/bin/env python
# ########################## 消费者 ##########################
import pika connection = pika.BlockingConnection(pika.ConnectionParameters(
host='172.16.5.7'))
channel = connection.channel() # 与服务器创建连接 channel.queue_declare(queue='hello') # 与hello队列关联 def callback(ch, method, properties, body):
print(" [x] Received %r" % body) channel.basic_consume(callback,
queue='hello',
no_ack=True) # 从hello队列里取出一条消息 channel.start_consuming()
#!/usr/bin/env python
# ######################### 生产者 #########################
import pika connection = pika.BlockingConnection(pika.ConnectionParameters(
host='172.16.5.7'))
channel = connection.channel() # 与服务器创建连接 channel.queue_declare(queue='hello') # 与hello队列关联 channel.basic_publish(exchange='', # 向hello队列里放入消息'Hello World!'
routing_key='hello',
body='Hello World!')
connection.close()
2.在消费者端出现状况时保证消息不丢失,只有收到ack回文后该消息才会被确认消费消除,否则仍然会存在于队列当中,会影响性能,自行取舍
#!/usr/bin/env python
# ########################## 消费者 ##########################
import pika connection = pika.BlockingConnection(pika.ConnectionParameters(
host='172.16.5.7'))
channel = connection.channel() channel.queue_declare(queue='hello') def callback(ch, method, properties, body):
print(" [x] Received %r" % body)
ch.basic_ack(delivery_tag=method.delivery_tag) # 这里 channel.basic_consume(callback,
queue='hello',
no_ack=False) # 这里 channel.start_consuming()
3.生产者在产生消息时可决定是否将此消息持久化到磁盘上,可保证消息队列服务器本身出现问题时消息不丢失
#!/usr/bin/env python
# ######################### 生产者 #########################
import pika connection = pika.BlockingConnection(pika.ConnectionParameters(
host='172.16.5.7'))
channel = connection.channel() channel.queue_declare(queue='hello', durable=True) # 这里 channel.basic_publish(exchange='',
routing_key='hello',
body='Hello World!',
properties = pika.BasicProperties(delivery_mode=2,)) # 这里
connection.close()
4.rmq默认是由消费者个数来各自消费自己对应的任务,为防止某任务消费时间过长卡服务
#!/usr/bin/env python
# ########################## 消费者 ##########################
import pika connection = pika.BlockingConnection(pika.ConnectionParameters(
host='172.16.5.7'))
channel = connection.channel() channel.queue_declare(queue='hello') def callback(ch, method, properties, body):
print(" [x] Received %r" % body)
ch.basic_ack(delivery_tag=method.delivery_tag) channel.basic_qos(prefetch_count=1) # 谁来谁取任务,一个接一个 channel.basic_consume(callback,
queue='hello',
no_ack=False) channel.start_consuming()
5.发布订阅(上面的功能也是支持的哦):发布订阅会将收到的任务消息放入所有订阅者,而普通的被消费一次就gg思密达了
此时就要用到exchange功能了,由他来关联对应的队列,关联方式有三种(完全发布fanout,关键字发布direct,模糊匹配关键字发布topic)
完全发布模式
#!/usr/bin/env python
# ########################## 消费者 ##########################
import pika connection = pika.BlockingConnection(pika.ConnectionParameters(
host='172.16.5.7'))
channel = connection.channel() channel.exchange_declare(exchange='logs', # exchange的名称
type='fanout') # exchange的类型,完全发布 result = channel.queue_declare(exclusive=True)
queue_name = result.method.queue # 随机生成一个队列名(对于我这种起名困哪户简直是福音...) channel.queue_bind(exchange='logs',
queue=queue_name) # 将刚才的队列绑定到exchange中 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
# ######################### 生产者 #########################
import pika connection = pika.BlockingConnection(pika.ConnectionParameters(host='172.16.5.7'))
channel = connection.channel()
channel.exchange_declare(exchange='logs', type='fanout')
message = ''
channel.basic_publish(exchange='logs', routing_key='', body=message) # 向exchange里发布消息
print('[x] send %s' % message)
connection.close()
关键字模式
#!/usr/bin/env python
# ######################### 消费者 #########################
import pika connection = pika.BlockingConnection(pika.ConnectionParameters(host='172.16.5.7'))
channel = connection.channel()
channel.exchange_declare(exchange='direct_logs', type='direct') # 关键字模式
result = channel.queue_declare(exclusive=True)
queue_name = result.method.queue
severities = ['info', 'error', 'warning'] # 关键字3个 for severity in severities:
channel.queue_bind(exchange='direct_logs',
queue=queue_name,
routing_key=severity) def call_back(ch, method, properties, body):
print(" [x] %r:%r" % (method.routing_key, body)) channel.basic_consume(call_back,
queue=queue_name,
no_ack=True) channel.start_consuming()
#!/usr/bin/env python
# ######################### 消费者 #########################
import pika connection = pika.BlockingConnection(pika.ConnectionParameters(host='172.16.5.7'))
channel = connection.channel()
channel.exchange_declare(exchange='direct_logs', type='direct')
result = channel.queue_declare(exclusive=True)
queue_name = result.method.queue
severities = ['error'] # 关键字1个 for severity in severities:
channel.queue_bind(exchange='direct_logs',
queue=queue_name,
routing_key=severity) def call_back(ch, method, properties, body):
print(" [x] %r:%r" % (method.routing_key, body)) channel.basic_consume(call_back,
queue=queue_name,
no_ack=True) channel.start_consuming()
#!/usr/bin/env python
# ########################## 生产者 ##########################
import pika connection = pika.BlockingConnection(pika.ConnectionParameters(host='172.16.5.7'))
channel = connection.channel() channel.exchange_declare(exchange='direct_logs',
type='direct') severity = 'info' # 关键字'info'只有一个队列收取
# severity = 'error' # 关键字'error'都收取
message = ''
channel.basic_publish(exchange='direct_logs',
routing_key=severity,
body=message)
print(" [x] Sent %r:%r" % (severity, message))
connection.close()
模糊匹配模式(我不用....)
# 表示可以匹配 0 个 或 多个 单词
* 表示只能匹配 一个 单词
abc.aaaaa abc.# 不匹配
abc.aaaaa abc.* 匹配
想要吃好吃的食物
python第十二天-----RabbitMQ的更多相关文章
- Python第二十二天 stat模块 os.chmod方法 os.stat方法 pwd grp模块
Python第二十二天 stat模块 os.chmod方法 os.stat方法 pwd grp模块 stat模块描述了os.stat(filename)返回的文件属性列表中各值的意义,根据 ...
- python 学习分享-rabbitmq
一.RabbitMQ 消息队列介绍 RabbitMQ也是消息队列,那RabbitMQ和之前python的Queue有什么区别么? py 消息队列: 线程 queue(同一进程下线程之间进行交互) 进程 ...
- 孤荷凌寒自学python第二十二天python类的继承
孤荷凌寒自学python第二十二天python类的继承 (完整学习过程屏幕记录视频地址在文末,手写笔记在文末) python中定义的类可以继承自其它类,所谓继承的概念,我的理解 是,就是一个类B继承自 ...
- 19.python笔记之Rabbitmq
RabbitMQ是一个在AMQP基础上完整的,可复用的企业消息系统.他遵循Mozilla Public License开源协议. MQ全称为Message Queue, 消息队列(MQ)是一种应用程序 ...
- Python并发编程-RabbitMQ消息队列
RabbitMQ队列 RabbitMQ是一个在AMQP基础上完整的,可复用的企业消息系统.他遵循Mozilla Public License开源协议. MQ全称为Message Queue, 消息队列 ...
- Python中使用RabbitMQ
一 RabbitMQ简介 RabbitMQ是一个在AMQP基础上完整的,可复用的企业消息系统.他遵循Mozilla Public License开源协议. MQ全称为Message Queue, 消息 ...
- python中使用rabbitmq消息中间件
上周一直在研究zeromq,并且也实现了了zeromq在python和ruby之间的通信,但是如果是一个大型的企业级应用,对消息中间件的要求比较高,比如消息的持久化机制以及系统崩溃恢复等等需求,这个时 ...
- python网络编程--RabbitMQ
一:RabbitMQ介绍 RabbitMQ是AMPQ(高级消息协议队列)的标准实现.也就是说是一种消息队列. 二:RabbitMQ和线程进程queue区别 线程queue:不能跨进程,只能用于多个线程 ...
- python 消息队列-rabbitMQ 和 redis介绍使用
1.rabbitMQ 与ptyhon 进程queue 区别.进程queue 主要用户Python父子进程之间或者统一进程不同子进程.rabbit可以用户不同语言之前的相互交流,socket可以实现同样 ...
随机推荐
- C++访问托管类(C#类库)
1.新建C# 类库项目Airth,新建类 using System; using System.Collections.Generic; using System.Linq; using System ...
- lua学习记录
1.八种数据类型:number,string,boolean,nil,function,table,协程,自定义类型 空字符串和数字0是真,false和nil为假2.lua是动态语言,每个变量携带自己 ...
- windows环境下局域网内无法访问apache站点
DocumentRoot "D:/wamp/www/" <Directory /> AllowOverride none order deny,allo ...
- MyEclipse Spring 学习总结一 Spring IOC容器
一.Spring IOC容器---- Spring AllicationContext容器 程序的结构如下: 1.首先在MyEclipse 创建创建Java Project 2.创建好后,添加spin ...
- Spring-MVC开发之全局异常捕获全面解读
异常,异常 我们一定要捕获一切该死的异常,宁可错杀一千也不能放过一个! 产品上线后的异常更要命,一定要屏蔽错误内容,以免暴露敏感信息! 在用Spring MVC开发WEB应用时捕获全局异常的方法基本有 ...
- WCF JSON DATETIME JSON.NET (Newtonsoft.Json.dll)
[DataMember] public DateTime? myTime { get; set; } var timeFormat = new JsonSerializerSettings() { D ...
- Apache Shiro 使用手册(三)Shiro 授权
授权即访问控制,它将判断用户在应用程序中对资源是否拥有相应的访问权限. 如,判断一个用户有查看页面的权限,编辑数据的权限,拥有某一按钮的权限,以及是否拥有打印的权限等等. 一.授权的三要素 授权有着三 ...
- python标准库xml.etree.ElementTree的bug
使用python生成或者解析xml的方法用的最多的可能就数python标准库xml.etree.ElementTree和lxml了,在某些环境下使用xml.etree.ElementTree更方便一些 ...
- Mysql备份迁移——Mysqldump(.NET调用Mysqldump.exe方式)——(解决视图嵌视图报错)
利用Mysqldump备份和迁移,我想很多人都用过,具体参数不介绍了,这里主要讲.NET调用Mysqldump进行备份和.NET调用Mysql.exe进行导入数据. 这里使用的是5.1版的Mysqld ...
- 实习日记:图像检索算法 LSH 的总结与分析(matlab)
最开始仿真和精度测试,基于 matlab 完成的. Demo_MakeTable.m (生成 Hash 表) %======================================== %** ...