好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

Python操作RabbitMQ初体验(一)

由于想用Python实现一套分布式系统,来管理和监控CDN的内容与运行状态,误打误撞认识了RabbitMQ,推荐的人很多,如余锋《我为什么要选择RabbitMQ》等等。

点击可以下载各个版本的binary包,我下载了rabbitmq-server-3.3.0-1.noarch.rpm

进入下载路径,/home/sun5495/Downloads/

[sun5495@localhost Downloads]# sudo chmod 777 rabbitmq-server-3.3.0-1.noarch.rpm

更改可执行文件权限,增加执行权限。

然后执行./rabbitmq-server-3.3.0-1.noarch.rpm,运行报错,无法安装。

原来是现需要安装Erlang才可以,试用此命令 yum install erlang 搞定。

然后使用root用户执行

rpm --import http://HdhCmsTestrabbitmq测试数据/rabbitmq-signing-key-public.asc yum install rabbitmq-server-3.3.0-1.noarch.rpm 

安装成功。

为了设置RBMQ开机启动,使用管理员账户执行

chkconfig rabbitmq-server on 

开启和关闭server使用命令

/sbin/service rabbitmq-server stop/start 

结果开启的时候报错如下
Starting rabbitmq-server (via systemctl): Job for rabbitmq-server.service failed. See 'systemctl status rabbitmq-server.service' and 'journalctl -xn' for details. [FAILED]

使用journalctl -xn命令打开日志,查看了下貌似是Erlang的某个文件拒绝访问,然后还提出了一大堆建议。

尝试一下

grep beam.smp /var/log/audit/audit.log | audit2allow -M mypolsemodule -i mypol.pp/sbin/service rabbitmq-server start 

既然RabbitMQ安装也运行成功了,那么我就来尝尝RabbitMQ的鲜吧。就从官网上的例子一步一笔来做好了。

由于我使用的是Python,那么就需要安装一些支持RabbitMQ的库来进行操作,其中包括

py-amqplib,txAMQP,pika这几种,按照官网的tutorial,我也安装了pika。

pip install pika 

从最简单的收发消息开始。即一端发送消息,一端接收消息。

发送方即生产者,首先要创建与RabbitMQ服务器的连接,

#!/usr/bin/env pythonimport pikaconnection = pika.BlockingConnection(pika.ConnectionParameters(              
 'localhost'))channel = connection.channel() 

此处服务器连接本地localhost,也可以指定ip或者主机名。

其次发送方需要声明一个队列,比如命名为sayhello

channel.queue_declare(queue='sayhello') 

此时我们就可以发送消息了。由于第一个小案例比较简单,没有经过路由器,因此发送消息时,指定路由为空即可。

channel.basic_publish(exchange='',                        
routing_key='hello',                                    
body='hello world')print "Sent ‘hello world'" 

最后关闭连接即可。

connection.close() 

接收方即消费者,需要从队列上获取数据,因此也需要绑定一个队列

channel.queue_declare(queue='hello') 

同时,由于接收方的工作方式是基于队列的消息执行一个回调函数,当收到消息时,Pika就会执行相应的回调函数,因此我们需要定义此函数。

def callback(ch, method, properties, body):    print " [x] Received %r" % (body,) 

接下来我们需要初始化这个消费者,并对消费者进行启动。

channel.basic_consume(callback,                      
queue='hello',                      
no_ack=True)print ' [*] Waiting for messages. To exit press CTRL+C'channel.start_consuming() 

查看更多关于Python操作RabbitMQ初体验(一)的详细内容...

  阅读:40次