118 lines
3.3 KiB
Markdown
118 lines
3.3 KiB
Markdown
# Отчет по лабораторной работе №4
|
||
|
||
Выполнила студентка гр. ИСЭбд-41 Зиновьева А. Д.
|
||
|
||
## Прохождение tutorial
|
||
|
||
Установила rabbitMQ server, erlang и зашла в брокер под гостем по http://localhost:15672/#/
|
||
data:image/s3,"s3://crabby-images/20ce3/20ce3aacc2d0fd2a96e1e48ca526d737490f038d" alt=""
|
||
|
||
Туториал 1:
|
||
|
||
data:image/s3,"s3://crabby-images/2389d/2389d40dd77e8a9b569fd0af6d8afe02249df1e4" alt=""
|
||
data:image/s3,"s3://crabby-images/78b2f/78b2fb41515e1a3225b50f2aa38b67d4a0a7c3d4" alt=""
|
||
data:image/s3,"s3://crabby-images/7a27f/7a27f8a023fd1f6d55780faca6adb0ac2da1c1f8" alt=""
|
||
|
||
Туториал 2:
|
||
|
||
data:image/s3,"s3://crabby-images/bc2e1/bc2e1dbd0b4f652f46a45595c207febbb05016f8" alt=""
|
||
data:image/s3,"s3://crabby-images/5019b/5019b6d948760e3c1b642a8e90f82f10b0c4c9ca" alt=""
|
||
data:image/s3,"s3://crabby-images/f0673/f06737837fccac24428ddec69db87e2f3ae55e16" alt=""
|
||
|
||
Туториал 3:
|
||
|
||
data:image/s3,"s3://crabby-images/e7204/e7204ec28ec89635e2a4bf9fd73b115b61e74270" alt=""
|
||
data:image/s3,"s3://crabby-images/4a940/4a940a35b032a72c29a9feff6c5ed60e6bd22012" alt=""
|
||
data:image/s3,"s3://crabby-images/9af93/9af933908c66580734f6f258f6561ab86021dc2d" alt=""
|
||
|
||
## Разработка демонстрационных приложений
|
||
|
||
Предметная область: Дополнительный соглашения и договоры на проживание.
|
||
Разработаны три приложения, согласно предметной области.
|
||
|
||
1. Publisher
|
||
|
||
```py
|
||
import pika
|
||
import time
|
||
import random
|
||
|
||
collection = ["the employment document", "The document is agreed", "Signatures are provided", "the employee is accepted"]
|
||
|
||
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:
|
||
|
||
data:image/s3,"s3://crabby-images/1466e/1466ed52db2fb63698fc61c94c4491909b605f69" alt=""
|
||
data:image/s3,"s3://crabby-images/1bc91/1bc91ac1734485fb2dc70b8abdb47d6de98aeb07" alt=""
|
||
|
||
Результат отработки Consumer_2:
|
||
|
||
data:image/s3,"s3://crabby-images/ede3a/ede3abcd33526ae63c52d0e2b8cc0a03988b46b5" alt=""
|
||
data:image/s3,"s3://crabby-images/96320/963208932770ee8ff0062354c7a1ed2de5aaca61" alt=""
|
||
|
||
Вывод: Consumer_2 нагружает меньше памяти, чем Consumer_1 и принимает сообщения гораздо быстрее, тем самым не позволяя очереди накапливать огромное количество сообщений. |