2023-12-16 20:09:40 +04:00
# Отчет по лабораторной работе №4
Выполнила студентка г р . ИСЭбд-41 Зиновьева А . Д.
## Прохождение tutorial
Установила rabbitMQ server, erlang и зашла в брокер под гостем по http://localhost:15672/#/
data:image/s3,"s3://crabby-images/c706e/c706eee5ea8feac30ddd18f0e77db205ea77bf4b" alt=""
Туториал 1:
data:image/s3,"s3://crabby-images/f8d8b/f8d8bc1b5a2bd1df8c80b1fd0babd634c7b03bd5" alt=""
data:image/s3,"s3://crabby-images/0401b/0401bd3de81c81e2ad9f19cde913313ae467f556" alt=""
data:image/s3,"s3://crabby-images/de676/de6763f0544dbd3e5ad0ddce864ba980087d0d70" alt=""
Туториал 2:
data:image/s3,"s3://crabby-images/0a468/0a4680425723e4161304c82dcbba133c35e65dd3" alt=""
data:image/s3,"s3://crabby-images/584c8/584c8fe84a6b22b42969a57355bdff8cef61ee0d" alt=""
data:image/s3,"s3://crabby-images/53331/53331e50fe9a1269375b896435cf546cf40fff38" alt=""
Туториал 3:
data:image/s3,"s3://crabby-images/14122/14122366ccb67d6149f4687bd9a4133192207f89" alt=""
data:image/s3,"s3://crabby-images/1cd24/1cd24e0af90a661a4ae5ff7e1ec8cc1c8615f174" alt=""
data:image/s3,"s3://crabby-images/06be5/06be5d29d181ac370c32a06df33927143117d3db" 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/d9c85/d9c850c74d2e446c1983cad4052164c8ad45cc83" alt=""
2023-12-16 20:09:40 +04:00
data:image/s3,"s3://crabby-images/5bcc9/5bcc93738b0bc33dddb393680744569838310fe7" alt=""
Результат отработки Consumer_2:
2023-12-16 21:04:41 +04:00
data:image/s3,"s3://crabby-images/219f4/219f42217c6614cd6084ce050f1353351dc9239d" alt=""
2023-12-16 20:09:40 +04:00
data:image/s3,"s3://crabby-images/dbf76/dbf761a8d4dbb0ffc50a62b8024aa1474804808c" alt=""
Вывод: Consumer_2 нагружает меньше памяти, чем Consumer_1 и принимает сообщения гораздо быстрее, тем самым не позволяя очереди накапливать огромное количество сообщений.