DAS_2023_1/mashkova_margarita_lab_4
2024-01-10 08:39:13 +04:00
..
Consumer1/src/main/java/org/example mashkova_margarita_lab_4 ready 2024-01-10 08:39:13 +04:00
Consumer2/src/main/java/org/example mashkova_margarita_lab_4 ready 2024-01-10 08:39:13 +04:00
Publisher/src/main/java/org/example mashkova_margarita_lab_4 ready 2024-01-10 08:39:13 +04:00
console_consumer1.png mashkova_margarita_lab_4 ready 2024-01-10 08:39:13 +04:00
console_consumer2.png mashkova_margarita_lab_4 ready 2024-01-10 08:39:13 +04:00
console_publisher.png mashkova_margarita_lab_4 ready 2024-01-10 08:39:13 +04:00
exchange.png mashkova_margarita_lab_4 ready 2024-01-10 08:39:13 +04:00
main_report.png mashkova_margarita_lab_4 ready 2024-01-10 08:39:13 +04:00
queue1.png mashkova_margarita_lab_4 ready 2024-01-10 08:39:13 +04:00
queue2.png mashkova_margarita_lab_4 ready 2024-01-10 08:39:13 +04:00
README.md mashkova_margarita_lab_4 ready 2024-01-10 08:39:13 +04:00

Лабораторная работа №4

ПИбд-42 Машкова Маргарита

Задание

Необходимо выбрать предметную область и разработать следующие приложения:

  1. Publisher. Программа, которая создаёт один exchange с типом fanout. Программа должна раз в секунду генерировать сообщения в журнал событий согласно вашей предметной области. Например, событие "пришёл заказ" или "сообщение от пользователя" или "необходимо создать отчёт".
  2. Consumer 1. Программа, которая создаёт под себя отдельную не анонимную (!) очередь (queue) (то есть имя queue НЕ пустая строка), создаёт binding на exchange и начинает принимать сообщения (consume). Программа должна обрабатывать сообщения 2-3 секунды. Можно реализовать через обычный Thread.Sleep.
  3. Consumer 2. Аналогично Consumer 1, только сообщения необходимо обрабатывать моментально. Только имя очереди должно отличаться от Consumer 1.

Запуск программы

Запустить программу Consumer1 Запустить программу Consumer2 Запустить программу Publisher

Описание работы программы

Publisher каждую секунду отправляет сообщение Пришел заказ №. Consumer1 и Consumer2 получают сообщения, обрабатывают его Consumer1 в течении 4 секунд, Consumer2 в течении 6 секунд.

Тесты

Вывод отправителя:

Вывод отправителя

Вывод получателя 1:

Вывод получателя1

Вывод получателя 2:

Вывод получателя2

Отчеты из RabbitMQ Management UI:

Основной отчет

Очередь Consumer1:

Очередь Consumer1

Очередь Consumer2:

Очередь Consumer2

Exchange:

Exchange

Ссылка на видео: https://youtu.be/9gr2HpZrYyk