DAS_2024_1/balakhonov_danila_lab_4/README.md

5.0 KiB
Raw Blame History

Лабораторная работа номер 4

Здравствуйте меня зовут Балахонов Данила группа ПИбд-42

— Балахонов Данила ПИбд-42

Видео лабораторной работы номер 4 доступно по этой ссылке.

Как запустить лабораторную работу номер 4?

Необходимые компоненты для запуска лабораторной работы номер 4

Здесь рассказана установка необходимых компонентов для запуска лабораторной работы номер 3 под дистрибутив GNU/Linux Ubuntu.

Для запуска лабораторной работы номер 4 необходимы такие компоненты:

  • Git
  • Docker
  • Docker compose

Чтобы установить Git, необходимо ввести данные команды в командную строку:

sudo apt-get update
sudo apt-get install git

Чтобы установить Docker и Docker compose, стоит ввести такие команды:

# Настройка репозитория Docker
sudo apt-get update
sudo apt-get install ca-certificates curl
sudo install -m 0755 -d /etc/apt/keyrings
sudo curl -fsSL https://download.docker.com/linux/ubuntu/gpg -o /etc/apt/keyrings/docker.asc
sudo chmod a+r /etc/apt/keyrings/docker.asc

echo \
  "deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.asc] https://download.docker.com/linux/ubuntu \
  $(. /etc/os-release && echo "$VERSION_CODENAME") stable" | \
  sudo tee /etc/apt/sources.list.d/docker.list > /dev/null
sudo apt-get update

# Установка Docker и его компонентов
sudo apt-get install docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin

Помимо Docker необходимо установить python3.

sudo apt install python3

Запуск лабораторной работы номер 4

Для запуска лабораторной работы номер 4 необходимо склонировать репозиторий в любую папку и перейти на ветку balakhonov_danila_lab_4. Далее в папке с docker-compose.yaml нужно вызвать такую команду:

sudo docker compose up -d

Таким образом контейнер с редисом будет запущен в фоне.

Чтобы запустить программу, нужно вызывать три разных файла:

  • Файл издателя
python3 program/publisher.py
  • Файл первого потребителя с задержкой
python3 program/consumer_1.py
  • Файл второго потребителя
python3 program/consumer_2.py

Какие технологии были использованы?

Для выполнения лабораторной работы номер 4 были использованы такие технологии, как:

  • Docker compose
  • Git
  • Python 3
  • Pika
  • RabbitMQ

Что делает лабораторная работа номер 4?

Суть лабораторной работы номер 4 заключается в получении навыков работы с брокером сообщений.

Вывод лабораторной работы номер 4

Были пройдены туториалы по ознакомлению с RabbitMQ:

1 туториал

1 туториал

2 туториал

2 туториал

3 туториал

3 туториал

Также была разработана программа, которая состоит из издателя и двух потребителей. Разница между двумя потребителями заключается в скорости их обработки. Первый потребитель имеет некоторую задержку, поэтому он обрабатывает полученные данные гораздо дольше, чем второй потребитель. Из-за задержки происходит накапливание сообщений в очереди первого потребителя. Так как второй потребитель не имеет задержек, то и его очередь не будет настолько заметно возрастать. Если запустить несколько первых потребителей, то очередь также накапливается, но она меньше, так как уже два потребителя принимают сообщения.