.. | ||
data | ||
result | ||
screens | ||
worker-1 | ||
worker-2 | ||
docker-compose.yml | ||
README.md |
Лабораторная работа №2 - Разработка простейшего распределенного приложения
Цель: изучение техники создания простого распределенного приложения.
Задачи:
- Согласно вышему варианту (выбирайте любой) разработать два приложения такие, что результат первого является исходными данными для второго.
- Изучить файлы сборки образов docker и разработать их для созданных приложений.
- Собрать файл docker-compose.yml для запуска приложений. Разобраться с монтированием каталогов из хост-системы.
- Правильно закоммитить результат без лишних файлов.
- Оформить pull request по правилам и отправить его на проверку.
Описание заданий двух приложений
Вариант первого приложения(worker-1): 1 - Ищет в каталоге /var/data файл с наибольшим количеством строк и перекладывает его в /var/result/data.txt Вариант второго приложения(worker-2): 0 - сохраняет произведение первого и последнего числа из файла /var/result/data.txt в /var/result/result.txt
Cтруктура проекта
![Cтруктура проекта](/Alexey/DAS_2023_1/media/branch/belyaeva_ekaterina_lab_4/volkov_rafael_lab_2/screens/img1.png)
Работа программы
- Создано две директории: worker-1 и worker-2 для двух программ.
- Dockerfile для образов обоих программ.
Worker-1 Dockerfile
![Worker-1 Dockerfile](/Alexey/DAS_2023_1/media/branch/belyaeva_ekaterina_lab_4/volkov_rafael_lab_2/screens/img2.png)
Worker-2 Dockerfile
![Worker-2 Dockerfile](/Alexey/DAS_2023_1/media/branch/belyaeva_ekaterina_lab_4/volkov_rafael_lab_2/screens/img3.png)
docker-compose
![docker-compose](/Alexey/DAS_2023_1/media/branch/belyaeva_ekaterina_lab_4/volkov_rafael_lab_2/screens/img7.png)
Сборка и запуска контейнеров
![Сборка и запуска контейнеров](/Alexey/DAS_2023_1/media/branch/belyaeva_ekaterina_lab_4/volkov_rafael_lab_2/screens/img8.png)
Docker Desktop контейнеры и образы
![Docker Desktop контейнеры и образы](/Alexey/DAS_2023_1/media/branch/belyaeva_ekaterina_lab_4/volkov_rafael_lab_2/screens/img9.png)
Консоль первого воркера
![Консоль первого воркера](/Alexey/DAS_2023_1/media/branch/belyaeva_ekaterina_lab_4/volkov_rafael_lab_2/screens/img11.png)
Консоль второго воркера
![Консоль второго воркера](/Alexey/DAS_2023_1/media/branch/belyaeva_ekaterina_lab_4/volkov_rafael_lab_2/screens/img12.png)
Результат работы контейнера, папка result два файла data.txt и result.txt
![Результат работы контейнера, папка result два файла data.txt и result.txt](/Alexey/DAS_2023_1/media/branch/belyaeva_ekaterina_lab_4/volkov_rafael_lab_2/screens/img13.png)
Содержимое data.txt
![Содержимое data.txt](/Alexey/DAS_2023_1/media/branch/belyaeva_ekaterina_lab_4/volkov_rafael_lab_2/screens/img14.png)
Содержимое result.txt
![Содержимое result.txt](/Alexey/DAS_2023_1/media/branch/belyaeva_ekaterina_lab_4/volkov_rafael_lab_2/screens/img15.png)
Видео
Видео с разбором лабораторной работы - https://drive.google.com/file/d/1-sLDH9PPFeHlEqzfLtcerbGs8sCALaxe/view?usp=sharing