92 lines
3.0 KiB
Markdown
92 lines
3.0 KiB
Markdown
|
# Лабораторная работа №2 - Разработка простейшего распределенного приложения
|
|||
|
|
|||
|
## ПИбд-42 || Давыдов Юрий
|
|||
|
|
|||
|
## Описание
|
|||
|
|
|||
|
В рамках данной лабораторной работы было создано два контейнера спростыми программами на python, соблюдающими условие: результат первой программы - это исходные данные второй программы.
|
|||
|
|
|||
|
### Цель лабораторной работы
|
|||
|
|
|||
|
изучение техники создания простого распределённого приложения
|
|||
|
|
|||
|
### 1. Варианты
|
|||
|
|
|||
|
Для обеих программ был выбран вариант 1.
|
|||
|
|
|||
|
Вариант первой программы:
|
|||
|
**1**. Ищет в каталоге /var/data файл с наибольшим количеством строк и перекладывает его в /var/result/data.txt.
|
|||
|
|
|||
|
Вариант второй программы:
|
|||
|
**1**. Ищет набольшее число из файла /var/data/data.txt и сохраняет его вторую степень в /var/result/result.txt.
|
|||
|
|
|||
|
### 2. Dockerfile
|
|||
|
|
|||
|
Два Dockerfile имеют сходную структуру:
|
|||
|
|
|||
|
```Dockerfile
|
|||
|
#Берем базовый образ python
|
|||
|
FROM python:3.12
|
|||
|
|
|||
|
#Устанавливаем рабочую директорию
|
|||
|
WORKDIR /app
|
|||
|
|
|||
|
#Копирум код в рабочую директорию
|
|||
|
COPY main.py .
|
|||
|
|
|||
|
#Задаем /var/data как монтируемый
|
|||
|
VOLUME ["/var/data"]
|
|||
|
#Задаем /var/result как монтируемый
|
|||
|
VOLUME ["/var/result"]
|
|||
|
|
|||
|
#Задаем команду для выполнения программы
|
|||
|
CMD ["python", "main.py"]
|
|||
|
```
|
|||
|
|
|||
|
### 3. Docker-compose
|
|||
|
|
|||
|
`docker-compose.yml`:
|
|||
|
|
|||
|
```yaml
|
|||
|
services:
|
|||
|
#Первая программа
|
|||
|
first:
|
|||
|
#Директория для сборки первой программы
|
|||
|
build: ./WorkFirst/
|
|||
|
#Монтирование 2 каталогов из хост системы
|
|||
|
volumes:
|
|||
|
- ./data:/var/data
|
|||
|
- ./result_first:/var/result
|
|||
|
|
|||
|
#Вторая программа
|
|||
|
second:
|
|||
|
#Директория для сборки второй программы
|
|||
|
build: ./WorkSecond/
|
|||
|
#Задание очередности запуска через depends_on
|
|||
|
depends_on:
|
|||
|
- first
|
|||
|
#Монтирование 2 каталогов из хост системы
|
|||
|
volumes:
|
|||
|
- ./result_first:/var/data
|
|||
|
- ./result_second:/var/result
|
|||
|
```
|
|||
|
|
|||
|
### 4. Инструкция для работы
|
|||
|
|
|||
|
1. Клонирование репозитория:
|
|||
|
|
|||
|
```
|
|||
|
git clone <ссылка-на-репозиторий>
|
|||
|
cd <папка репозитория>
|
|||
|
cd <папка лабораторной работы>
|
|||
|
```
|
|||
|
|
|||
|
2. Запуск контейнеров:
|
|||
|
|
|||
|
```
|
|||
|
docker compose up --build
|
|||
|
```
|
|||
|
|
|||
|
3. Результаты:
|
|||
|
Итог работы первой программы будет в папке `result_first`, а второй - в `result_second`.
|