Merge pull request 'lazarev_andrey_lab_2' (#65) from lazarev_andrey_lab_2 into main
Reviewed-on: #65
This commit is contained in:
commit
d23e808325
1
lazarev_andrey_lab_2/.gitignore
vendored
Normal file
1
lazarev_andrey_lab_2/.gitignore
vendored
Normal file
@ -0,0 +1 @@
|
||||
var/
|
56
lazarev_andrey_lab_2/README.md
Normal file
56
lazarev_andrey_lab_2/README.md
Normal file
@ -0,0 +1,56 @@
|
||||
# Лабораторная работа №2
|
||||
|
||||
## Описание проекта
|
||||
|
||||
Проект разворачивает 3 программы в отдельных контейнерах с использованием Docker Compose:
|
||||
1. **generateFiles** - программа, выполняющая подготовку для последующих задач(генерирует файлы и помещает их в `./var/data`);
|
||||
2. **first** - программа, выполняющая задачу 1.0 (ищет самый большой по объему файл в `./var/data` и перекладывает его в `./var/result`);
|
||||
3. **second** - программа, выполняющая задачу 2.1 (ищет наибольшее число в найденном раннее файле и записывет его квадрат в `./var/result/result.txt`).
|
||||
|
||||
## Струкутура проекта
|
||||
|
||||
### Проект состоит из:
|
||||
|
||||
- 3 папки(generateFiles, first, second)
|
||||
- Каждая папка содержит в себе файл с расширением `.py` с кодом программы;
|
||||
- Кадлая папка сожержит в себе файл `Dockerfile` с инструкцией по созданию Docker образа.
|
||||
|
||||
- Файл `.gitignore` для исключения временных файлов директории `var/`;
|
||||
|
||||
- Файл `docker-compose.yml` с конфигурацией Docker Compose.
|
||||
|
||||
Каждый файл содержит в себе комментарии с описанием функциональности.
|
||||
|
||||
## Запуск
|
||||
|
||||
1. Скачать и установить Docker и Docker Compose;
|
||||
2. Перейти в директорию с файлом docker-compose.yml;
|
||||
3. Открыть консоль и запустить сервисы командой
|
||||
```bash
|
||||
docker-compose up --build -d
|
||||
```
|
||||
4. Дождаться запуска всех сервисов
|
||||
```bash
|
||||
[+] Running 3/3
|
||||
✔ Container lazarev_andrey_lab_2-generate-files-1 Started 0.5s
|
||||
✔ Container lazarev_andrey_lab_2-first-1 Started 1.3s
|
||||
✔ Container lazarev_andrey_lab_2-second-1 Started 2.0s
|
||||
```
|
||||
5. Остановка всех сервисов
|
||||
Для завершения работы с сервисами необходимо выполнить команду:
|
||||
```bash
|
||||
docker-compose down
|
||||
```
|
||||
Дождаться завершения работы:
|
||||
```bash
|
||||
[+] Running 4/4
|
||||
✔ Container lazarev_andrey_lab_2-second-1 Removed 0.0s
|
||||
✔ Container lazarev_andrey_lab_2-first-1 Removed 0.0s
|
||||
✔ Container lazarev_andrey_lab_2-generate-files-1 Removed 0.0s
|
||||
✔ Network lazarev_andrey_lab_2_default Removed 0.4s
|
||||
```
|
||||
|
||||
## Видеодемонстрация работоспособности
|
||||
|
||||
[Демонстрация работы сервисов](https://files.ulstu.ru/s/5EKdE7mFfApLDkr)
|
||||
|
24
lazarev_andrey_lab_2/docker-compose.yml
Normal file
24
lazarev_andrey_lab_2/docker-compose.yml
Normal file
@ -0,0 +1,24 @@
|
||||
services:
|
||||
|
||||
generate-files: # Определяет первый сервис с именем "generate-files"
|
||||
build:
|
||||
context: ./generateFiles # Указывает путь к Docker-контексту для сборки образа (./generateFiles)
|
||||
volumes:
|
||||
- ./var/data:/data # Монтирует локальную директорию ./var/data в контейнерную директорию /data
|
||||
|
||||
first: # Определяет второй сервис с именем "first"
|
||||
build:
|
||||
context: ./first # Указывает путь к Docker-контексту для сборки образа (./first)
|
||||
volumes:
|
||||
- ./var/data:/data # Монтирует локальную директорию ./var/data в контейнерную директорию /data
|
||||
- ./var/result:/result # Монтирует локальную директорию ./var/result в контейнерную директорию /result
|
||||
depends_on:
|
||||
- generate-files # Определяет, что сервис "first" зависит от "generate-files" и будет запущен после него
|
||||
|
||||
second: # Определяет третий сервис с именем "second"
|
||||
build:
|
||||
context: ./second # Указывает путь к Docker-контексту для сборки образа (./second)
|
||||
volumes:
|
||||
- ./var/result:/result # Монтирует локальную директорию ./var/result в контейнерную директорию /result
|
||||
depends_on:
|
||||
- first # Определяет, что сервис "second" зависит от "first" и будет запущен после него
|
8
lazarev_andrey_lab_2/first/Dockerfile
Normal file
8
lazarev_andrey_lab_2/first/Dockerfile
Normal file
@ -0,0 +1,8 @@
|
||||
#описание в Dockerfile generateFiles
|
||||
FROM python:3.9-slim
|
||||
|
||||
WORKDIR /first
|
||||
|
||||
COPY first.py /first/
|
||||
|
||||
CMD ["python", "first.py"]
|
31
lazarev_andrey_lab_2/first/first.py
Normal file
31
lazarev_andrey_lab_2/first/first.py
Normal file
@ -0,0 +1,31 @@
|
||||
import os
|
||||
|
||||
filesPath="/data" #путь до папки с данными
|
||||
resultPath="/result" #путь до папки с результатами
|
||||
|
||||
#функция нахождения файла с наибольшим объемом
|
||||
def find_highest_volume():
|
||||
maxSizeFileName = ""
|
||||
maxSize = 0
|
||||
for filename in os.listdir(filesPath):
|
||||
curSize = os.path.getsize(f"{filesPath}/{filename}")
|
||||
if maxSize < curSize :
|
||||
maxSize = curSize
|
||||
maxSizeFileName = filename
|
||||
dataFile = open(f"{filesPath}/{maxSizeFileName}", "r")
|
||||
result = open(f"{resultPath}/{maxSizeFileName}", "w+")
|
||||
result.write(dataFile.read())
|
||||
print(f"файлик({maxSizeFileName}) с наибольшим объемом найден, перемещаем его")
|
||||
|
||||
#проверка наличия папки с результатами
|
||||
if not os.path.exists(resultPath):
|
||||
print("создаем папку для результатов")
|
||||
os.mkdir(resultPath)
|
||||
else: #если папка есть очищает ее
|
||||
for filename in os.listdir(resultPath):
|
||||
if os.path.isfile(f"{resultPath}/{filename}"):
|
||||
os.remove(f"{resultPath}/{filename}")
|
||||
print("удаляем файлы из папки с результатами")
|
||||
|
||||
#находит файл с наибольшим объемом
|
||||
find_highest_volume()
|
11
lazarev_andrey_lab_2/generateFiles/Dockerfile
Normal file
11
lazarev_andrey_lab_2/generateFiles/Dockerfile
Normal file
@ -0,0 +1,11 @@
|
||||
# Использует базовый образ Python 3.9 на основе slim-версии, которая минимальна и легковесна
|
||||
FROM python:3.9-slim
|
||||
|
||||
# Устанавливает рабочую директорию в контейнере как /generatefiles
|
||||
WORKDIR /generatefiles
|
||||
|
||||
# Копирует файл first.py из текущей директории на хосте в директорию /generatefiles в контейнере
|
||||
COPY generateFiles.py /generatefiles/
|
||||
|
||||
# Задает команду для запуска контейнера: выполнение скрипта generateFiles.py с помощью Python
|
||||
CMD ["python", "generateFiles.py"]
|
32
lazarev_andrey_lab_2/generateFiles/generateFiles.py
Normal file
32
lazarev_andrey_lab_2/generateFiles/generateFiles.py
Normal file
@ -0,0 +1,32 @@
|
||||
import os
|
||||
import random
|
||||
|
||||
fPath = '/data' #путь до папки
|
||||
|
||||
#функция очищения папки
|
||||
def empty_folder():
|
||||
for filename in os.listdir(fPath):
|
||||
if os.path.isfile(f"{fPath}/{filename}"):
|
||||
os.remove(f"{fPath}/{filename}")
|
||||
print("папка был очищена и готова к наполнению")
|
||||
|
||||
#функция генерации файлов
|
||||
def gen_Files(files, minLines, maxLines):
|
||||
for i in range(files):
|
||||
file = open(f"{fPath}/file_{i}.txt", "w+")
|
||||
for _ in range(random.randint(minLines, maxLines)):
|
||||
num=random.randint(20, 1000)
|
||||
file.write(f"{num} \n")
|
||||
file.close()
|
||||
print("файлы созданы и готовы к работе")
|
||||
|
||||
#проверка наличия папки
|
||||
if os.path.exists(fPath): #если папка есть очищает ее
|
||||
print("папка есть и полна старых файлов")
|
||||
empty_folder()
|
||||
else: #если папки нет создает ее
|
||||
print("папки нет, надо создать")
|
||||
os.mkdir(fPath)
|
||||
|
||||
#генерирует файлы в папке(5-20), в каждом файле от 1 до 500 строк
|
||||
gen_Files(random.randint(5, 20), 1, 500)
|
8
lazarev_andrey_lab_2/second/Dockerfile
Normal file
8
lazarev_andrey_lab_2/second/Dockerfile
Normal file
@ -0,0 +1,8 @@
|
||||
#описание в Dockerfile generateFiles
|
||||
FROM python:3.9-slim
|
||||
|
||||
WORKDIR /second
|
||||
|
||||
COPY second.py /second/
|
||||
|
||||
CMD ["python", "second.py"]
|
26
lazarev_andrey_lab_2/second/second.py
Normal file
26
lazarev_andrey_lab_2/second/second.py
Normal file
@ -0,0 +1,26 @@
|
||||
import os
|
||||
import math
|
||||
|
||||
rPath="/result"
|
||||
|
||||
#функция поиска наибольшего числа в файле, возведение в степень и запись в итоговый файл
|
||||
def find_highest_num():
|
||||
hightesVolumeFile = os.listdir(f"{rPath}")[0]
|
||||
|
||||
dataFile = open(f"{rPath}/{hightesVolumeFile}", "r")
|
||||
|
||||
lines = [line.strip() for line in dataFile]
|
||||
highestNumber = max(lines)
|
||||
|
||||
resultFile = open(f"{rPath}/result.txt", "w+")
|
||||
resultFile.write(str(pow(int(highestNumber), 2)))
|
||||
|
||||
print(f"Нашел наибольшее число({highestNumber}) и возвел его в степень ({pow(int(highestNumber), 2)})")
|
||||
|
||||
#проверка если в папке result есть файл с результатами(удаляем его)
|
||||
if os.path.exists(f"{rPath}/result.txt"):
|
||||
os.remove(f"{rPath}/result.txt")
|
||||
print("результаты уже есть, удаляем")
|
||||
|
||||
#поиск наибольшего числа, возведения в степень и запись в итоговый файл
|
||||
find_highest_num()
|
Loading…
Reference in New Issue
Block a user