Python RabbitMQ消息队列
- 线程 queue:不同线程交互,不能夸进程
- 进程 queue:只能用于父进程与子进程,或者同一父进程下的多个子进程,进行交互
- RabbitMQ是用erlang语言开发的。windos环境需要先安装erlang。
- BabbitMQ主要以中间件的形式,实现多个独立进程的代理,维护网络通信。
- 此原理实现的软件有RabbitMQ,ZeroMQ,ActiveMQ。
- RabbitMQ下载地址:http://www.rabbitmq.com/download.html
- erlang下载地址:http://www.erlang.org/downloads
- windos 安装完需要通过 管理-->服务-->RabbitMQ 开启服务
- Linux 安装完 输入命令:rabbitmq-server start 开启服务
windos 下RabbitMQ\sbin\rabbitmq-server:启动服务
windos 下RabbitMQ\sbin\rabbitmqctl.bat:RabbitMQ管理工具
- RabbitMQ:启动插件、重启生效
C:\Users\Administrator>"C:\Program Files\RabbitMQ Server\rabbitmq_server-3.7.2\s
bin\rabbitmq-plugins.bat" enable rabbitmq_management
- RabbitMQ:基本命令
rabbitmq的安装、启动和停止
rabbitmq-service.bat install
rabbitmq-service.bat start
rabbitmq-service.bat stop 列出所有queue
rabbitmqctl.bat list_queues 列出指定queue的信息
rabbitmqctl.bat list_queues [the queue name] messages_ready messages_unacknowledged 列出所有exchange
rabbitmqctl.bat list_exchanges 列出所有binding
rabbitmqctl.bat list_bindings 安装基于web的管理插件
rabbitmq-plugins.bat enable rabbitmq_management 查看所有队列信息
添加用户:
rabbitmqctl.bat add_user rainbird password 添加权限:
rabbitmqctl.bat set_permissions -p "/" rainbird ".*" ".*" ".*" 删除测试用户:
rabbitmqctl.bat delete_user guest
- 安装 http://www.rabbitmq.com/install-standalone-mac.html
- 安装python rabbitMQ module
- pip install pika or easy_install pika or 源码 https://pypi.python.org/pypi/pika
注:celery模块是分布式任务队列

