RabbitMQ上手记录–part 3-发送消息

  接上一part<<RabbitMQ上手记录–part 2 - 安装RabbitMQ>>,这里咱们来看看如何经过代码实现对RabbitMQ的调用。html

RabbitMQ一般是安装在服务器端,那么要体现它的功能,固然还须要一个客户端来调用。这个客户端一般就是咱们的业务系统,那么如何操做RabbitMQ呢?不可能让程序员写底层的传输代码或者局限于用erlang开发语言。RabbitMQ已经贴心的准备好了API Client,没错就是程序员喜闻乐见的API(或者说是调包)。python

  RabbitMQ官方(http://www.rabbitmq.com/clients.html)提供了Java,.NET和erlang的API包,Java和.NET是开发业务系统的两大阵型,erlang是RabbitMQ的开发语言,因此官方主推了这三个语言的API包。那其余语言呢?没问题,RabbitMQ虽然没有提供实现,可是给出了”amqp”的URI规范(http://www.rabbitmq.com/uri-spec.html),也就是跟服务器通信的一套协议,其余开发语言照着这个规范实现就能够了。有了官方的指引文档,加上活跃热心的社区群众,其余语言也有各自的API包,具体可参考http://www.rabbitmq.com/devtools.html程序员

 

这里采用很火的Python做为示例代码,演示消费者如何订阅消息,生产者如何发布消息。数据库

准备工做bash

1.已安装好RabbitMQ,并确保服务是在运行的()。服务器

2.有可用的Python环境,并安装了RabbitMQ的API包pika。函数

 

开始编码ui

a.新建文件rabbitMQConfig.py,代码以下编码

import pika, sys


def getDefaultChannel():
     credentials = pika.PlainCredentials("guest", "guest")
     conn_params = pika.ConnectionParameters(
         "localhost", credentials=credentials)
     conn_broker = pika.BlockingConnection(conn_params)
     channel = conn_broker.channel()
     return channel

 

各行代码大体的意思spa

credentials = pika.PlainCredentials("guest", "guest")

guest是RabbitMQ默认的一个访客帐号,只能用于链接本机localhost服务,密码默认也是guest。这里是建立明文的访问帐号信息。

conn_params = pika.ConnectionParameters("localhost", credentials=credentials)

建立链接参数,有点相似于数据库的链接字符串信息

conn_broker = pika.BlockingConnection(conn_params)
channel = conn_broker.channel()

这里是建立一个链接,而且是一个阻塞的链接,会一直阻塞直到收到服务器的响应。而后建立一个通信的channel,这个channel是进行后续操做的关键接口。

 

b.新建文件HelloWorldConsumer.py,代码以下

import rabbitMQConfig
import pika

channel = rabbitMQConfig.getDefaultChannel()

channel.exchange_declare(
     exchange="hello-exchange",
     exchange_type="direct",
     passive=False,
     durable=True,
     auto_delete=False)

channel.queue_declare(queue="hello-queue")
channel.queue_bind(
     queue="hello-queue", exchange="hello-exchange", routing_key="hola")


def msg_consumer(channel, method, header, body):
     channel.basic_ack(delivery_tag=method.delivery_tag)
     if body == "quit":
         channel.basic_cancel(consumer_tag="hello-consumer")
         channel.stop_consuming()
     else:
         print body

    return


channel.basic_consume(
     msg_consumer, queue="hello-queue", consumer_tag="hello-consumer")
channel.start_consuming()

 

代码解释

在以前建立channel代码的基础上,咱们依次完成了如下动做

channel.exchange_declare(
     exchange="hello-exchange",
    exchange_type="direct",
     passive=False,
     durable=True,
    auto_delete=False)

建立exchange,名称为”hello-exchange”,类型是”direct”,也就是这个exchange是严格按照routing_key的值来匹配消息队列的。(具体相关的基本概念请参考《RabbitMQ 上手记录-part 1-基础概念》)

channel.queue_declare(queue="hello-queue")
channel.queue_bind(
     queue="hello-queue", exchange="hello-exchange", routing_key="hola")

建立queue,名称为”hello-queue“,而且绑定到”hello-exchange”,关联的routing_key是”hola”。这里的queue就是用于存放消息的消息队列。

 

def msg_consumer(channel, method, header, body):

这里定义了收到消息后的回调函数,这个函数会回确认消息已收到,同时会打印出收到的消息或者根据消息内容关闭链接。

 

channel.basic_consume(
    msg_consumer, queue="hello-queue", consumer_tag="hello-consumer")
channel.start_consuming()

最后的就是开始消费这个队列的消息,这是一个阻塞的操做,会一直等待有消息进入队列并推送到客户端。

 

到此消费者端的代码就完成了,接下来看看生产者端的代码。

c.新建文件HelloWorldProducer.py

import sys
import pika
import rabbitMQConfig

channel = rabbitMQConfig.getDefaultChannel()

channel.exchange_declare(
     exchange="hello-exchange",
     exchange_type="direct",
     passive=False,
     durable=True,
     auto_delete=False)

msg = sys.argv[1]
msg_props = pika.BasicProperties()
msg_props.content_type = "text/plain"

channel.basic_publish(
     body=msg,
     exchange="hello-exchange",
     properties=msg_props,
     routing_key="hola")

 

这里的代码前面几行跟消费者的调用代码相似,都是经过配置拿到channel信息,而后声明一个exchange。可能比较奇怪,为何以前消费者的代码里也调用了一样的代码声明一样的exchange。在声明exchange的时候,系统会判断是否已存在了相同名称的exchange,若是存在了直接返回。

msg = sys.argv[1]
msg_props = pika.BasicProperties()
msg_props.content_type = "text/plain"

这里定义了须要发送的消息内容,发送的文本从命令行获取,而且设置消息的content_type为”text/plain”

channel.basic_publish(
    body=msg,
     exchange="hello-exchange",
     properties=msg_props,
     routing_key="hola")

接下来是发布消息,关键的参数是指定发布到哪一个exchange,消息内容,以及routing_key。

运行

python HelloWorldConsumer.py

而后另起一个bash/命令行

python HelloWorldProducer.py hello

运行以后在第一个命令行就能看到消息输出

image

 

以上就是最基本的发布消息和订阅消息的过程,后续咱们来看看如何实现RabbitMQ集群。

相关文章
相关标签/搜索