2023-11-20 00:10:30 +04:00
# Лабораторная работа №4 - Работа с брокером сообщений
**Цель**: изучение проектирования приложений при помощи брокера сообщений.
**Задачи**:
1. Установить брокер сообщений RabbitMQ.
2. Пройти уроки 1, 2 и 3 из [RabbitMQ Tutorials ](https://www.rabbitmq.com/getstarted.html ) на любом языке программирования.
3. Продемонстрировать работу брокера сообщений.
2023-11-20 00:27:20 +04:00
## Установка брокера сообщений RabbitMQ
2023-11-20 00:10:30 +04:00
Можно не использовать Docker и использовать локальный ПК.
[Страница скачивания RabbitMQ с офф. сайта ](https://www.rabbitmq.com/download.html ).
[Страница релизов RabbitMQ ](https://github.com/rabbitmq/rabbitmq-server/releases/ ), где есть бинарные установщики для всех современных платформ.
## Прохождение tutorial
Достаточно для каждого урока скриншота, где виден запуск одновременно `producer` и `consumer` , а также видно, что сообщения передаются.
2023-11-20 00:27:20 +04:00
## Разработка демонстрационных приложений
2023-11-20 00:10:30 +04:00
См. 3 главу tutorial.
Необходимо выбрать предметную область и разработать следующие приложения:
1. **Publisher** .
Программа, которая создаёт один **exchange** с типом _fanout_ .
Программа должна раз в секунду генерировать сообщения в журнал событий согласно вашей предметной области.
Например, событие "пришёл заказ" или "сообщение от пользователя" или "необходимо создать отчёт".
2. **Consumer 1** .
2023-11-20 00:27:20 +04:00
Программа, которая создаёт под себя отдельную не анонимную (!) очередь (**queue**) (то есть имя queue Н Е пустая строка), создаёт **binding** на **exchange** и начинает принимать сообщения (_consume_).
2023-11-20 00:10:30 +04:00
Программа должна обрабатывать сообщения, например, 3 секунды.
Можно реализовать через обычный _Thread.Sleep_ (для C#).
3. **Consumer 2** .
Аналогично _Consumer 1_ , только сообщения необходимо обрабатывать моментально.
Только имя очереди должно отличаться от _Consumer 1_ .
Далее необходимо собрать и запустить приложения одновременно по одному экземпляру.
Сделать в отчёте вывод о скорости обработки _consumer_ -ами событий от _publisher_ -а .
Для этого можно посмотреть заполненность созданных очередей.
А для этого можно использовать скриншот из **RabbitMQ Management UI** .
Запустить несколько копий _Consumer 1_ .
Проверить заново заполненность очередей через _UI_ .
## Правила оформления pull request
Код и отчёт с о скриншотами необходимо положить в папку `tasks/фамилия-инициалы/lab_4` .
2023-11-20 00:27:20 +04:00
Н е забудьте о файле `.gitignore` , чтобы не закоммитить ничего лишнего.
2023-11-20 00:10:30 +04:00
Для C#-проектов это, например, папки `bin` и `obj` .
Правила именования ветки: `фамилия-инициалы-lab-номер` , например, `moiseev-vv-lab-4` .
Название pull request: `[Л/Р 4] ФАМИЛИЯ ИМЯ` , например, `[Л/Р 4] Моисеев Владислав` .