rabbitmq-tutorials/python-puka/receive_logs_topic.py
2011-07-06 15:44:10 +01:00

33 lines
903 B
Python
Executable File

#!/usr/bin/env python
import puka
import sys
client = puka.Client("amqp://localhost/")
promise = client.connect()
client.wait(promise)
promise = client.exchange_declare(exchange='topic_logs', type='topic')
client.wait(promise)
promise = client.queue_declare(exclusive=True)
queue_name = client.wait(promise)['queue']
binding_keys = sys.argv[1:]
if not binding_keys:
print >> sys.stderr, "Usage: %s [binding_key]..." % (sys.argv[0],)
sys.exit(1)
for binding_key in binding_keys:
promise = client.queue_bind(exchange='topic_logs', queue=queue_name,
routing_key=binding_key)
client.wait(promise)
print ' [*] Waiting for logs. To exit press CTRL+C'
consume_promise = client.basic_consume(queue=queue_name, no_ack=True)
while True:
msg_result = client.wait(consume_promise)
print " [x] %r:%r" % (msg_result['routing_key'], msg_result['body'])