refactor(rabbitmq): send tasks from one queue to some workers
This commit is contained in:
parent
819e9223d8
commit
3730ca7828
23
rabbitmq/send_message.py
Normal file
23
rabbitmq/send_message.py
Normal file
@ -0,0 +1,23 @@
|
||||
import sys
|
||||
|
||||
import pika
|
||||
|
||||
connection = pika.BlockingConnection(
|
||||
pika.ConnectionParameters(host="localhost"),
|
||||
)
|
||||
channel = connection.channel()
|
||||
|
||||
channel.queue_declare(queue="task_queue", durable=True)
|
||||
|
||||
message = " ".join(sys.argv[1:]) or "Hello World!"
|
||||
channel.basic_publish(
|
||||
exchange="",
|
||||
routing_key="task_queue",
|
||||
body=message,
|
||||
properties=pika.BasicProperties(
|
||||
delivery_mode=pika.DeliveryMode.Persistent,
|
||||
),
|
||||
)
|
||||
print(f" [x] Sent {message}")
|
||||
|
||||
connection.close()
|
24
rabbitmq/worker.py
Normal file
24
rabbitmq/worker.py
Normal file
@ -0,0 +1,24 @@
|
||||
import time
|
||||
|
||||
import pika
|
||||
|
||||
connection = pika.BlockingConnection(
|
||||
pika.ConnectionParameters(host="localhost"),
|
||||
)
|
||||
channel = connection.channel()
|
||||
|
||||
channel.queue_declare(queue="task_queue", durable=True)
|
||||
print(" [*] Waiting for messages. To exit press CTRL+C")
|
||||
|
||||
|
||||
def callback(ch, method, properties, body):
|
||||
print(f" [x] Received {body.decode()}")
|
||||
time.sleep(body.count(b"."))
|
||||
print(" [x] Done")
|
||||
ch.basic_ack(delivery_tag=method.delivery_tag)
|
||||
|
||||
|
||||
channel.basic_qos(prefetch_count=1)
|
||||
channel.basic_consume(queue="task_queue", on_message_callback=callback)
|
||||
|
||||
channel.start_consuming()
|
Loading…
Reference in New Issue
Block a user