forked from Alexey/DAS_2024_1
37 lines
2.2 KiB
Markdown
37 lines
2.2 KiB
Markdown
|
# Лабораторная работа 4 - Работа с брокером сообщений
|
|||
|
## ПИбд-42 || Алейкин Артем
|
|||
|
|
|||
|
### Описание
|
|||
|
В данной лабораторной работе мы познакомились с такой утилитой как RabbitMQ.
|
|||
|
|
|||
|
### Туториалы
|
|||
|
1. HelloWorld - Tutorial
|
|||
|
![Консольный вывод - первый туториал](images/Туториал_1.png)
|
|||
|
|
|||
|
2. Work Queues - Tutorial
|
|||
|
![Консольный вывод - второй туториал](images/Туториал_2.png)
|
|||
|
|
|||
|
3. Publish/Subscribe - Tutorial
|
|||
|
![Консольный вывод - третий туториал](images/Туториал_3.png)
|
|||
|
|
|||
|
### Основное задание
|
|||
|
Было разработано 3 приложения: Publisher, Consumer1 и Consumer2.
|
|||
|
Первое отвечало за доставку сообщений в очереди. Оно генерирует одно сообщение раз в секунду.
|
|||
|
Второе и Третье за обработку этих сообщений из очередей, но Consumer1 имел искусственную задержку в 2-3 секунды, в то время как Consumer2 таких ограничений не имел и работу.
|
|||
|
|
|||
|
### Шаги для запуска:
|
|||
|
1. Запуск контейнеров:
|
|||
|
```
|
|||
|
docker-compose up -d
|
|||
|
```
|
|||
|
|
|||
|
В результате мы можем посмотреть графики по этой ссылке http://localhost:15672/
|
|||
|
![График Consumer1 - медленный](images/Лаба_Отчет2.png)
|
|||
|
![График Consumer2 - быстрый](images/Лаба_Отчет1.png)
|
|||
|
|
|||
|
После этого было добавлено еще 3 клиента типа Consumer1 и только после этого их суммарной производительности стало хватать для обработки сообщений.
|
|||
|
![График Consumer1 для нескольких клиентов - медленный](images/Лаба_Отчет3.png)
|
|||
|
![График Consumer2 - быстрый](images/Лаба_Отчет4.png)
|
|||
|
|
|||
|
|
|||
|
Видео демонстрации работы: https://vk.com/video248424990_456239611?list=ln-v0VkWDOiRBxdctENzV
|