send端
#!/usr/bin/env python
import pika # 通过实例创建socket
connection = pika.BlockingConnection(
pika.ConnectionParameters('localhost')
) # 声明一个管道/在管道内发消息
channel = connection.channel() # 管道内,声明一个队列,queue=queue的名字
channel.queue_declare(queue='hello') # routing_key = queue的名字
# bod = 消息内容
# 一个消息不能直接发送到队列,它总是需要经过一个exchange。
channel.basic_publish(exchange='',
routing_key='hello',
body='Hello World!')
print(" [x] Sent 'Hello World!'") # 关闭队列
connection.close()
recv端
#_*_coding:utf-8_*_
__author__ = 'Alex Li'
import pika # 实例话创建socket
connection = pika.BlockingConnection(
pika.ConnectionParameters('localhost')) # 声明一个管道/在管道内发消息
channel = connection.channel() # 为什么再次声明queue名字:如果消费者先运行了,没有声明queue就会报错
# 如果想要防止报错发生,就要定义queue。
#
# 管道内,声明一个队列,queue=queue的名字
channel.queue_declare(queue='hello') # 回调函数
# ch 管道内存对象地址
# method 消息发给哪个queue
# properties定义消息持久话对象
# body数据对象
def callback(ch, method, properties, body):
print("-->",ch,method,properties)
print(" [x] Received %r" % body) # 消费消息
# callback 如果收到消息,就调用callback函数来处理消息
# queue 管道内的队列名字
# no_ack = True 这条消息出没处理完都不会给服务端发确认
channel.basic_consume(
callback,
queue='hello',
no_ack=True) print(' [*] Waiting for messages. To exit press CTRL+C') # 启动后一直运行,没有数据会等待..
channel.start_consuming()
Python RabbitMQ消息队列的更多相关文章
- Python RabbitMQ 消息队列
RabbitMQ是一个在AMQP基础上完整的,可复用的企业消息系统.他遵循Mozilla Public License开源协议. MQ全称为Message Queue, 消息队列(MQ)是一种应用程序 ...
- openresty 学习笔记番外篇:python访问RabbitMQ消息队列
openresty 学习笔记番外篇:python访问RabbitMQ消息队列 python使用pika扩展库操作RabbitMQ的流程梳理. 客户端连接到消息队列服务器,打开一个channel. 客户 ...
- RabbitMQ消息队列(一): Detailed Introduction 详细介绍
http://blog.csdn.net/anzhsoft/article/details/19563091 RabbitMQ消息队列(一): Detailed Introduction 详细介绍 ...
- RabbitMQ消息队列1: Detailed Introduction 详细介绍
1. 历史 RabbitMQ是一个由erlang开发的AMQP(Advanced Message Queue )的开源实现.AMQP 的出现其实也是应了广大人民群众的需求,虽然在同步消息通讯的世界里有 ...
- (转)RabbitMQ消息队列(七):适用于云计算集群的远程调用(RPC)
在云计算环境中,很多时候需要用它其他机器的计算资源,我们有可能会在接收到Message进行处理时,会把一部分计算任务分配到其他节点来完成.那么,RabbitMQ如何使用RPC呢?在本篇文章中,我们将会 ...
- (转)RabbitMQ消息队列(六):使用主题进行消息分发
在上篇文章RabbitMQ消息队列(五):Routing 消息路由 中,我们实现了一个简单的日志系统.Consumer可以监听不同severity的log.但是,这也是它之所以叫做简单日志系统的原因, ...
- (转)RabbitMQ消息队列(四):分发到多Consumer(Publish/Subscribe)
上篇文章中,我们把每个Message都是deliver到某个Consumer.在这篇文章中,我们将会将同一个Message deliver到多个Consumer中.这个模式也被成为 "pub ...
- RabbitMQ消息队列(四):分发到多Consumer(Publish/Subscribe)
上篇文章中,我们把每个Message都是deliver到某个Consumer.在这篇文章中,我们将会将同一个Message deliver到多个Consumer中.这个模式也被成为 "pub ...
- 使用EasyNetQ组件操作RabbitMQ消息队列服务
RabbitMQ是一个由erlang开发的AMQP(Advanved Message Queue)的开源实现,是实现消息队列应用的一个中间件,消息队列中间件是分布式系统中重要的组件,主要解决应用耦合, ...
随机推荐
- 转:Maven <resource>标签
maven资源文件的相关配置 构建Maven项目的时候,如果没有进行特殊的配置,Maven会按照标准的目录结构查找和处理各种类型文件. src/main/java和src/test/java 这 ...
- 在POM配置Maven plugin提示错误“Plugin execution not covered by lifecycle configuration”的解决方案
eclipse在其POM文件的一处提示出错如下: Plugin execution not covered by lifecycle configuration: org.apache.maven.p ...
- sanchi
修炼之路阶段1能简单处理html+css+js前端页面,可实现管理后台前端页面 熟练安装php的web运行环境,并调整配置,会自行安装php扩展 熟练数据库操作,清楚为何使用pdo而不使用mysql等 ...
- Webshell密码极速爆破工具 – cheetah
https://www.t00ls.net/thread-39660-1-1.html
- java基础学习总结——流
一.JAVA流式输入/输出原理
- aes 和 Md5 分析
高级加密标准(英语:Advanced Encryption Standard,缩写:AES). 密码的设计力求满足以下3条标准: ① 抵抗所有已知的攻击. ② 在多个平台上速度快,编码紧凑. ③ 设计 ...
- CAutolock
顾名思义CAutolock就是自动锁的意思,它可以把它之下的代码区锁住一直到其自身被释放掉 后这块代码区中的公共资源才会被其他线程使用.当然这个代码区能尽量少就尽量少,毕竟不能让其他线 程 ...
- 找不到 main 方法, 请将 main 方法定义为: public static void main(String[] args) 否则 JavaFX 应用程序类必须扩展javafx.应用程序类必 须扩展javafx.application.Application”
用eclipse写代码的时候,写了一个简单的程序,编译的时候突然出现“错误: 在类 com.test.demo 中找不到 main 方法, 请将 main 方法定义为: public static v ...
- Linux命令 printf
定长: $ printf '%s\t%s\t%s\t%s\t%s\t\n' $(cat printf.txt) # %s 表示一个不固定长度的字符串:printf不是管道命令,因此需要通过类似cat的 ...
- LeetCode 19 - 删除链表的倒数第N个节点 - [链表]
题目链接:https://leetcode-cn.com/problems/remove-nth-node-from-end-of-list/ 题解: 两个 $p,q$ 指针均指向头,然后 $q$ 先 ...