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.网络通信概念 说 ...
随机推荐
- MobX中@computed和自定义get函数的区别
首先这两者解决方法都会得到一个相同的结果,但使用@computed的意义在于它能够由MobX进行更智能的优化. 如果我不使用computed属性,直接使用自定义的getTheValue函数的话,那么一 ...
- Inheritance Learning Note
好几天没来学习了,昨晚把继承的又整理了一下.想把整理后的东西发到hexo博客上来,却发现命令行又失效了.前几天明明是好的,这几天又没有进行任何操作,网上搜了一下也没有招到合适的解决办法,无奈只能重装了 ...
- Python知识点汇总
*/ * Copyright (c) 2016,烟台大学计算机与控制工程学院 * All rights reserved. * 文件名:text.cpp * 作者:常轩 * 微信公众号:Worldhe ...
- 10——PHP中的两种数组【索引数组】与【关联数组】
[索引数组] 用数字作为键名的数组一般叫做索引数组.用字符串表示键的数组就是下面要介绍的关联数组.索引数组的键是整数,而且从0开始以此类推. 索引数组初始化例: <pre name=" ...
- VUE实现Studio管理后台(三):支持多语言国际化(vue-i18n)
RXEditor的第一版本是英文版,有些朋友看起来觉得不习惯,后来因为惰性,不愿意再修改旧代码加入中文版,这次提前就把这个问题解决了,克服惰性最好的方式,就是想到就尽快去做,避免拖延. 本来计划在界面 ...
- Eclipse+Mysql实现多条件查询
最近做一个项目的时候,就需要用到多条件查询,但是一直不完美,所有有bug,不过今天经高人提醒,做出了个小例子,在这里简单跟大家分享一下: 不说多了,直接放关键sql代码: 已知条件:菜名,菜品,价格区 ...
- Access Token 机制详解
我们在访问很多大公司的开放 api 的时候,都会发现这些 api 要求传递一个 access token 参数.这个参数是什么呢?需要去哪里获取这个 access token 呢? access to ...
- apache搭建Tomcat集群(Cluster)
搭建集群: apache:特点处理静态资源(html 图片 js等) apache的请求操作,Cluster工具 tomcat:特点处理动态资源 apache+tomcat(apache是web服 ...
- windows7免费永久激活方法分享
前言 我相信,这里肯定有看过我上一篇博客的同学. 我说了,为解决windows7激活问题,我会找一个比较好的方法. 首先先让大家看一看激活前windows7的计算机属性: 显示是未激活的.下面就是方法 ...
- html5 中高级选择器 querySelector
简介 HTML5向Web API新引入了document.querySelector以及document.querySelectorAll两个方法用来更方便地从DOM选取元素,功能类似于jQuery的 ...