2023-12-16 20:09:40 +04:00
# Отчет по лабораторной работе №4
Выполнила студентка г р . ИСЭбд-41 Зиновьева А . Д.
## Прохождение tutorial
Установила rabbitMQ server, erlang и зашла в брокер под гостем по http://localhost:15672/#/
data:image/s3,"s3://crabby-images/87724/87724eb182fd08250fb9dbbbb682cc54dac0901d" alt=""
Туториал 1:
data:image/s3,"s3://crabby-images/a465f/a465f8e511560c60c8909febcf80c73d1819bb62" alt=""
data:image/s3,"s3://crabby-images/14915/14915635fea9de8ff68384c0484b7a6a231e2be5" alt=""
data:image/s3,"s3://crabby-images/498b7/498b75684eaec2f3601e3c27a412ae8682b31242" alt=""
Туториал 2:
data:image/s3,"s3://crabby-images/8bc1a/8bc1ab41af1fc62343b55867d7a9b7c0d1574f7a" alt=""
data:image/s3,"s3://crabby-images/aaada/aaadab63d31b80e4b4c3a1b94b44962819ef531f" alt=""
data:image/s3,"s3://crabby-images/13755/1375567d955e217fb235de6852475b765286f271" alt=""
Туториал 3:
data:image/s3,"s3://crabby-images/74117/741172b5b56a5fc05caf9a82a8e804cba472da22" alt=""
data:image/s3,"s3://crabby-images/214ec/214ec18eff372457fafff7d4cf2a6404f6487963" alt=""
data:image/s3,"s3://crabby-images/6f9ee/6f9eea41b5403711220af7d4bf84b634791378c4" 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/a5820/a5820670f2439e8c368480188063af12fefaa270" alt=""
2023-12-16 20:09:40 +04:00
data:image/s3,"s3://crabby-images/62143/6214342001e6fddc7e93925aa9d678cbe5296fe4" alt=""
Результат отработки Consumer_2:
2023-12-16 21:04:41 +04:00
data:image/s3,"s3://crabby-images/fe3b8/fe3b86e15db43098136403a98712a2c1d667fcde" alt=""
2023-12-16 20:09:40 +04:00
data:image/s3,"s3://crabby-images/f1d96/f1d963e7cb6a6fc657c6e52cdb33636fd05e6a38" alt=""
Вывод: Consumer_2 нагружает меньше памяти, чем Consumer_1 и принимает сообщения гораздо быстрее, тем самым не позволяя очереди накапливать огромное количество сообщений.