2023-12-16 20:09:40 +04:00
# Отчет по лабораторной работе №4
Выполнила студентка г р . ИСЭбд-41 Зиновьева А . Д.
## Прохождение tutorial
Установила rabbitMQ server, erlang и зашла в брокер под гостем по http://localhost:15672/#/
data:image/s3,"s3://crabby-images/d3ca5/d3ca5b186597d001e52ba9496f33b65b6b8e757a" alt=""
Туториал 1:
data:image/s3,"s3://crabby-images/fa3e3/fa3e3262219d3a071e8bb5a3afc3cf41ff69c6d6" alt=""
data:image/s3,"s3://crabby-images/d0382/d03828a34aec4ca95eae72484808efcc69ae95e5" alt=""
data:image/s3,"s3://crabby-images/f7dd3/f7dd3e51500a1c5a890c5899d09b21ca5621aef9" alt=""
Туториал 2:
data:image/s3,"s3://crabby-images/254d0/254d047a3999729a69aa7b69aca809e4cca9fe2a" alt=""
data:image/s3,"s3://crabby-images/21d04/21d042070d88e854acfd4ffb260b3b9936502f0a" alt=""
data:image/s3,"s3://crabby-images/e6256/e62560b715f4b8253250faf83c500badad353332" alt=""
Туториал 3:
data:image/s3,"s3://crabby-images/0d580/0d5801804952ca43c77e60e5833f130dfca7d5fc" alt=""
data:image/s3,"s3://crabby-images/5412d/5412dfad2c5c352c71db773fc199c874e9420e14" alt=""
data:image/s3,"s3://crabby-images/001e8/001e87ddb877d6af47e3f2ef3d03d470a7959a10" alt=""
## Разработка демонстрационных приложений
Предметная область: Дополнительный соглашения и договоры на проживание.
Разработаны три приложения, согласно предметной области.
1. Publisher
```py
import pika
import time
import random
2023-12-16 21:04:41 +04:00
collection = ["the employment document", "The document is agreed", "Signatures are provided", "the employee is accepted"]
2023-12-16 20:09:40 +04:00
connection = pika.BlockingConnection(pika.ConnectionParameters('localhost'))
channel = connection.channel()
channel.exchange_declare(exchange='Agreements', exchange_type='fanout')
while True:
message = f"Message: {random.choice(collection)}"
channel.basic_publish(exchange='Agreements', routing_key='', body=message)
time.sleep(1)
connection.close()
```
2. Consumer 1.
```py
import pika
import time
def process_message(ch, method, properties, body):
print(f"Получено сообщение: {body}")
time.sleep(3)
print("Сообщение успешно обработано")
connection = pika.BlockingConnection(pika.ConnectionParameters('localhost'))
channel = connection.channel()
result = channel.queue_declare(queue='', exclusive=True)
queue_name = result.method.queue
channel.queue_bind(exchange='Agreements', queue=queue_name)
channel.basic_consume(queue=queue_name, on_message_callback=process_message, auto_ack=True)
print('Ожидание сообщений...')
channel.start_consuming()
```
3. Consumer 2.
```py
import pika
def process_message(ch, method, properties, body):
print(f"Получено сообщение: {body}")
print("Сообщение успешно обработано")
connection = pika.BlockingConnection(pika.ConnectionParameters('localhost'))
channel = connection.channel()
result = channel.queue_declare(queue='', exclusive=True)
queue_name = result.method.queue
channel.queue_bind(exchange='Agreements', queue=queue_name)
channel.basic_consume(queue=queue_name, on_message_callback=process_message, auto_ack=True)
print('Ожидание сообщений...')
channel.start_consuming()
```
## Результаты выполнения лабораторной работы
Результат отработки Consumer_1:
2023-12-16 21:04:41 +04:00
data:image/s3,"s3://crabby-images/502ba/502badeb7881ee9dd075b031c4bbcb2840bb9603" alt=""
2023-12-16 20:09:40 +04:00
data:image/s3,"s3://crabby-images/577e1/577e1e497faa27f0e234d23e44055bdaa2d09795" alt=""
Результат отработки Consumer_2:
2023-12-16 21:04:41 +04:00
data:image/s3,"s3://crabby-images/1befd/1befdc22dfda63bb56a62601e6e658be87a90475" alt=""
2023-12-16 20:09:40 +04:00
data:image/s3,"s3://crabby-images/80341/8034177bf3a8638d4a7cb64c41a82cae1263359e" alt=""
Вывод: Consumer_2 нагружает меньше памяти, чем Consumer_1 и принимает сообщения гораздо быстрее, тем самым не позволяя очереди накапливать огромное количество сообщений.