# Лабораторная работа №4 - Работа с брокером сообщений ## ПИбд-42 || Давыдов Юрий ### Цель лабораторной работы Изучение проектирования приложений при помощи брокера сообщений. ### Описание задач 1-2: В рамках данной лабораторной работы был установлен брокер сообщений RabbitMQ. После этого для обучения были пройдены первые три урока из RabbitMQ Tutorials на ЯП Python. Результаты приложены в виде скриншотов: - Итоги первого урока: ![изображение 1](./pictures/img_lesson_1.png) - Итоги второго урока: ![изображение 2](./pictures/img_lesson_2.png) - Итоги третьего урока: ![изображение 3](./pictures/img_lesson_3.png) ### Предметная область: В качестве предметной области применяется область из прошлой лабораторной работы - списки абитуриентов для поступления в университет. ### Описание задачи 3: Далее в рамках лабораторной работы по предметной области были разработаны демонстрационные приложения Publisher, Consumer_1 и Consumer_2. Результаты их работы: - Данные по очереди first_queue, запущен один экземпляр Consumer_1: ![изображение 1](./pictures/1_Consumer1.png) - Данные по очереди second_queue, запущен один экземпляр Consumer_2: ![изображение 2](./pictures/Consumer2.png) - Данные по очереди first_queue, запущено два экземпляра Consumer_1: ![изображение 3](./pictures/2_Consumer1.png) - Данные по очереди first_queue, запущено три экземпляра Consumer_1: ![изображение 4](./pictures/3_Consumer1.png) ### Выводы: По представленным данным хорошо видно, что second_queue не заполняется совсем, это связано с тем, что обработка сообщений там моментальная и в очереди им задерживаться не приходится. В свою очередь, Cunsomer_1 тратит на обработку сообщения 2-3 секунды, поэтому очередь first_queue достаточно быстро заполняется, если запущен один экземпляр. Также было обнаружено, что чем больше экземпляров Cunsomer_1 запущено, тем медленнее заполняется очередь. Это потому, что каждый из экземпляров занимается обработкой сообщений из очереди. С увеличением числа экземпляров можно достичь момента, когда очередь перестанет заполняться.