Python通過RabbitMQ服務器實現(xiàn)交換機功能的實例教程
作者:陳杰斌
快速回顧一下RabbitMQ服務器的安裝:
sudo apt-get install rabbitmq-server
Python使用RabbitMQ需要Pika庫:
sudo pip install pika
好了,接下來我們先看交換機的工作原理:消息發(fā)送端先將消息發(fā)送給交換機,交換機再將消息發(fā)送到綁定的消息隊列,而后每個接收端都能從各自的消息隊列里接收到信息。

下面用send.py和receive.py來模擬實現(xiàn)交換機的功能。send.py表示發(fā)送端,receive.py表示接收端。
receive.py:
#!/usr/bin/env python
#coding=utf8
import pika
connection = pika.BlockingConnection(pika.ConnectionParameters(
'localhost'))
channel = connection.channel()
#定義交換機
channel.exchange_declare(exchange='messages', type='fanout')
#隨機生成隊列,并綁定到交換機上
result = channel.queue_declare(exclusive=True)
queue_name = result.method.queue
channel.queue_bind(exchange='messages', queue=queue_name)
def callback(ch, method, properties, body):
print " [x] Received %r" % (body,)
channel.basic_consume(callback, queue=queue_name, no_ack=True)
print ' [*] Waiting for messages. To exit press CTRL+C'
channel.start_consuming()
上例代碼中,queue_declare的參數(shù)exclusive=True表示當接收端退出時,銷毀臨時產(chǎn)生的隊列,這樣就不會占用資源。運行這個程序,然后使用rabbitmqctl list_exchanges命令來查看交換機信息:

其中紅色框就是上例定義的交換機了。再使用rabbitmqctl list_queues查看下消息隊列情況:

其中紅色框就是隨機產(chǎn)生的消息隊列了。
send.py:
#!/usr/bin/env python
#coding=utf8
import pika
connection = pika.BlockingConnection(pika.ConnectionParameters(
'localhost'))
channel = connection.channel()
#定義交換機
channel.exchange_declare(exchange='messages', type='fanout')
#將消息發(fā)送到交換機
channel.basic_publish(exchange='messages', routing_key='', body='Hello World!')
print " [x] Sent 'Hello World!'"
connection.close()
上例代碼中, basic_publish方法的參數(shù)exchange被設定為相應交換機,因為是要廣播出去,發(fā)送到所有隊列,所以routing_key就不需要設定了。
exchange如果為空,表示是使用匿名的交換機,在上面交換機信息的圖片中可以看到有amq.*這樣的交換機,就是系統(tǒng)默認的交換機了。routing_key在使用匿名交換機的時候才需要指定,表示發(fā)送到哪個隊列的意思。第一篇的例子演示了這個功能。
打開另外一個終端,執(zhí)行send.py,可以觀察到receive.py接收到了消息。如果有多個終端執(zhí)行receive.py,那么每個receive.py都會接收到消息。