High level interfaces for work with RabbitMQ.
Project description
Stack:
Installation
pip install rabbitmq-clients
Usage
Run rabbitMQ on your computer.
Producer
import asyncio
import json
from rabbitmq_clients import RabbitProducer
if __name__ == "__main__":
producer = RabbitProducer(
host='localhost',
login='test',
password='test',
queue_name='test_queue',
exchange_name='',
routing_key='',
)
data = {"result": True}
asyncio.run(producer.publish(json.dumps(data)))
Consume multiply queues (recommended)
import asyncio
from rabbitmq_clients import RabbitConsumer, QueueDTO
from rabbitmq_clients.core.types import JSON
async def show_decoded_result(result: JSON):
print(result)
async def show_encoded_result(result: JSON):
print(result.body)
if __name__ == "__main__":
consumer = RabbitConsumer(
host='localhost',
login='test',
password='test',
)
first_queue = QueueDTO(
name='decoded_result',
callback=show_decoded_result,
)
second_queue = QueueDTO(
name='encoded_result',
callback=show_encoded_result,
auto_decode=False,
)
consumer.add_queue(first_queue)
consumer.add_queue(second_queue)
try:
asyncio.run(consumer.consume_all())
except KeyboardInterrupt:
pass
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Close
Hashes for rabbitmq_clients-0.1.13-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 29d82a8ba4eaa6bc528540bd0e1f89ebfef32e75143c0ccc6d476ed13d7f1410 |
|
MD5 | d313e611b3e9ccd94c74dab402ec35e6 |
|
BLAKE2b-256 | 102eb3dc8afabfb58305a1ce8891481feb802b02b9dd38e5b9a8efb0412cc168 |