kombu/examples/experimental/async_consume.py

32 lines
746 B
Python
Raw Permalink Normal View History

2023-05-24 14:26:40 +00:00
#!/usr/bin/env python3
2014-02-03 15:40:40 +00:00
from __future__ import annotations
from kombu import Connection, Consumer, Exchange, Producer, Queue
from kombu.asynchronous import Hub
2014-02-03 15:40:40 +00:00
hub = Hub()
exchange = Exchange('asynt')
queue = Queue('asynt', exchange, 'asynt')
2014-05-27 13:41:20 +00:00
2014-02-03 15:40:40 +00:00
def send_message(conn):
producer = Producer(conn)
producer.publish('hello world', exchange=exchange, routing_key='asynt')
print('message sent')
2014-02-03 15:40:40 +00:00
def on_message(message):
2020-07-13 13:58:06 +00:00
print(f'received: {message.body!r}')
2014-02-03 15:40:40 +00:00
message.ack()
hub.stop() # <-- exit after one message
if __name__ == '__main__':
conn = Connection('amqp://')
conn.register_with_event_loop(hub)
with Consumer(conn, [queue], on_message=on_message):
send_message(conn)
hub.run_forever()