.. | ||
data | ||
result | ||
screens | ||
worker-1 | ||
worker-2 | ||
docker-compose.yml | ||
README.md |
Лабораторная работа №2 - Разработка простейшего распределенного приложения
Цель: изучение техники создания простого распределенного приложения.
Задачи:
- Согласно вышему варианту (выбирайте любой) разработать два приложения такие, что результат первого является исходными данными для второго.
- Изучить файлы сборки образов docker и разработать их для созданных приложений.
- Собрать файл docker-compose.yml для запуска приложений. Разобраться с монтированием каталогов из хост-системы.
- Правильно закоммитить результат без лишних файлов.
- Оформить pull request по правилам и отправить его на проверку.
Разработка двух приложений
Вариант первого приложения(worker-1): 5 - Ищет в каталоге /var/data файл с самым коротким названием и перекладывает его в /var/result/data.txt Вариант второго приложения(worker_2) 1 - Ищет набольшее число из файла /var/data/data.txt и сохраняет его вторую степень в /var/result/result.txt
Приложения выполнены на языке Java
Worker-1
![Worker-1](/Alexey/DAS_2023_1/media/branch/almukhammetov_bulat_lab_6/savenkov_alexander_lab_2/screens/img1.png)
Worker-2
![Worker-2](/Alexey/DAS_2023_1/media/branch/almukhammetov_bulat_lab_6/savenkov_alexander_lab_2/screens/img2.png)
Запуск
Запуск контейнеров производится командой "docker-compose up -d"
Работа программы
- Создание двух деррикторий: worker-1 и worker-2 для реализаций двух программ.
- Описание Dockerfile для создания образов для обоих программ.
Worker-1 Dockerfile
![Worker-1 Dockerfile](/Alexey/DAS_2023_1/media/branch/almukhammetov_bulat_lab_6/savenkov_alexander_lab_2/screens/img3.png)
Worker-2 Dockerfile
![Worker-2 Dockerfile](/Alexey/DAS_2023_1/media/branch/almukhammetov_bulat_lab_6/savenkov_alexander_lab_2/screens/img4.png)
data
![data](/Alexey/DAS_2023_1/media/branch/almukhammetov_bulat_lab_6/savenkov_alexander_lab_2/screens/img5.png)
result
![result](/Alexey/DAS_2023_1/media/branch/almukhammetov_bulat_lab_6/savenkov_alexander_lab_2/screens/img6.png)
f3.txt
![f3.txt](/Alexey/DAS_2023_1/media/branch/almukhammetov_bulat_lab_6/savenkov_alexander_lab_2/screens/img7.png)
file_with_a_very_long_name_that_is_often_used_in_programming.txt
![file_with_a_very_long_name_that_is_often_used_in_programming.txt](/Alexey/DAS_2023_1/media/branch/almukhammetov_bulat_lab_6/savenkov_alexander_lab_2/screens/img8.png)
file1.txt
![file1.txt](/Alexey/DAS_2023_1/media/branch/almukhammetov_bulat_lab_6/savenkov_alexander_lab_2/screens/img9.png)
docker-compose
![docker-compose](/Alexey/DAS_2023_1/media/branch/almukhammetov_bulat_lab_6/savenkov_alexander_lab_2/screens/img10.png)
Сборка и запуска контейнеров
![Сборка и запуска контейнеров](/Alexey/DAS_2023_1/media/branch/almukhammetov_bulat_lab_6/savenkov_alexander_lab_2/screens/img11.png)
Проверка в Docker Desktop контейнеров и образов
![Проверка в Docker Desktop контейнеров и образов](/Alexey/DAS_2023_1/media/branch/almukhammetov_bulat_lab_6/savenkov_alexander_lab_2/screens/img12.png)
Смотрим, что выдает нам первый воркер в консоль
![Смотрим, что выдает нам первый воркер в консоль](/Alexey/DAS_2023_1/media/branch/almukhammetov_bulat_lab_6/savenkov_alexander_lab_2/screens/img14.png)
Смотрим, что выдает нам второй воркер в консоль
![Смотрим, что выдает нам второй воркер в консоль](/Alexey/DAS_2023_1/media/branch/almukhammetov_bulat_lab_6/savenkov_alexander_lab_2/screens/img15.png)
Смотрим, что при запуске контейнеров действительно в папке result создалось два файла data.txt и result.txt
![Смотрим, что при запуске контейнеров действительно в папке result создалось два файла data.txt и result.txt](/Alexey/DAS_2023_1/media/branch/almukhammetov_bulat_lab_6/savenkov_alexander_lab_2/screens/img16.png)
Смотрим, что лежит в файле data.txt
![Смотрим, что лежит в файле data.txt](/Alexey/DAS_2023_1/media/branch/almukhammetov_bulat_lab_6/savenkov_alexander_lab_2/screens/img17.png)
Смотрим, что лежит в файле result.txt
![Смотрим, что лежит в файле result.txt](/Alexey/DAS_2023_1/media/branch/almukhammetov_bulat_lab_6/savenkov_alexander_lab_2/screens/img18.png)
Видео
Видео с разбором лабораторной работы - https://youtu.be/o_sTok7W22s