diff --git a/artamonova_tatyana_lab_4/Consumer1.py b/artamonova_tatyana_lab_4/Consumer1.py new file mode 100644 index 0000000..507bbbf --- /dev/null +++ b/artamonova_tatyana_lab_4/Consumer1.py @@ -0,0 +1,23 @@ +import pika +import json +import time + +credentials = pika.PlainCredentials('guest', 'guest') +connection = pika.BlockingConnection( + pika.ConnectionParameters(host='localhost', credentials=credentials)) +channel = connection.channel() + +channel.queue_declare(queue='order_queue_1') + +channel.queue_bind(exchange='order_events', queue='order_queue_1') + +def callback(ch, method, properties, body): + event = json.loads(body.decode('utf-8')) + print(f'Получено событие (очередь 1): {event}') + print(f'Обработка заказа {event["order_id"]}...') + time.sleep(2) + +channel.basic_consume(queue='order_queue_1', on_message_callback=callback, auto_ack=True) + +print('Ожидание сообщений (очередь 1)...') +channel.start_consuming() diff --git a/artamonova_tatyana_lab_4/Consumer2.py b/artamonova_tatyana_lab_4/Consumer2.py new file mode 100644 index 0000000..a8268cb --- /dev/null +++ b/artamonova_tatyana_lab_4/Consumer2.py @@ -0,0 +1,22 @@ +import pika +import json +import time + +credentials = pika.PlainCredentials('guest', 'guest') +connection = pika.BlockingConnection( + pika.ConnectionParameters(host='localhost', credentials=credentials)) +channel = connection.channel() + +channel.queue_declare(queue='order_queue_2') + +channel.queue_bind(exchange='order_events', queue='order_queue_2') + +def callback(ch, method, properties, body): + event = json.loads(body.decode('utf-8')) + print(f'Получено событие (очередь 2): {event}') + print(f'Обработка заказа {event["order_id"]} завершена.') + +channel.basic_consume(queue='order_queue_2', on_message_callback=callback, auto_ack=True) + +print('Ожидание сообщений (очередь 2)...') +channel.start_consuming() diff --git a/artamonova_tatyana_lab_4/Publisher.py b/artamonova_tatyana_lab_4/Publisher.py new file mode 100644 index 0000000..e4acf8a --- /dev/null +++ b/artamonova_tatyana_lab_4/Publisher.py @@ -0,0 +1,31 @@ +import pika +import json +import time +import random + +credentials = pika.PlainCredentials('guest', 'guest') +connection = pika.BlockingConnection( + pika.ConnectionParameters(host='localhost', credentials=credentials)) +channel = connection.channel() + +channel.exchange_declare(exchange='order_events', exchange_type='fanout') + +while True: + event = { + 'event_type': 'order_created', + 'order_id': random.randint(1000, 9999), + 'customer_name': f'Клиент {random.randint(1, 100)}', + 'product_name': f'Товар {random.randint(1, 10)}', + 'quantity': random.randint(1, 10), + 'timestamp': time.time() + } + + channel.basic_publish( + exchange='order_events', + routing_key='', + body=json.dumps(event) + ) + print(f'Опубликовано событие: {event}') + time.sleep(1) + +connection.close() diff --git a/artamonova_tatyana_lab_4/images/consumers.png b/artamonova_tatyana_lab_4/images/consumers.png new file mode 100644 index 0000000..08b7cf6 Binary files /dev/null and b/artamonova_tatyana_lab_4/images/consumers.png differ diff --git a/artamonova_tatyana_lab_4/images/exchange.png b/artamonova_tatyana_lab_4/images/exchange.png new file mode 100644 index 0000000..a295d6b Binary files /dev/null and b/artamonova_tatyana_lab_4/images/exchange.png differ diff --git a/artamonova_tatyana_lab_4/images/queue1.png b/artamonova_tatyana_lab_4/images/queue1.png new file mode 100644 index 0000000..8fcb07f Binary files /dev/null and b/artamonova_tatyana_lab_4/images/queue1.png differ diff --git a/artamonova_tatyana_lab_4/images/queue2.png b/artamonova_tatyana_lab_4/images/queue2.png new file mode 100644 index 0000000..cc2ca65 Binary files /dev/null and b/artamonova_tatyana_lab_4/images/queue2.png differ diff --git a/artamonova_tatyana_lab_4/images/tutorial-1.png b/artamonova_tatyana_lab_4/images/tutorial-1.png new file mode 100644 index 0000000..5d0f9a1 Binary files /dev/null and b/artamonova_tatyana_lab_4/images/tutorial-1.png differ diff --git a/artamonova_tatyana_lab_4/images/tutorial-2.png b/artamonova_tatyana_lab_4/images/tutorial-2.png new file mode 100644 index 0000000..8cd59b0 Binary files /dev/null and b/artamonova_tatyana_lab_4/images/tutorial-2.png differ diff --git a/artamonova_tatyana_lab_4/images/tutorial-3.png b/artamonova_tatyana_lab_4/images/tutorial-3.png new file mode 100644 index 0000000..38f470c Binary files /dev/null and b/artamonova_tatyana_lab_4/images/tutorial-3.png differ diff --git a/artamonova_tatyana_lab_4/readme.md b/artamonova_tatyana_lab_4/readme.md new file mode 100644 index 0000000..0fced7d --- /dev/null +++ b/artamonova_tatyana_lab_4/readme.md @@ -0,0 +1,26 @@ +## Лабораторная работа №4 ПИбд-42 Артамонова Татьяна + +### Прохождение туториала +1. ![tutorial-1.png](images/tutorial-1.png) +2. ![tutorial-2.png](images/tutorial-2.png) +3. ![tutorial-3.png](images/tutorial-3.png) + +### Запуск приложений и анализ скорости обработки + +1. Запуск Publisher, Consumer 1 и Consumer 2. +* Consumer 1: Очередь order_queue_1 будет иметь некоторое количество сообщений, так как Consumer 1 обрабатывает сообщения с задержкой в 2 секунды. +* Consumer 2: Очередь order_queue_2 будет практически пустой, так как Consumer 2 обрабатывает сообщения моментально. + +2. Запуск нескольких копий Consumer 1 +* Очередь order_queue_1 будет иметь меньше сообщений, так как 3 Consumer-а обрабатывают сообщения быстрее, чем 1 Consumer. + +![queue1.png](images/queue1.png) + +![queue2.png](images/queue2.png) + +![exchange.png](images/exchange.png) + +![consumers.png](images/consumers.png) + +### Видео +https://vk.com/video/@artamonovat?section=upload&z=video212084908_456239359 diff --git a/artamonova_tatyana_lab_4/tutorial/1/receive.py b/artamonova_tatyana_lab_4/tutorial/1/receive.py new file mode 100644 index 0000000..f118e0a --- /dev/null +++ b/artamonova_tatyana_lab_4/tutorial/1/receive.py @@ -0,0 +1,25 @@ +import pika, sys, os + +def main(): + connection = pika.BlockingConnection(pika.ConnectionParameters(host='localhost')) + channel = connection.channel() + + channel.queue_declare(queue='hello') + + def callback(ch, method, properties, body): + print(f" [x] Received {body}") + + channel.basic_consume(queue='hello', on_message_callback=callback, auto_ack=True) + + print(' [*] Waiting for messages. To exit press CTRL+C') + channel.start_consuming() + +if __name__ == '__main__': + try: + main() + except KeyboardInterrupt: + print('Interrupted') + try: + sys.exit(0) + except SystemExit: + os._exit(0) \ No newline at end of file diff --git a/artamonova_tatyana_lab_4/tutorial/1/send.py b/artamonova_tatyana_lab_4/tutorial/1/send.py new file mode 100644 index 0000000..41cfff2 --- /dev/null +++ b/artamonova_tatyana_lab_4/tutorial/1/send.py @@ -0,0 +1,11 @@ +import pika + +connection = pika.BlockingConnection( + pika.ConnectionParameters(host='localhost')) +channel = connection.channel() + +channel.queue_declare(queue='hello') + +channel.basic_publish(exchange='', routing_key='hello', body='Hello World!') +print(" [x] Sent 'Hello World!'") +connection.close() \ No newline at end of file diff --git a/artamonova_tatyana_lab_4/tutorial/2/new_task.py b/artamonova_tatyana_lab_4/tutorial/2/new_task.py new file mode 100644 index 0000000..a2444e0 --- /dev/null +++ b/artamonova_tatyana_lab_4/tutorial/2/new_task.py @@ -0,0 +1,19 @@ +import pika +import sys + +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() \ No newline at end of file diff --git a/artamonova_tatyana_lab_4/tutorial/2/worker.py b/artamonova_tatyana_lab_4/tutorial/2/worker.py new file mode 100644 index 0000000..8f8ab64 --- /dev/null +++ b/artamonova_tatyana_lab_4/tutorial/2/worker.py @@ -0,0 +1,22 @@ +import pika +import time + +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() \ No newline at end of file diff --git a/artamonova_tatyana_lab_4/tutorial/3/emit_log.py b/artamonova_tatyana_lab_4/tutorial/3/emit_log.py new file mode 100644 index 0000000..45b6989 --- /dev/null +++ b/artamonova_tatyana_lab_4/tutorial/3/emit_log.py @@ -0,0 +1,13 @@ +import pika +import sys + +connection = pika.BlockingConnection( + pika.ConnectionParameters(host='localhost')) +channel = connection.channel() + +channel.exchange_declare(exchange='logs', exchange_type='fanout') + +message = ' '.join(sys.argv[1:]) or "info: Hello World!" +channel.basic_publish(exchange='logs', routing_key='', body=message) +print(f" [x] Sent {message}") +connection.close() \ No newline at end of file diff --git a/artamonova_tatyana_lab_4/tutorial/3/receive_logs.py b/artamonova_tatyana_lab_4/tutorial/3/receive_logs.py new file mode 100644 index 0000000..60d881d --- /dev/null +++ b/artamonova_tatyana_lab_4/tutorial/3/receive_logs.py @@ -0,0 +1,22 @@ +import pika + +connection = pika.BlockingConnection( + pika.ConnectionParameters(host='localhost')) +channel = connection.channel() + +channel.exchange_declare(exchange='logs', exchange_type='fanout') + +result = channel.queue_declare(queue='', exclusive=True) +queue_name = result.method.queue + +channel.queue_bind(exchange='logs', queue=queue_name) + +print(' [*] Waiting for logs. To exit press CTRL+C') + +def callback(ch, method, properties, body): + print(f" [x] {body}") + +channel.basic_consume( + queue=queue_name, on_message_callback=callback, auto_ack=True) + +channel.start_consuming() \ No newline at end of file