python浅学【网络服务中间件】之RabbitMQ
一、关于AMQP:
AMQP,即Advanced Message Queuing Protocol,高级消息队列协议。
AMQP使符合要求的客户端应用程序能够与符合要求的消息传递中间件代理进行通信。
AMQP是一种新的消息传递中间件开放标准。它解决了如何跨LANS和WANS连接应用程序的问题。在AMQP之前,没有相互连接应用程序的标准,这是大型软件体系结构中比较昂贵的部分之一。AMQP是一个线级协议,外加一个用于路由和消息排队的模型。它包括非常高性能的发布-订阅(通过单个代理的速度可达每秒150k条消息)和高可靠性的消息传递(无论如何都保证交付)。
AMQP是一种可编程的协议:
定义了三种实体(对象)
queues, exchanges, bindings
queues :队列,存储信息,用于消费
exchanges : 消息中转站,包含多种类型
bindings :消息转发规则,定义了route,规定怎么把消息发送到队列

二、关于RabbitMQ:
RabbitMQ是实现了高级消息队列协议(AMQP)的开源消息代理软件(亦称面向消息的中间件)。RabbitMQ服务器是用Erlang语言编写的,而群集和故障转移是构建在开放电信平台框架上的。所有主要的编程语言均有与代理接口通讯的客户端库。
消息代理的应用:
(1)将消息路由到一个或多个目的地
(2)将消息转换为替代表示
(3)执行消息聚合,将消息分解为多个消息并将其发送到目的地,然后将响应重新组合成一条消息以返回给用户
(4)与外部的存储库交互以扩充消息或存储消息
(5)调用web服务以检索数据
(6)回应事件或错误
(7)使用发布订阅模式提供内容和基于主题的消息路由
三、RabbitMQ交换机exchanges的四种类型:
exchanges 的属性:
name 名字
durability 持久化
auto-delete 自动删除(所有队列都解除绑定的时候)
exchanges 类型: direct exchange,fanout exchange,topic exchange,headers exchange
1、direct exchange:
queue创建时,绑定一个同名的routing key
用途:把任务分配给多个workers, 每个work做特定工作,比如写日志

2、fanout exchange:
传递消息到每一个queue,忽略routeing key
用途:多处记录日志,统一发布通知,球赛更新比分, 分布式系统更新配置信息

3、topic exchange:
根据规则匹配相应的queue, 实现订阅发布
用途:根据不同标签更新新闻,根据位置信息提供商品

4、Headers Exchange
根据多个属性当做消息头,忽略routing key, 需要开发者定义更多内容
用途:当direct 和routeing key 不是字符串时,可使用这个自定义属性匹配

四、python简单操作RabbitMQ:
client端:消费信息
#!/usr/bin/env python
# -*- coding:utf-8 -*-
# msg_worker.py
# Author:Riy import time
import pika # 连接服务
config = {
"username": "root",
"password": "root",
"host": "127.0.0.1",
"port": ""
}
creds = pika.PlainCredentials(config["username"], config["password"])
params = pika.ConnectionParameters(config["host"], credentials=creds)
connection = pika.BlockingConnection(params) # 创建队列
channel = connection.channel()
channel.queue_declare(queue="msg_queue", durable=True) # 接收,消费消息
def callback(ch, method, properties, body):
print(f"收到消息:{body}")
time.sleep(body.count(b"-"))
print('ok')
ch.basic_ack(delivery_tag=method.delivery_tag) # 均衡任务
channel.basic_qos(prefetch_count=1)
channel.basic_consume("msg_queue", callback) channel.start_consuming()
server端:发送信息
#!/usr/bin/env python
# -*- coding:utf-8 -*-
# msg_pub.py
# Author:Riy import sys
import pika # 连接服务
config = {
"username": "root",
"password": "root",
"host": "127.0.0.1",
"port": ""
}
creds = pika.PlainCredentials(config["username"], config["password"])
params = pika.ConnectionParameters(config["host"], credentials=creds)
connection = pika.BlockingConnection(params) # 创建队列
channel = connection.channel()
channel.queue_declare(queue="msg_queue", durable=True) # 发送消息
msg = " ".join(sys.argv[1:]) or "new msg from Riy"
channel.basic_publish(exchange="",
routing_key="msg_queue",
body=msg,
properties=pika.BasicProperties(
delivery_mode=2 # TODO
)) print(f"发送消息:{msg}")
connection.close()
python浅学【网络服务中间件】之RabbitMQ的更多相关文章
- python浅学【网络服务中间件】之Redis
一.关于NoSQL: NoSQL(NoSQL = Not Only SQL ),"不仅仅是SQL". 相比MySQL等关系型数据库,NoSQL为非关系型的数据存储 Nosql中比较 ...
- python浅学【网络服务中间件】之Memcached
一.缓存的由来: 提升性能 绝大多数情况下,select 是出现性能问题最大的地方.一方面,select 会有很多像 join.group.order.like 等这样丰富的语义,而这些语义是非常耗性 ...
- python浅学【网络服务中间件】之Celery
一.关于Celery: 什么是任务队列: 任务队列一般用于线程或计算机之间分配工作的一种机制. 任务队列的输入是一个称为任务的工作单元,有专门的工作进行不断的监视任务队列,进行执行新的任务工作. 什么 ...
- python浅学【网络服务中间件】之MongoDB
一.关于MongoDB: MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统. 在高负载的情况下,添加更多的节点,可以保证服务器性能. MongoDB 旨在为WEB应用提供 ...
- 浅谈surging服务引擎中的rabbitmq组件和容器化部署
1.前言 上个星期完成了surging 的0.9.0.1 更新工作,此版本通过nuget下载引擎组件,下载后,无需通过代码build集成,引擎会通过Sidecar模式自动扫描装配异构组件来构建服务引擎 ...
- greenev —— Python 异步网络服务框架
greenev是一个基于greenlet协程,事件驱动,非阻塞socket模型的Python网络服务框架,它使得可以编写同步的代码,却得到异步执行的优点. 本项目受到gevent, openresty ...
- 浅谈Django的中间件与Python的装饰器
浅谈Django的中间件 与Python的装饰器 一.原理 1.装饰器是Python的一种语法应用,利用闭包的原理去更改一个函数的功能,即让一个函数执行之前先到另外一个函数中执行其他需求语句,在执行该 ...
- iOS WebServiceFramework网络服务框架浅解
网络服务几乎是每一款成功APP的必备条件,打开你手机你会发现里面不用联网的应用数量十只手指可以数出来,就算是一些以独特技术切入市场的APP如美颜相机,都至少加入了分享功能.下面我先做下简单的回顾兼扫盲 ...
- python高级之网络编程
python高级之网络编程 本节内容 网络通信概念 socket编程 socket模块一些方法 聊天socket实现 远程执行命令及上传文件 socketserver及其源码分析 1.网络通信概念 说 ...
随机推荐
- 解决sendmail发送邮件慢的问题
sendmail默认会先监听本机的邮件服务,如果本机邮件服务访问不了,在访问其他的邮件服务器 自己测试将本机主机名(通过hostname命令查看)从/etc/hosts中删除,发送邮件的速度就非常快了 ...
- 你会选永生吗?NASA实验为火星宇航员提供年龄逆转药
宇宙辐射不仅是宇航员面临的问题.在乘坐飞机的过程中,我们所有人都会暴露在宇宙辐射中.一趟从伦敦到新加坡再到墨尔本的飞行中,人体受到的辐射量就相当于进行一次胸部X射线透视. 在去年12月NASA举 ...
- CountDownLatch源码探究 (JDK 1.8)
CountDownLatch能够实现让线程等待某个计数器倒数到零的功能,之前对它的了解也仅仅是简单的使用,对于其内部如何实现线程等待却不是很了解,最好的办法就是通过看源码来了解底层的实现细节.Coun ...
- Java中如何更优雅的处理空值
经常看到项目中存在到处空值判断的情况,这些判断,会让人觉得摸不着头绪,它的出现很有可能和当前的业务逻辑并没有关系.但它会让你很头疼.有时候,更可怕的是系统因为这些空值的情况,会抛出空指针异常,导致业务 ...
- Golang 使用Protocol Buffer 案例
目录 1. 前言 2. Protobuf 简介 2.1 Protobuf 优点 2.2 Protobuf 缺点 2.3 Protobuf Golang 安装使用 3. Protobuf 通讯案例 3. ...
- 前端Bug解决方案
没错!我正在写bug呢!不管你是小白还是大牛,写bug无可避免,遇到bug怎么办?别慌!毛主席教导我们"战略上藐视BUG,战术上重视BUG"!前端遇到的bug无非就三个方面结构层( ...
- JS 增删改查操作XML
效果图: <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <titl ...
- [LeetCode] 994. Rotting Oranges 腐烂的橘子
题目: 思路: 每个腐烂的橘子都能将自己上下左右的新鲜橘子传染,像极了现在的肺炎... 如果格子中只有一个腐烂的橘子,那么这便是一个典型的层次遍历,第一个传染多个,称为第二层,第二层传染第三层 但这里 ...
- win10查看本机mac地址的详细操作
今天和大家分享win10查看本机mac地址的方法,mac地址是什么东西?MAC地址实际上就是网卡的一个标识,和身份证号码类似,大多数情况下是不需要关心MAC地址是多少的,一般不能改动,所以也不会重复. ...
- Java实现生产者消费者(一)
问题描述:生产者和消费者问题是线程模型中的经典问题:生产者和消费者在同一时间段内共用同一个存储空间,生产者往存储空间中添加产品,消费者从存储空间中取走产品,当存储空间为空时,消费者阻塞,当存储空间满时 ...