diff --git a/.gitignore b/.gitignore
index e69de29..697082a 100644
--- a/.gitignore
+++ b/.gitignore
@@ -0,0 +1,9 @@
+
+/dozorova_alena_lab_2/.vs
+/dozorova_alena_lab_2/ConsoleApp1/.vs
+/dozorova_alena_lab_2/ConsoleApp1/bin
+/dozorova_alena_lab_2/ConsoleApp1/obj
+/dozorova_alena_lab_2/ConsoleApp1/Properties/PublishProfiles
+/dozorova_alena_lab_2/ConsoleApp2/.vs
+/dozorova_alena_lab_2/ConsoleApp2/bin
+/dozorova_alena_lab_2/ConsoleApp2/obj
diff --git a/balakhonov_danila_lab_1/README.md b/balakhonov_danila_lab_1/README.md
new file mode 100644
index 0000000..fb03807
--- /dev/null
+++ b/balakhonov_danila_lab_1/README.md
@@ -0,0 +1,59 @@
+# Лабораторная работа номер 1
+
+> Здравствуйте меня зовут Балахонов Данила группа ПИбд-42
+>
+> *— Балахонов Данила ПИбд-42*
+
+Видео лабораторной работы номер 1 доступно по этой [ссылке](https://drive.google.com/file/d/1Up_JzDcK_TjYLixpfYXN7PhJmOeg_Uck/view?usp=sharing).
+
+## Как запустить лабораторную работу номер 1?
+### Необходимые компоненты для запуска лабораторной работы номер 1
+> Здесь рассказана установка необходимых компонентов для запуска лабораторной работы номер 1 под дистрибутив GNU/Linux **Ubuntu**.
+
+Для запуска лабораторной работы номер 1 необходимы такие компоненты:
+ - Git
+ - Docker
+ - Docker compose
+
+Чтобы установить **Git**, необходимо ввести данные команды в командную строку:
+``` bash
+sudo apt-get update
+sudo apt-get install git
+```
+
+Чтобы установить **Docker** и **Docker compose**, стоит ввести такие команды:
+``` bash
+# Настройка репозитория 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
+```
+### Запуск лабораторной работы номер 1
+Для запуска лабораторной работы номер 1 необходимо **склонировать** репозиторий в любую папку и **перейти на ветку** balakhonov_danila_lab_1.
+Далее в папке с `docker-compose.yaml` нужно вызвать такую команду:
+``` bash
+sudo docker-compose up -d
+```
+Таким образом будут запущены контейнеры в фоновом режиме.
+## Какие технологии были использованы?
+Для выполнения лабораторной работы номер 1 использовались такие технологии, как: *git*, *docker*, *docker compose*.
+
+Сервисы, выбранные для запуска в docker-compose файле:
+ - *Gitea* - удобный сервис отслеживания версий разрабатываемого ПО
+ - *MediaWiki* - сервис создания и ведения электронной энциклопедии
+ - *PostgreSQL* - база данных, используемая сервисами выше
+
+Системой, на которую были установлены указанные технологии, является Ubuntu 22.
+## Что делает лабораторная работа номер 1?
+Лабораторная работа номер 1 заключается в написании docker-compose файла для удобного запуска и администрирования сразу нескольких сервисов в docker-контейнерах.
\ No newline at end of file
diff --git a/balakhonov_danila_lab_1/docker-compose.yaml b/balakhonov_danila_lab_1/docker-compose.yaml
new file mode 100644
index 0000000..68f242b
--- /dev/null
+++ b/balakhonov_danila_lab_1/docker-compose.yaml
@@ -0,0 +1,58 @@
+services:
+ # PostgreSQL
+ db:
+ # Образ контейнера PostgreSQL последней версии
+ image: postgres
+ # Название контейнера
+ container_name: db
+ # Переменные окружения для настройки базы данных
+ environment:
+ - POSTGRES_USER=gitea
+ - POSTGRES_PASSWORD=gitea
+ - POSTGRES_DB=gitea
+ # Настройка корневого каталога, где хранятся данные
+ # Слева указан каталог компьютера, справа - каталог контейнера
+ # Нужно для сохранения данных на сервере после отключения контейнера
+ volumes:
+ - ./postgres:/var/lib/postgresql/data
+ # Порт, через который можно будет подключиться к базе данных
+ ports:
+ - 5432:5432
+ # После перезапуска докера всегда запускать этот контейнер
+ restart: always
+ # Gitea
+ gitea:
+ # Используется Gitea последней версии
+ image: gitea/gitea
+ container_name: gitea
+ # После перезапуска докера всегда запускать этот контейнер
+ restart: always
+ volumes:
+ - ./data:/var/lib/gitea
+ - ./config:/etc/gitea
+ - /etc/timezone:/etc/timezone:ro
+ - /etc/localtime:/etc/localtime:ro
+ ports:
+ - 3000:3000
+ - 2222:2222
+ environment:
+ - GITEA__database__DB_TYPE=postgres
+ - GITEA__database__HOST=db:5432
+ - GITEA__database__NAME=gitea
+ - GITEA__database__USER=gitea
+ - GITEA__database__PASSWD=gitea
+ # Указывается, что этот контейнер запускается только после запуска контейнера db
+ depends_on:
+ - db
+ # MediaWiki
+ mediawiki:
+ # Образ контейнера MediaWiki последней версии
+ image: mediawiki
+ container_name: mediawiki
+ restart: always
+ ports:
+ - 8080:80
+ links:
+ - db
+ volumes:
+ - ./images:/var/www/html/images
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/ConsoleApp1/.dockerignore b/dozorova_alena_lab_2/ConsoleApp1/.dockerignore
new file mode 100644
index 0000000..fe1152b
--- /dev/null
+++ b/dozorova_alena_lab_2/ConsoleApp1/.dockerignore
@@ -0,0 +1,30 @@
+**/.classpath
+**/.dockerignore
+**/.env
+**/.git
+**/.gitignore
+**/.project
+**/.settings
+**/.toolstarget
+**/.vs
+**/.vscode
+**/*.*proj.user
+**/*.dbmdl
+**/*.jfm
+**/azds.yaml
+**/bin
+**/charts
+**/docker-compose*
+**/Dockerfile*
+**/node_modules
+**/npm-debug.log
+**/obj
+**/secrets.dev.yaml
+**/values.dev.yaml
+LICENSE
+README.md
+!**/.gitignore
+!.git/HEAD
+!.git/config
+!.git/packed-refs
+!.git/refs/heads/**
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/ConsoleApp1/ConsoleApp1.csproj b/dozorova_alena_lab_2/ConsoleApp1/ConsoleApp1.csproj
new file mode 100644
index 0000000..599ec87
--- /dev/null
+++ b/dozorova_alena_lab_2/ConsoleApp1/ConsoleApp1.csproj
@@ -0,0 +1,13 @@
+
+
+ Exe
+ net6.0
+ enable
+ enable
+ Linux
+ .
+
+
+
+
+
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/ConsoleApp1/ConsoleApp1.csproj.user b/dozorova_alena_lab_2/ConsoleApp1/ConsoleApp1.csproj.user
new file mode 100644
index 0000000..6c031cb
--- /dev/null
+++ b/dozorova_alena_lab_2/ConsoleApp1/ConsoleApp1.csproj.user
@@ -0,0 +1,7 @@
+
+
+
+ Container (Dockerfile)
+ <_LastSelectedProfileId>C:\Users\Alena\WorkFolder\Study\politech\7\РВиП\DAS_2024_1\dozorova_alena_lab_2\ConsoleApp1\Properties\PublishProfiles\registry.hub.docker.com_alenadozorova.pubxml
+
+
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/ConsoleApp1/ConsoleApp1.sln b/dozorova_alena_lab_2/ConsoleApp1/ConsoleApp1.sln
new file mode 100644
index 0000000..12f3d98
--- /dev/null
+++ b/dozorova_alena_lab_2/ConsoleApp1/ConsoleApp1.sln
@@ -0,0 +1,25 @@
+
+Microsoft Visual Studio Solution File, Format Version 12.00
+# Visual Studio Version 17
+VisualStudioVersion = 17.10.35004.147
+MinimumVisualStudioVersion = 10.0.40219.1
+Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "ConsoleApp1", "ConsoleApp1.csproj", "{093B5FCB-33F6-4F14-B150-87DA092D2BFA}"
+EndProject
+Global
+ GlobalSection(SolutionConfigurationPlatforms) = preSolution
+ Debug|Any CPU = Debug|Any CPU
+ Release|Any CPU = Release|Any CPU
+ EndGlobalSection
+ GlobalSection(ProjectConfigurationPlatforms) = postSolution
+ {093B5FCB-33F6-4F14-B150-87DA092D2BFA}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
+ {093B5FCB-33F6-4F14-B150-87DA092D2BFA}.Debug|Any CPU.Build.0 = Debug|Any CPU
+ {093B5FCB-33F6-4F14-B150-87DA092D2BFA}.Release|Any CPU.ActiveCfg = Release|Any CPU
+ {093B5FCB-33F6-4F14-B150-87DA092D2BFA}.Release|Any CPU.Build.0 = Release|Any CPU
+ EndGlobalSection
+ GlobalSection(SolutionProperties) = preSolution
+ HideSolutionNode = FALSE
+ EndGlobalSection
+ GlobalSection(ExtensibilityGlobals) = postSolution
+ SolutionGuid = {CDC30087-C732-4ED0-97FB-E43A9F219F67}
+ EndGlobalSection
+EndGlobal
diff --git a/dozorova_alena_lab_2/ConsoleApp1/Dockerfile b/dozorova_alena_lab_2/ConsoleApp1/Dockerfile
new file mode 100644
index 0000000..6bbf72d
--- /dev/null
+++ b/dozorova_alena_lab_2/ConsoleApp1/Dockerfile
@@ -0,0 +1,22 @@
+#See https://aka.ms/customizecontainer to learn how to customize your debug container and how Visual Studio uses this Dockerfile to build your images for faster debugging.
+
+FROM mcr.microsoft.com/dotnet/runtime:6.0 AS base
+WORKDIR /app
+
+FROM mcr.microsoft.com/dotnet/sdk:6.0 AS build
+ARG BUILD_CONFIGURATION=Release
+WORKDIR /src
+COPY ["ConsoleApp1.csproj", "."]
+RUN dotnet restore "./ConsoleApp1.csproj"
+COPY . .
+WORKDIR "/src/."
+RUN dotnet build "./ConsoleApp1.csproj" -c $BUILD_CONFIGURATION -o /app/build
+
+FROM build AS publish
+ARG BUILD_CONFIGURATION=Release
+RUN dotnet publish "./ConsoleApp1.csproj" -c $BUILD_CONFIGURATION -o /app/publish /p:UseAppHost=false
+
+FROM base AS final
+WORKDIR /app
+COPY --from=publish /app/publish .
+ENTRYPOINT ["dotnet", "ConsoleApp1.dll"]
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/ConsoleApp1/Program.cs b/dozorova_alena_lab_2/ConsoleApp1/Program.cs
new file mode 100644
index 0000000..5440c09
--- /dev/null
+++ b/dozorova_alena_lab_2/ConsoleApp1/Program.cs
@@ -0,0 +1,32 @@
+// Ищет в каталоге /var/data файл с самым коротким названием и перекладывает
+// его в /var/result/data.txt.
+
+Console.WriteLine("Start first service");
+var files = Directory.GetFiles("/var/data/");
+
+if(files == null || files.Length == 0)
+{
+ File.Create("./var/data/data.txt");
+}
+
+string res = files[0];
+
+files.ToList().ForEach(f =>
+{
+ if(res.Length > f.Length)
+ {
+ res = f;
+ }
+});
+
+Console.WriteLine("Find file " + res);
+
+if(!Directory.Exists("/var/result"))
+{
+ Directory.CreateDirectory("/var/result");
+}
+
+File.Copy(res, "/var/result/data.txt");
+
+Console.WriteLine("Copy to /var/result/data.txt");
+
diff --git a/dozorova_alena_lab_2/ConsoleApp1/Properties/launchSettings.json b/dozorova_alena_lab_2/ConsoleApp1/Properties/launchSettings.json
new file mode 100644
index 0000000..1fc0367
--- /dev/null
+++ b/dozorova_alena_lab_2/ConsoleApp1/Properties/launchSettings.json
@@ -0,0 +1,10 @@
+{
+ "profiles": {
+ "ConsoleApp1": {
+ "commandName": "Project"
+ },
+ "Container (Dockerfile)": {
+ "commandName": "Docker"
+ }
+ }
+}
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/ConsoleApp2/.dockerignore b/dozorova_alena_lab_2/ConsoleApp2/.dockerignore
new file mode 100644
index 0000000..fe1152b
--- /dev/null
+++ b/dozorova_alena_lab_2/ConsoleApp2/.dockerignore
@@ -0,0 +1,30 @@
+**/.classpath
+**/.dockerignore
+**/.env
+**/.git
+**/.gitignore
+**/.project
+**/.settings
+**/.toolstarget
+**/.vs
+**/.vscode
+**/*.*proj.user
+**/*.dbmdl
+**/*.jfm
+**/azds.yaml
+**/bin
+**/charts
+**/docker-compose*
+**/Dockerfile*
+**/node_modules
+**/npm-debug.log
+**/obj
+**/secrets.dev.yaml
+**/values.dev.yaml
+LICENSE
+README.md
+!**/.gitignore
+!.git/HEAD
+!.git/config
+!.git/packed-refs
+!.git/refs/heads/**
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/ConsoleApp2/ConsoleApp2.csproj b/dozorova_alena_lab_2/ConsoleApp2/ConsoleApp2.csproj
new file mode 100644
index 0000000..7be2204
--- /dev/null
+++ b/dozorova_alena_lab_2/ConsoleApp2/ConsoleApp2.csproj
@@ -0,0 +1,16 @@
+
+
+
+ Exe
+ net6.0
+ enable
+ enable
+ Linux
+ .
+
+
+
+
+
+
+
diff --git a/dozorova_alena_lab_2/ConsoleApp2/ConsoleApp2.csproj.user b/dozorova_alena_lab_2/ConsoleApp2/ConsoleApp2.csproj.user
new file mode 100644
index 0000000..dd2d54c
--- /dev/null
+++ b/dozorova_alena_lab_2/ConsoleApp2/ConsoleApp2.csproj.user
@@ -0,0 +1,6 @@
+
+
+
+ Container (Dockerfile)
+
+
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/ConsoleApp2/ConsoleApp2.sln b/dozorova_alena_lab_2/ConsoleApp2/ConsoleApp2.sln
new file mode 100644
index 0000000..8337ab4
--- /dev/null
+++ b/dozorova_alena_lab_2/ConsoleApp2/ConsoleApp2.sln
@@ -0,0 +1,25 @@
+
+Microsoft Visual Studio Solution File, Format Version 12.00
+# Visual Studio Version 17
+VisualStudioVersion = 17.10.35004.147
+MinimumVisualStudioVersion = 10.0.40219.1
+Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "ConsoleApp2", "ConsoleApp2.csproj", "{364FF6E2-3AED-4C3A-B2DD-D20CA9214BB8}"
+EndProject
+Global
+ GlobalSection(SolutionConfigurationPlatforms) = preSolution
+ Debug|Any CPU = Debug|Any CPU
+ Release|Any CPU = Release|Any CPU
+ EndGlobalSection
+ GlobalSection(ProjectConfigurationPlatforms) = postSolution
+ {364FF6E2-3AED-4C3A-B2DD-D20CA9214BB8}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
+ {364FF6E2-3AED-4C3A-B2DD-D20CA9214BB8}.Debug|Any CPU.Build.0 = Debug|Any CPU
+ {364FF6E2-3AED-4C3A-B2DD-D20CA9214BB8}.Release|Any CPU.ActiveCfg = Release|Any CPU
+ {364FF6E2-3AED-4C3A-B2DD-D20CA9214BB8}.Release|Any CPU.Build.0 = Release|Any CPU
+ EndGlobalSection
+ GlobalSection(SolutionProperties) = preSolution
+ HideSolutionNode = FALSE
+ EndGlobalSection
+ GlobalSection(ExtensibilityGlobals) = postSolution
+ SolutionGuid = {E5B491A6-064F-48E0-ACBD-E1B4FE3D0898}
+ EndGlobalSection
+EndGlobal
diff --git a/dozorova_alena_lab_2/ConsoleApp2/Dockerfile b/dozorova_alena_lab_2/ConsoleApp2/Dockerfile
new file mode 100644
index 0000000..3d0b78d
--- /dev/null
+++ b/dozorova_alena_lab_2/ConsoleApp2/Dockerfile
@@ -0,0 +1,22 @@
+#See https://aka.ms/customizecontainer to learn how to customize your debug container and how Visual Studio uses this Dockerfile to build your images for faster debugging.
+
+FROM mcr.microsoft.com/dotnet/runtime:6.0 AS base
+WORKDIR /app
+
+FROM mcr.microsoft.com/dotnet/sdk:6.0 AS build
+ARG BUILD_CONFIGURATION=Release
+WORKDIR /src
+COPY ["ConsoleApp2.csproj", "."]
+RUN dotnet restore "./ConsoleApp2.csproj"
+COPY . .
+WORKDIR "/src/."
+RUN dotnet build "./ConsoleApp2.csproj" -c $BUILD_CONFIGURATION -o /app/build
+
+FROM build AS publish
+ARG BUILD_CONFIGURATION=Release
+RUN dotnet publish "./ConsoleApp2.csproj" -c $BUILD_CONFIGURATION -o /app/publish /p:UseAppHost=false
+
+FROM base AS final
+WORKDIR /app
+COPY --from=publish /app/publish .
+ENTRYPOINT ["dotnet", "ConsoleApp2.dll"]
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/ConsoleApp2/Program.cs b/dozorova_alena_lab_2/ConsoleApp2/Program.cs
new file mode 100644
index 0000000..ccbf2e3
--- /dev/null
+++ b/dozorova_alena_lab_2/ConsoleApp2/Program.cs
@@ -0,0 +1,16 @@
+// Ищет набольшее число из файла /var/data/data.txt и сохраняет
+// его вторую степень в /var/result/result.txt.
+Console.WriteLine("Start second service");
+var data = File.ReadAllText("/var/data/data.txt").Split(" ").ToList();
+
+var max = data.Select(x => Int32.TryParse(x, out int value) ? value : 0).Max();
+
+Console.WriteLine("Find max value: "+max);
+if(!Directory.Exists("/var/result/"))
+{
+ Directory.CreateDirectory("/var/result/");
+}
+
+File.WriteAllText("/var/result/result.txt", Math.Pow(max, 2).ToString());
+
+Console.WriteLine("Save to /var/result/result.txt");
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/ConsoleApp2/Properties/launchSettings.json b/dozorova_alena_lab_2/ConsoleApp2/Properties/launchSettings.json
new file mode 100644
index 0000000..7d85e14
--- /dev/null
+++ b/dozorova_alena_lab_2/ConsoleApp2/Properties/launchSettings.json
@@ -0,0 +1,10 @@
+{
+ "profiles": {
+ "ConsoleApp2": {
+ "commandName": "Project"
+ },
+ "Container (Dockerfile)": {
+ "commandName": "Docker"
+ }
+ }
+}
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/FilesInput/First/0.txt b/dozorova_alena_lab_2/FilesInput/First/0.txt
new file mode 100644
index 0000000..85b45be
--- /dev/null
+++ b/dozorova_alena_lab_2/FilesInput/First/0.txt
@@ -0,0 +1 @@
+52 32 22 57 23 30 63 22 27 32 10 0 58 40 83 86 21 87 84 27 44 31 59 35 37 57 21 97 87 7 23 89 27 35 55 9 14 35 59
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/FilesInput/First/1.txt b/dozorova_alena_lab_2/FilesInput/First/1.txt
new file mode 100644
index 0000000..252c02b
--- /dev/null
+++ b/dozorova_alena_lab_2/FilesInput/First/1.txt
@@ -0,0 +1 @@
+93 95 67 2 81 16 46 47 40 43 93 71 16 63 6 86 94 8 55 32 59 28 71 43 39 29 60 23 43 75 67 70 73 50 75 65 10 99 41
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/FilesInput/First/10.txt b/dozorova_alena_lab_2/FilesInput/First/10.txt
new file mode 100644
index 0000000..35d8815
--- /dev/null
+++ b/dozorova_alena_lab_2/FilesInput/First/10.txt
@@ -0,0 +1 @@
+48 88 38 25 7 96 34 30 92 34 97 0 81 41 94 85 4 82 77 23 41 8 78 93 38 12 27 55 97 46 20 52 88 54 35 72 62 28 43
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/FilesInput/First/11.txt b/dozorova_alena_lab_2/FilesInput/First/11.txt
new file mode 100644
index 0000000..2de3f85
--- /dev/null
+++ b/dozorova_alena_lab_2/FilesInput/First/11.txt
@@ -0,0 +1 @@
+14 3 92 80 29 21 88 21 98 41 64 10 73 57 31 27 92 84 53 37 35 27 60 52 54 90 89 4 90 95 26 79 55 31 34 17 26 90 49
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/FilesInput/First/12.txt b/dozorova_alena_lab_2/FilesInput/First/12.txt
new file mode 100644
index 0000000..cb6764e
--- /dev/null
+++ b/dozorova_alena_lab_2/FilesInput/First/12.txt
@@ -0,0 +1 @@
+66 33 75 48 42 37 2 29 34 77 0 11 59 38 61 80 85 29 50 59 14 64 37 91 65 65 3 14 41 19 13 49 42 30 55 69 81 8 39
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/FilesInput/First/13.txt b/dozorova_alena_lab_2/FilesInput/First/13.txt
new file mode 100644
index 0000000..83eea89
--- /dev/null
+++ b/dozorova_alena_lab_2/FilesInput/First/13.txt
@@ -0,0 +1 @@
+57 54 24 59 80 67 13 95 86 96 58 60 32 20 79 56 5 98 27 5 71 92 1 54 47 85 33 87 97 41 49 52 35 86 60 21 64 76 75
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/FilesInput/First/14.txt b/dozorova_alena_lab_2/FilesInput/First/14.txt
new file mode 100644
index 0000000..b69c830
--- /dev/null
+++ b/dozorova_alena_lab_2/FilesInput/First/14.txt
@@ -0,0 +1 @@
+75 57 65 15 61 79 94 34 49 33 25 58 91 55 91 81 64 50 25 46 87 44 28 65 15 68 94 56 58 2 40 39 14 29 35 24 9 48 65
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/FilesInput/First/15.txt b/dozorova_alena_lab_2/FilesInput/First/15.txt
new file mode 100644
index 0000000..4293908
--- /dev/null
+++ b/dozorova_alena_lab_2/FilesInput/First/15.txt
@@ -0,0 +1 @@
+91 31 90 98 76 35 61 95 67 78 23 91 26 33 2 44 93 20 90 14 33 22 19 35 57 65 81 62 91 84 69 74 55 34 63 98 64 4 77
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/FilesInput/First/16.txt b/dozorova_alena_lab_2/FilesInput/First/16.txt
new file mode 100644
index 0000000..bcfad3f
--- /dev/null
+++ b/dozorova_alena_lab_2/FilesInput/First/16.txt
@@ -0,0 +1 @@
+41 11 46 24 85 69 93 45 33 33 97 31 91 75 43 60 32 3 76 58 70 66 97 7 75 14 62 1 32 17 54 79 3 59 67 15 43 92 43
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/FilesInput/First/17.txt b/dozorova_alena_lab_2/FilesInput/First/17.txt
new file mode 100644
index 0000000..899f58f
--- /dev/null
+++ b/dozorova_alena_lab_2/FilesInput/First/17.txt
@@ -0,0 +1 @@
+36 88 91 3 42 4 87 65 42 10 95 54 71 79 60 9 5 63 87 27 75 79 67 45 89 32 65 38 64 22 73 78 48 57 89 28 81 58 18
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/FilesInput/First/18.txt b/dozorova_alena_lab_2/FilesInput/First/18.txt
new file mode 100644
index 0000000..599a026
--- /dev/null
+++ b/dozorova_alena_lab_2/FilesInput/First/18.txt
@@ -0,0 +1 @@
+39 86 99 32 34 57 95 27 73 90 80 62 85 91 50 24 54 36 15 87 6 54 63 63 78 10 18 90 9 20 14 57 54 4 97 22 80 50 24
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/FilesInput/First/19.txt b/dozorova_alena_lab_2/FilesInput/First/19.txt
new file mode 100644
index 0000000..c5a78c4
--- /dev/null
+++ b/dozorova_alena_lab_2/FilesInput/First/19.txt
@@ -0,0 +1 @@
+32 65 91 95 28 84 23 47 63 3 78 70 48 15 17 58 22 20 67 58 27 24 68 97 3 55 57 9 18 85 14 16 23 10 1 97 24 64 83
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/FilesInput/First/2.txt b/dozorova_alena_lab_2/FilesInput/First/2.txt
new file mode 100644
index 0000000..a933198
--- /dev/null
+++ b/dozorova_alena_lab_2/FilesInput/First/2.txt
@@ -0,0 +1 @@
+50 60 55 6 46 82 92 76 47 53 94 93 58 71 54 68 83 56 32 39 96 9 31 93 30 72 88 15 1 45 5 98 64 83 45 60 73 69 74
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/FilesInput/First/20.txt b/dozorova_alena_lab_2/FilesInput/First/20.txt
new file mode 100644
index 0000000..b6d09fa
--- /dev/null
+++ b/dozorova_alena_lab_2/FilesInput/First/20.txt
@@ -0,0 +1 @@
+26 79 84 64 17 53 9 84 52 98 27 42 8 11 83 67 66 57 81 80 47 95 53 98 66 88 60 0 93 98 43 87 47 17 48 49 28 35 28
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/FilesInput/First/21.txt b/dozorova_alena_lab_2/FilesInput/First/21.txt
new file mode 100644
index 0000000..3cec464
--- /dev/null
+++ b/dozorova_alena_lab_2/FilesInput/First/21.txt
@@ -0,0 +1 @@
+60 70 16 18 71 67 22 71 54 55 70 57 13 54 84 73 99 27 53 13 49 68 12 89 96 77 93 52 80 62 59 11 73 9 33 40 49 82 1
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/FilesInput/First/22.txt b/dozorova_alena_lab_2/FilesInput/First/22.txt
new file mode 100644
index 0000000..3ce9290
--- /dev/null
+++ b/dozorova_alena_lab_2/FilesInput/First/22.txt
@@ -0,0 +1 @@
+67 22 18 71 64 80 19 5 28 2 75 73 9 51 8 81 76 36 96 26 58 96 95 4 88 51 24 10 71 33 79 63 21 59 95 61 28 97 40
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/FilesInput/First/23.txt b/dozorova_alena_lab_2/FilesInput/First/23.txt
new file mode 100644
index 0000000..279a9fd
--- /dev/null
+++ b/dozorova_alena_lab_2/FilesInput/First/23.txt
@@ -0,0 +1 @@
+62 36 50 68 46 3 28 7 16 30 26 1 21 39 27 78 13 92 34 6 6 38 70 1 1 42 45 20 98 49 61 24 51 45 56 33 53 3 75
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/FilesInput/First/24.txt b/dozorova_alena_lab_2/FilesInput/First/24.txt
new file mode 100644
index 0000000..c6b785a
--- /dev/null
+++ b/dozorova_alena_lab_2/FilesInput/First/24.txt
@@ -0,0 +1 @@
+81 40 95 8 98 87 88 60 51 87 38 42 13 99 75 24 98 90 33 71 99 41 95 68 39 52 9 64 77 61 70 17 90 91 64 53 41 13 5
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/FilesInput/First/25.txt b/dozorova_alena_lab_2/FilesInput/First/25.txt
new file mode 100644
index 0000000..574d4ec
--- /dev/null
+++ b/dozorova_alena_lab_2/FilesInput/First/25.txt
@@ -0,0 +1 @@
+79 25 4 32 1 51 91 16 26 23 87 8 98 25 23 86 23 94 24 35 34 84 54 79 46 18 40 48 90 9 98 80 37 20 80 79 4 13 57
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/FilesInput/First/26.txt b/dozorova_alena_lab_2/FilesInput/First/26.txt
new file mode 100644
index 0000000..8caa6bf
--- /dev/null
+++ b/dozorova_alena_lab_2/FilesInput/First/26.txt
@@ -0,0 +1 @@
+66 95 69 29 36 5 17 70 97 10 6 72 92 87 72 90 68 94 77 49 23 68 73 74 77 49 94 75 40 52 57 70 80 77 67 34 67 65 61
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/FilesInput/First/27.txt b/dozorova_alena_lab_2/FilesInput/First/27.txt
new file mode 100644
index 0000000..8e91577
--- /dev/null
+++ b/dozorova_alena_lab_2/FilesInput/First/27.txt
@@ -0,0 +1 @@
+21 5 57 27 17 89 4 91 80 49 55 57 92 9 61 37 92 33 28 18 27 45 88 7 61 26 22 64 24 17 63 70 75 1 69 96 62 77 47
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/FilesInput/First/28.txt b/dozorova_alena_lab_2/FilesInput/First/28.txt
new file mode 100644
index 0000000..67c6f55
--- /dev/null
+++ b/dozorova_alena_lab_2/FilesInput/First/28.txt
@@ -0,0 +1 @@
+28 63 7 24 14 25 49 42 34 18 14 1 59 60 47 21 75 54 29 11 89 46 90 69 61 37 18 75 55 43 43 16 80 93 55 27 67 50 11
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/FilesInput/First/29.txt b/dozorova_alena_lab_2/FilesInput/First/29.txt
new file mode 100644
index 0000000..a288228
--- /dev/null
+++ b/dozorova_alena_lab_2/FilesInput/First/29.txt
@@ -0,0 +1 @@
+35 9 60 57 42 99 29 73 61 44 21 75 18 96 67 9 81 37 39 54 83 33 62 62 17 30 11 7 30 10 37 1 36 75 92 40 77 37 69
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/FilesInput/First/3.txt b/dozorova_alena_lab_2/FilesInput/First/3.txt
new file mode 100644
index 0000000..55fb352
--- /dev/null
+++ b/dozorova_alena_lab_2/FilesInput/First/3.txt
@@ -0,0 +1 @@
+10 26 86 88 31 39 62 76 84 21 83 62 10 0 70 87 46 67 31 19 40 17 68 18 57 87 63 58 21 90 31 74 30 76 4 25 47 77 88
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/FilesInput/First/30.txt b/dozorova_alena_lab_2/FilesInput/First/30.txt
new file mode 100644
index 0000000..4c0df26
--- /dev/null
+++ b/dozorova_alena_lab_2/FilesInput/First/30.txt
@@ -0,0 +1 @@
+2 39 85 29 46 99 69 64 89 20 5 72 23 47 57 14 64 9 62 22 15 48 93 51 14 28 97 18 60 48 44 9 70 22 25 69 53 86 67
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/FilesInput/First/31.txt b/dozorova_alena_lab_2/FilesInput/First/31.txt
new file mode 100644
index 0000000..1cdff86
--- /dev/null
+++ b/dozorova_alena_lab_2/FilesInput/First/31.txt
@@ -0,0 +1 @@
+21 39 28 1 2 38 90 22 23 47 88 51 84 55 44 20 74 48 66 82 9 37 39 5 30 24 53 33 25 1 83 69 61 80 68 30 55 49 61
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/FilesInput/First/32.txt b/dozorova_alena_lab_2/FilesInput/First/32.txt
new file mode 100644
index 0000000..b77936c
--- /dev/null
+++ b/dozorova_alena_lab_2/FilesInput/First/32.txt
@@ -0,0 +1 @@
+77 3 9 39 23 95 77 44 53 18 33 10 85 90 84 47 55 48 69 91 44 93 70 1 30 12 64 98 15 57 43 18 69 61 8 17 77 16 95
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/FilesInput/First/33.txt b/dozorova_alena_lab_2/FilesInput/First/33.txt
new file mode 100644
index 0000000..fd1dc3e
--- /dev/null
+++ b/dozorova_alena_lab_2/FilesInput/First/33.txt
@@ -0,0 +1 @@
+13 6 29 65 44 37 43 75 20 61 35 9 39 20 28 58 58 55 11 16 18 65 62 41 36 96 63 75 61 5 13 75 9 84 1 59 73 87 10
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/FilesInput/First/34.txt b/dozorova_alena_lab_2/FilesInput/First/34.txt
new file mode 100644
index 0000000..a1efda9
--- /dev/null
+++ b/dozorova_alena_lab_2/FilesInput/First/34.txt
@@ -0,0 +1 @@
+57 35 36 64 48 37 9 72 89 61 83 89 29 6 13 25 11 41 33 21 68 58 74 63 54 48 16 49 53 1 70 93 3 87 9 34 69 77 95
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/FilesInput/First/35.txt b/dozorova_alena_lab_2/FilesInput/First/35.txt
new file mode 100644
index 0000000..cbafe7e
--- /dev/null
+++ b/dozorova_alena_lab_2/FilesInput/First/35.txt
@@ -0,0 +1 @@
+34 62 93 45 30 62 34 1 60 29 15 69 96 74 2 24 98 13 95 65 0 36 64 37 60 56 54 55 7 49 10 21 16 86 63 49 96 11 26
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/FilesInput/First/36.txt b/dozorova_alena_lab_2/FilesInput/First/36.txt
new file mode 100644
index 0000000..1d2c8bd
--- /dev/null
+++ b/dozorova_alena_lab_2/FilesInput/First/36.txt
@@ -0,0 +1 @@
+29 15 87 70 80 67 79 64 7 52 29 91 5 88 52 77 83 56 74 34 27 27 25 22 95 91 56 10 21 84 82 54 92 94 98 23 56 65 43
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/FilesInput/First/37.txt b/dozorova_alena_lab_2/FilesInput/First/37.txt
new file mode 100644
index 0000000..6c47d53
--- /dev/null
+++ b/dozorova_alena_lab_2/FilesInput/First/37.txt
@@ -0,0 +1 @@
+87 41 82 29 38 22 89 69 3 92 55 73 0 30 70 20 71 96 98 38 60 26 62 21 34 0 10 99 71 31 83 40 56 25 40 16 21 48 17
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/FilesInput/First/38.txt b/dozorova_alena_lab_2/FilesInput/First/38.txt
new file mode 100644
index 0000000..f9a19a7
--- /dev/null
+++ b/dozorova_alena_lab_2/FilesInput/First/38.txt
@@ -0,0 +1 @@
+69 78 36 30 6 95 39 12 30 63 57 84 83 8 25 50 64 96 84 1 99 85 67 48 72 93 93 90 99 74 58 39 15 66 3 11 72 87 70
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/FilesInput/First/4.txt b/dozorova_alena_lab_2/FilesInput/First/4.txt
new file mode 100644
index 0000000..d21d0e5
--- /dev/null
+++ b/dozorova_alena_lab_2/FilesInput/First/4.txt
@@ -0,0 +1 @@
+88 14 19 72 87 34 86 83 13 68 37 54 93 97 67 68 3 8 37 24 22 52 98 83 64 88 0 89 46 7 78 78 26 45 14 10 91 45 35
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/FilesInput/First/5.txt b/dozorova_alena_lab_2/FilesInput/First/5.txt
new file mode 100644
index 0000000..d099947
--- /dev/null
+++ b/dozorova_alena_lab_2/FilesInput/First/5.txt
@@ -0,0 +1 @@
+46 1 4 50 36 86 56 84 17 54 89 38 36 25 4 93 48 97 63 99 34 42 0 9 16 88 82 10 98 57 0 37 41 33 32 27 61 43 3
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/FilesInput/First/6.txt b/dozorova_alena_lab_2/FilesInput/First/6.txt
new file mode 100644
index 0000000..87d0082
--- /dev/null
+++ b/dozorova_alena_lab_2/FilesInput/First/6.txt
@@ -0,0 +1 @@
+32 0 85 46 21 63 83 28 15 57 69 68 65 72 86 9 56 3 11 33 62 50 85 20 37 92 61 66 60 78 68 66 84 9 6 77 32 19 36
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/FilesInput/First/7.txt b/dozorova_alena_lab_2/FilesInput/First/7.txt
new file mode 100644
index 0000000..a69e9f4
--- /dev/null
+++ b/dozorova_alena_lab_2/FilesInput/First/7.txt
@@ -0,0 +1 @@
+59 49 82 65 53 10 15 58 87 83 57 14 54 34 52 98 97 2 11 1 68 7 15 69 57 67 83 7 26 6 38 31 1 60 38 88 72 33 41
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/FilesInput/First/8.txt b/dozorova_alena_lab_2/FilesInput/First/8.txt
new file mode 100644
index 0000000..b42b4f3
--- /dev/null
+++ b/dozorova_alena_lab_2/FilesInput/First/8.txt
@@ -0,0 +1 @@
+76 27 40 19 12 76 83 72 55 53 80 20 94 17 20 8 77 52 87 40 20 36 81 92 56 31 31 33 51 18 28 10 44 88 63 41 15 53 64
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/FilesInput/First/9.txt b/dozorova_alena_lab_2/FilesInput/First/9.txt
new file mode 100644
index 0000000..cbc48b0
--- /dev/null
+++ b/dozorova_alena_lab_2/FilesInput/First/9.txt
@@ -0,0 +1 @@
+11 56 97 86 0 43 38 49 0 91 1 94 58 27 82 9 25 7 28 41 37 97 44 97 87 96 74 9 10 89 91 51 94 32 77 34 15 12 0
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/FilesInput/Second/data.txt b/dozorova_alena_lab_2/FilesInput/Second/data.txt
new file mode 100644
index 0000000..85b45be
--- /dev/null
+++ b/dozorova_alena_lab_2/FilesInput/Second/data.txt
@@ -0,0 +1 @@
+52 32 22 57 23 30 63 22 27 32 10 0 58 40 83 86 21 87 84 27 44 31 59 35 37 57 21 97 87 7 23 89 27 35 55 9 14 35 59
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/FilesOutput/result.txt b/dozorova_alena_lab_2/FilesOutput/result.txt
new file mode 100644
index 0000000..5a0a33a
--- /dev/null
+++ b/dozorova_alena_lab_2/FilesOutput/result.txt
@@ -0,0 +1 @@
+9409
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/docker-compose.yml b/dozorova_alena_lab_2/docker-compose.yml
new file mode 100644
index 0000000..4e6538b
--- /dev/null
+++ b/dozorova_alena_lab_2/docker-compose.yml
@@ -0,0 +1,14 @@
+services:
+ first:
+ build: ./ConsoleApp1/
+ volumes:
+ - ./FilesInput/First:/var/data
+ - ./FilesInput/Second:/var/result
+
+ second:
+ build: ./ConsoleApp2/
+ depends_on:
+ - first
+ volumes:
+ - ./FilesInput/Second:/var/data
+ - ./FilesOutput:/var/result
\ No newline at end of file
diff --git a/dozorova_alena_lab_2/readme.md b/dozorova_alena_lab_2/readme.md
new file mode 100644
index 0000000..736c1cc
--- /dev/null
+++ b/dozorova_alena_lab_2/readme.md
@@ -0,0 +1,70 @@
+# Лабораторная работа 2
+В рамках лабораторной работы были реализованы два сервиса, для которых выходные данные первого являются входными данными второго.
+## Описание
+Варианты:
+Первый сервис - 5
+Второй сервис - 1
+Оба сервиса являются консольным приложением с сгенерированным dockerfile
+В результате были проброшены папки следующим образом:
+для первого сервиса :
+```
+ volumes:
+ - ./FilesInput/First:/var/data
+ - ./FilesInput/Second:/var/result
+```
+для второго сервиса:
+```
+ volumes:
+ - ./FilesInput/Second:/var/data
+ - ./FilesOutput:/var/result
+```
+## Запуск
+Для запуска лабораторной работы необходимо иметь запущенный Docker.
+Из папки, где находится файл docker-compose.yml запустить консоль и выполнить:
+```
+docker compose up --build
+```
+Флаг `--build` указывает на то, что необходимо выполнить сборку исходников.
+После сборки мы получим следующие логи:
+[+] Running 3/2
+ ✔ Network dozorova_alena_lab_2_default Created 0.2s
+ ✔ Container dozorova_alena_lab_2-first-1 Created 0.1s
+ ✔ Container dozorova_alena_lab_2-second-1 Created 0.0s
+Attaching to first-1, second-1
+first-1 | Start first service
+first-1 | Find file /var/data/0.txt
+first-1 | Copy to /var/result/data.txt
+first-1 exited with code 0
+second-1 | Start second service
+second-1 | Find max value: 97
+second-1 | Save to /var/result/result.txt
+second-1 exited with code 0
+## Пример dockerfile
+```
+FROM mcr.microsoft.com/dotnet/runtime:6.0 AS base #базовый образ сборки
+WORKDIR /app
+
+FROM mcr.microsoft.com/dotnet/sdk:6.0 AS build #используем sdk для сборки
+ARG BUILD_CONFIGURATION=Release #сборку проводим в релизной конфигурации
+WORKDIR /src
+COPY ["ConsoleApp2.csproj", "."] #копируем в контейнер
+RUN dotnet restore "./ConsoleApp2.csproj" #восстанавливаем зависимости
+COPY . . #копируем в папку сборки
+WORKDIR "/src/."
+RUN dotnet build "./ConsoleApp2.csproj" -c $BUILD_CONFIGURATION -o /app/build #собираем проект
+
+FROM build AS publish #все, что создалось в папке publish
+ARG BUILD_CONFIGURATION=Release
+RUN dotnet publish "./ConsoleApp2.csproj" -c $BUILD_CONFIGURATION -o /app/publish /p:UseAppHost=false #публикуем в /app/publish
+
+FROM base AS final #берем базовый образ
+WORKDIR /app #указываем рабочую папку
+COPY --from=publish /app/publish . #опубликованное копируем в app
+ENTRYPOINT ["dotnet", "ConsoleApp2.dll"] #указываем команду запуска приложения
+```
+
+## Особенности compose файла
+Директива`depends_on` позволяет указать, какого сервиса мы дожидаемся, прежде чем запустимся.
+Директива `build` позволяет использовать не уже готовый образ, а тот, что будет собран непосредственно в момент запуска.
+## Видеодемонстрация
+Был записан видеоролик, демонстрирующий процесс запуска и работы сервисов. Он расположен по [адресу](https://drive.google.com/file/d/1BOt_Ja9AanINPjJyRKzgUaghRGwJYdd7/view?usp=drive_link)
\ No newline at end of file
diff --git a/emelyanov_artem_lab_2/README.md b/emelyanov_artem_lab_2/README.md
new file mode 100644
index 0000000..5978d5d
--- /dev/null
+++ b/emelyanov_artem_lab_2/README.md
@@ -0,0 +1,23 @@
+# Распределённое приложение для поиска файлов и обработки чисел
+## Описаниe
+Данное распределённое приложение состоит из двух консольных Java-приложений, которые работают в контейнерах Docker. Приложения выполняют следующие задачи:
+
+### file-finder:
+Ищет самый большой файл в директории /var/data и копирует его в /var/result/data.txt.
+### number-processor:
+Считывает числа из файла /var/result/data.txt и сохраняет произведение первого и последнего числа в файл /var/result/result.txt.
+
+#### Приложения работают совместно через Docker Compose, используя общий том для передачи файлов между контейнерами.
+
+### Как запустить
+1. #### Подготовка данных
+ Убедитесь, что в директории data находятся файлы, которые вы хотите обработать. Это могут быть текстовые файлы с числами.
+
+2. #### Сборка и запуск контейнеров
+ Выполните команду для сборки и запуска контейнеров с помощью Docker Compose: docker-compose up --build
+
+3. #### Результаты выполнения
+ #### Приложение file-finder находит самый большой файл в директории /var/data (локально это монтируемая директория data/) и копирует его в файл /var/result/data.txt.
+ #### Приложение number-processor читает файл /var/result/data.txt и сохраняет произведение первого и последнего числа в файл /var/result/result.txt.
+
+#### Ссылка на видео https://drive.google.com/file/d/1u7nwZdUI4KHC4NzUAXdOABflYswokGwx/view
\ No newline at end of file
diff --git a/emelyanov_artem_lab_2/app_1/.gitignore b/emelyanov_artem_lab_2/app_1/.gitignore
new file mode 100644
index 0000000..4291186
--- /dev/null
+++ b/emelyanov_artem_lab_2/app_1/.gitignore
@@ -0,0 +1,31 @@
+### IntelliJ IDEA ###
+out/
+!**/src/main/**/out/
+!**/src/test/**/out/
+
+### Eclipse ###
+.apt_generated
+.classpath
+.factorypath
+.project
+.settings
+.springBeans
+.sts4-cache
+bin/
+!**/src/main/**/bin/
+!**/src/test/**/bin/
+
+### NetBeans ###
+/nbproject/private/
+/nbbuild/
+/dist/
+/nbdist/
+/.nb-gradle/
+
+### VS Code ###
+.vscode/
+
+### Mac OS ###
+.DS_Store
+/.idea/modules.xml
+/.idea/vcs.xml
diff --git a/emelyanov_artem_lab_2/app_1/.idea/.gitignore b/emelyanov_artem_lab_2/app_1/.idea/.gitignore
new file mode 100644
index 0000000..13566b8
--- /dev/null
+++ b/emelyanov_artem_lab_2/app_1/.idea/.gitignore
@@ -0,0 +1,8 @@
+# Default ignored files
+/shelf/
+/workspace.xml
+# Editor-based HTTP Client requests
+/httpRequests/
+# Datasource local storage ignored files
+/dataSources/
+/dataSources.local.xml
diff --git a/emelyanov_artem_lab_2/app_1/Dockerfile b/emelyanov_artem_lab_2/app_1/Dockerfile
new file mode 100644
index 0000000..3e87ad7
--- /dev/null
+++ b/emelyanov_artem_lab_2/app_1/Dockerfile
@@ -0,0 +1,17 @@
+# Используем базовый образ с установленной JDK
+FROM openjdk:17-jdk-slim
+
+# Создаем директорию для исходных файлов
+RUN mkdir /var/data
+
+# Создаем директорию для приложения
+WORKDIR /app
+
+#Копируем исходные файлы приложения внутрь контейнера
+COPY src /app/src
+
+#Компилируем код
+RUN javac /app/src/Main.java
+
+# Определяем команду для запуска приложения
+CMD ["java", "-cp", "/app/src", "Main"]
\ No newline at end of file
diff --git a/emelyanov_artem_lab_2/app_1/src/Main.java b/emelyanov_artem_lab_2/app_1/src/Main.java
new file mode 100644
index 0000000..e071e91
--- /dev/null
+++ b/emelyanov_artem_lab_2/app_1/src/Main.java
@@ -0,0 +1,64 @@
+import java.io.File;
+import java.io.IOException;
+import java.nio.file.Files;
+import java.nio.file.StandardCopyOption;
+
+public class Main {
+
+ public static void main(String[] args) {
+
+ /*
+ Ищет в каталоге /var/data самый большой по объёму файл и перекладывает его в /var/result/data.txt.
+ */
+
+ File sourceDir = new File("/var/data");
+ File targetFile = new File("/var/result/data.txt");
+
+ // Проверяем, что sourceDir существует и является директорией
+ if (!sourceDir.exists() || !sourceDir.isDirectory()) {
+ System.out.println("Каталог " + sourceDir + " не существует или не является директорией.");
+ return;
+ }
+
+ File[] files = sourceDir.listFiles();
+ if (files == null || files.length == 0) {
+ System.out.println("Каталог " + sourceDir + " пуст.");
+ return;
+ }
+
+ long maxFileSize = -1L;
+ File maxFile = null;
+
+ // Находим файл с максимальным размером
+ for (File item : files) {
+ if (item.isFile() && item.length() > maxFileSize) {
+ maxFileSize = item.length();
+ maxFile = item;
+ }
+ }
+
+ if (maxFile != null) {
+ // Проверяем, существует ли конечная директория, если нет — создаем её
+ File targetDir = targetFile.getParentFile();
+ if (!targetDir.exists()) {
+ boolean dirCreated = targetDir.mkdirs();
+ if (dirCreated) {
+ System.out.println("Директория " + targetDir + " была успешно создана.");
+ } else {
+ System.out.println("Не удалось создать директорию " + targetDir);
+ return;
+ }
+ }
+
+ try {
+ // Копируем файл
+ Files.copy(maxFile.toPath(), targetFile.toPath(), StandardCopyOption.REPLACE_EXISTING);
+ System.out.println("Самый большой файл: " + maxFile.getName() + " был скопирован в /var/result/data.txt");
+ } catch (IOException e) {
+ System.out.println("Ошибка копирования файла: " + e.getMessage());
+ }
+ } else {
+ System.out.println("Файлы для копирования не найдены.");
+ }
+ }
+}
\ No newline at end of file
diff --git a/emelyanov_artem_lab_2/app_2/.gitignore b/emelyanov_artem_lab_2/app_2/.gitignore
new file mode 100644
index 0000000..1c5e2ec
--- /dev/null
+++ b/emelyanov_artem_lab_2/app_2/.gitignore
@@ -0,0 +1,30 @@
+### IntelliJ IDEA ###
+out/
+!**/src/main/**/out/
+!**/src/test/**/out/
+
+### Eclipse ###
+.apt_generated
+.classpath
+.factorypath
+.project
+.settings
+.springBeans
+.sts4-cache
+bin/
+!**/src/main/**/bin/
+!**/src/test/**/bin/
+
+### NetBeans ###
+/nbproject/private/
+/nbbuild/
+/dist/
+/nbdist/
+/.nb-gradle/
+
+### VS Code ###
+.vscode/
+
+### Mac OS ###
+.DS_Store
+/.idea/misc.xml
diff --git a/emelyanov_artem_lab_2/app_2/.idea/.gitignore b/emelyanov_artem_lab_2/app_2/.idea/.gitignore
new file mode 100644
index 0000000..7c5452a
--- /dev/null
+++ b/emelyanov_artem_lab_2/app_2/.idea/.gitignore
@@ -0,0 +1,10 @@
+# Default ignored files
+/shelf/
+/workspace.xml
+# Editor-based HTTP Client requests
+/httpRequests/
+# Datasource local storage ignored files
+/dataSources/
+/dataSources.local.xml
+/modules.xml
+/vcs.xml
diff --git a/emelyanov_artem_lab_2/app_2/Dockerfile b/emelyanov_artem_lab_2/app_2/Dockerfile
new file mode 100644
index 0000000..69b918c
--- /dev/null
+++ b/emelyanov_artem_lab_2/app_2/Dockerfile
@@ -0,0 +1,17 @@
+# Используем базовый образ с установленной JDK
+FROM openjdk:17-jdk-slim
+
+# Создаем директорию для исходных файлов
+RUN mkdir /var/data
+
+# Создаем директорию для приложения
+WORKDIR /app
+
+#Копируем исходные файлы приложения внутрь контейнера
+COPY src /app/src
+
+#Компилируем код
+RUN javac /app/src/Main.java
+
+# Определяем команду для запуска приложения
+CMD ["java", "-cp", "/app/src", "Main"]
diff --git a/emelyanov_artem_lab_2/app_2/src/Main.java b/emelyanov_artem_lab_2/app_2/src/Main.java
new file mode 100644
index 0000000..2d7b837
--- /dev/null
+++ b/emelyanov_artem_lab_2/app_2/src/Main.java
@@ -0,0 +1,46 @@
+import java.io.File;
+import java.io.FileNotFoundException;
+import java.io.PrintWriter;
+import java.util.Scanner;
+
+public class Main {
+
+ // Сохраняет произведение первого и последнего числа из файла /var/result/data.txt в /var/result/result.txt.
+ public static void main(String[] args) {
+
+ File sourceFile = new File("/var/result/data.txt");
+ File targetFile = new File("/var/result/result.txt");
+
+ int firstNumber = 0;
+ int lastNumber = 0;
+ boolean isFirstNumber = true;
+
+ try (Scanner scanner = new Scanner(sourceFile)) {
+ // Считываем числа
+ while (scanner.hasNextInt()) {
+ int currentNumber = scanner.nextInt();
+
+ if (isFirstNumber) {
+ firstNumber = currentNumber; // Сохраняем первое число
+ isFirstNumber = false;
+ }
+
+ lastNumber = currentNumber; // Последнее число обновляется на каждом шаге
+ }
+ } catch (FileNotFoundException ex) {
+ System.out.println("Файл не найден: " + ex.getMessage());
+ return; // Выходим, если файл не найден
+ }
+
+ // Рассчитываем произведение первого и последнего числа
+ int result = firstNumber * lastNumber;
+
+ // Сохраняем результат в файл
+ try (PrintWriter writer = new PrintWriter(targetFile)) {
+ writer.println(result);
+ System.out.println("Произведение первого и последнего числа: " + result);
+ } catch (FileNotFoundException ex) {
+ System.out.println("Ошибка записи в файл: " + ex.getMessage());
+ }
+ }
+}
diff --git a/emelyanov_artem_lab_2/data/1.txt b/emelyanov_artem_lab_2/data/1.txt
new file mode 100644
index 0000000..2988c8b
--- /dev/null
+++ b/emelyanov_artem_lab_2/data/1.txt
@@ -0,0 +1,10 @@
+2
+32
+1
+2
+3
+54
+64
+4
+3
+3
\ No newline at end of file
diff --git a/emelyanov_artem_lab_2/data/2.txt b/emelyanov_artem_lab_2/data/2.txt
new file mode 100644
index 0000000..4eb4b6f
--- /dev/null
+++ b/emelyanov_artem_lab_2/data/2.txt
@@ -0,0 +1,12 @@
+12
+4
+12
+3
+21
+3
+12
+1
+3
+32
+2
+5
\ No newline at end of file
diff --git a/emelyanov_artem_lab_2/data/3.txt b/emelyanov_artem_lab_2/data/3.txt
new file mode 100644
index 0000000..36ee730
--- /dev/null
+++ b/emelyanov_artem_lab_2/data/3.txt
@@ -0,0 +1,9 @@
+12
+2
+1
+2
+4
+3
+1
+2
+3
\ No newline at end of file
diff --git a/emelyanov_artem_lab_2/docker-compose.yml b/emelyanov_artem_lab_2/docker-compose.yml
new file mode 100644
index 0000000..0ed51ed
--- /dev/null
+++ b/emelyanov_artem_lab_2/docker-compose.yml
@@ -0,0 +1,21 @@
+version: '3'
+services:
+ file-finder:
+ build:
+ context: ./app_1 # Путь к первому приложению
+ dockerfile: Dockerfile
+ volumes:
+ - C:/Users/Admin/Desktop/УлГТУ/Распределенные вычисления и приложения/DAS_2024_1/emelyanov_artem_lab_2/data:/var/data # Монтируем директорию с файлами
+ - shared-result:/var/result
+
+ number-processor:
+ build:
+ context: ./app_2 # Путь ко второму приложению
+ dockerfile: Dockerfile
+ depends_on:
+ - file-finder
+ volumes:
+ - shared-result:/var/result
+
+volumes:
+ shared-result: # Объявляем общий том
diff --git a/mochalov_danila_lab_1/LocalSettings.php b/mochalov_danila_lab_1/LocalSettings.php
new file mode 100644
index 0000000..9644427
--- /dev/null
+++ b/mochalov_danila_lab_1/LocalSettings.php
@@ -0,0 +1,140 @@
+ "$wgResourceBasePath/resources/assets/change-your-logo.svg",
+ 'icon' => "$wgResourceBasePath/resources/assets/change-your-logo-icon.svg",
+];
+
+## UPO means: this is also a user preference option
+
+$wgEnableEmail = true;
+$wgEnableUserEmail = true; # UPO
+
+$wgEmergencyContact = '';
+$wgPasswordSender = '';
+
+$wgEnotifUserTalk = false; # UPO
+$wgEnotifWatchlist = false; # UPO
+$wgEmailAuthentication = true;
+
+## Database settings
+$wgDBtype = 'mysql';
+$wgDBserver = 'mariadb';
+$wgDBname = 'my_wiki';
+$wgDBuser = 'wikiuser';
+$wgDBpassword = 'password';
+
+# MySQL specific settings
+$wgDBprefix = "";
+$wgDBssl = false;
+
+# MySQL table options to use during installation or update
+$wgDBTableOptions = "ENGINE=InnoDB, DEFAULT CHARSET=binary";
+
+# Shared database table
+# This has no effect unless $wgSharedDB is also set.
+$wgSharedTables[] = "actor";
+
+## Shared memory settings
+$wgMainCacheType = CACHE_NONE;
+$wgMemCachedServers = [];
+
+## To enable image uploads, make sure the 'images' directory
+## is writable, then set this to true:
+$wgEnableUploads = false;
+$wgUseImageMagick = true;
+$wgImageMagickConvertCommand = '/usr/bin/convert';
+
+# InstantCommons allows wiki to use images from https://commons.wikimedia.org
+$wgUseInstantCommons = false;
+
+# Periodically send a pingback to https://www.mediawiki.org/ with basic data
+# about this MediaWiki instance. The Wikimedia Foundation shares this data
+# with MediaWiki developers to help guide future development efforts.
+$wgPingback = false;
+
+# Site language code, should be one of the list in ./includes/languages/data/Names.php
+$wgLanguageCode = 'ru';
+
+# Time zone
+$wgLocaltimezone = 'UTC';
+
+## Set $wgCacheDirectory to a writable directory on the web server
+## to make your wiki go slightly faster. The directory should not
+## be publicly accessible from the web.
+#$wgCacheDirectory = "$IP/cache";
+
+$wgSecretKey = '35e36bd38120ddaa8ba6e353d81951b7b85c7be00e0ee915c4bb4bfa44477368';
+
+# Changing this will log out all existing sessions.
+$wgAuthenticationTokenVersion = '1';
+
+# Site upgrade key. Must be set to a string (default provided) to turn on the
+# web installer while LocalSettings.php is in place
+$wgUpgradeKey = '698fd18eabeec460';
+
+## For attaching licensing metadata to pages, and displaying an
+## appropriate copyright notice / icon. GNU Free Documentation
+## License and Creative Commons licenses are supported so far.
+$wgRightsPage = ""; # Set to the title of a wiki page that describes your license/copyright
+$wgRightsUrl = '';
+$wgRightsText = '';
+$wgRightsIcon = "";
+
+# Path to the GNU diff3 utility. Used for conflict resolution.
+$wgDiff3 = '/usr/bin/diff3';
+
+## Default skin: you can change the default skin. Use the internal symbolic
+## names, e.g. 'vector' or 'monobook':
+$wgDefaultSkin = 'vector-2022';
+
+# Enabled skins.
+# The following skins were automatically enabled:
+wfLoadSkin( 'MinervaNeue' );
+wfLoadSkin( 'MonoBook' );
+wfLoadSkin( 'Timeless' );
+wfLoadSkin( 'Vector' );
+
+
+# End of automatically generated settings.
+# Add more configuration options below.
+
diff --git a/mochalov_danila_lab_1/README.md b/mochalov_danila_lab_1/README.md
new file mode 100644
index 0000000..2d59f12
--- /dev/null
+++ b/mochalov_danila_lab_1/README.md
@@ -0,0 +1,40 @@
+# Лабораторная работа №1
+
+## Описание
+Для выполнения данной лабораторной работы были развернуты следующие сервисы:
+ - mediawiki - Вики-движок;
+ - mariadb - БД для сервиса mediawiki;
+ - drupal - Система управления контентом;
+ - postgres - БД для сервиса drupal.
+
+В файле docker-compose прописаны инструкции для запуска четырех контейнеров с сервисами.
+Для пояснения инструкций для каждой строки добавлены комментарии с объяснением.
+
+## Запуск
+Для запуска необходимо перейти в папку с файлом docker-compose и ввести команду в терминале
+```
+docker compose up -d
+```
+Флаг -d позволяет запустить контейнеры в фоновом режиме, оставляя доступ к консоли.
+
+Для полноценного первого запуска сервиса drupal необходимо открыть его веб-клиент и следовать инструкциям.
+Для полноценного первого запуска сервиса mediawiki необходимо открыть его веб-клиент после запуска и следовать инструкциям по настройке.
+После получения файла LocalSettings.php необходимо:
+ - расскоментировать строчку ./LocalSettings.php:/var/www/html/LocalSettings.php в docker-compose
+ - перенести файл в директорию с файлом docker-compose и перезапустить контейнер.
+
+Для проверки контейнеров после запуска можно использовать команду
+```
+docker ps -a
+```
+В случае если все контейнеры успешно запущены мы увидим в их в консоли со статусом Up
+```
+CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
+e86a2cd3b071 mediawiki "docker-php-entrypoi…" 42 seconds ago Up 39 seconds 0.0.0.0:8080->80/tcp mochalov_danila_lab_1-mediawiki-1
+260ca4b612fe postgres:16 "docker-entrypoint.s…" 42 seconds ago Up 41 seconds 5432/tcp mochalov_danila_lab_1-postgres-1
+1fbd6c3922e2 mariadb "docker-entrypoint.s…" 42 seconds ago Up 41 seconds 3306/tcp mochalov_danila_lab_1-mariadb-1
+a7d4e194a30a drupal:10-apache "docker-php-entrypoi…" 42 seconds ago Up 40 seconds 0.0.0.0:3000->80/tcp mochalov_danila_lab_1-drupal-1
+```
+
+## Демонстрация работы
+Для демонстрации работоспособности записан ролик. Доступ по [ссылке] (https://drive.google.com/file/d/1GkJSwaoSUjggKQIRJlNQtJ12QEDtium6/view?usp=sharing)
diff --git a/mochalov_danila_lab_1/docker-compose.yml b/mochalov_danila_lab_1/docker-compose.yml
new file mode 100644
index 0000000..d977dcb
--- /dev/null
+++ b/mochalov_danila_lab_1/docker-compose.yml
@@ -0,0 +1,52 @@
+services:
+ mediawiki: # Сервис MediaWiki
+ image: mediawiki # Образ MediaWiki из Docker Hub
+ restart: always # Автоматический перезапуск контейнера при сбое
+ ports:
+ - 8080:80 # Проброс порта 80 из контейнера на порт 8080 хоста
+ depends_on:
+ - mariadb # Запуск MediaWiki только после запуска MariaDB
+ volumes:
+ - images:/var/www/html/images # Монтирование volume для хранения данных
+ - ./LocalSettings.php:/var/www/html/LocalSettings.php # Монтирование локального файла настроек (ЗАКОММЕНТИРОВАТЬ ДО НАСТРОЙКИ)
+
+ mariadb: # Сервис MariaDB
+ image: mariadb # Образ MariaDB из Docker Hub
+ restart: always # Автоматический перезапуск контейнера при сбое
+ environment: # Переменные окружения для настройки базы данных
+ MYSQL_DATABASE: my_wiki # Название базы данных
+ MYSQL_USER: wikiuser # Имя пользователя для доступа к базе данных
+ MYSQL_PASSWORD: password # Пароль для пользователя
+ MYSQL_RANDOM_ROOT_PASSWORD: 'yes' # Случайный пароль для пользователя root
+ volumes:
+ - db_maria:/var/lib/mysql # Монтирование volume для хранения данных базы
+
+ drupal: # Сервис Drupal
+ image: drupal:10-apache # Образ Drupal
+ ports:
+ - 3000:80 # Проброс порта 80 из контейнера на порт 3000 хоста
+ volumes: # Монтирование volumes для хранения локальных файлов Drupal
+ - drupal-modules:/var/www/html/modules
+ - drupal-profiles:/var/www/html/profiles
+ - drupal-themes:/var/www/html/themes
+ - drupal-sites:/var/www/html/sites
+ restart: always # Автоматический перезапуск контейнера при сбое
+ depends_on:
+ - postgres # Запуск Drupal только после запуска Postgres
+
+ postgres: # Сервис PostgreSQL
+ image: postgres:16 # Образ PostgreSQL
+ environment:
+ POSTGRES_PASSWORD: password # Пароль для пользователя postgres
+ restart: always # Автоматический перезапуск контейнера при сбое
+ volumes:
+ - db_postgres:/var/lib/postgresql # Монтирование volume для хранения данных базы
+
+volumes:
+ images: # Volume для хранения изображений MediaWiki
+ db_maria: # Volume для хранения данных MariaDB
+ db_postgres: # Volume для хранения данных Postgres
+ drupal-modules: # Volumes для хранения локальных данных Drupal
+ drupal-profiles: # Volumes для хранения локальных данных Drupal
+ drupal-themes: # Volumes для хранения локальных данных Drupal
+ drupal-sites: # Volumes для хранения локальных данных Drupal
diff --git a/polevoy_sergey_lab_1/docker-compose.yml b/polevoy_sergey_lab_1/docker-compose.yml
new file mode 100644
index 0000000..9fc0f0d
--- /dev/null
+++ b/polevoy_sergey_lab_1/docker-compose.yml
@@ -0,0 +1,42 @@
+services: # Начало объявления сервисов
+ gitea: # Указывается название сервиса
+ image: gitea/gitea:1.22.2 # Указание названия образа (и/или его версии), который будет взят для создания контейнера
+ restart: always # Указывается политика перезапуска, в данном случае всегда перезапускать контейнер, если он остановился
+ environment: # Указываются переменные среды
+ - GITEA__database__DB_TYPE=postgres # Тип базы данных
+ - GITEA__database__HOST=postgres:5432 # Хост бд. Название сервиса это а-ля доменное имя и внутри сети разрешается в ip нужного контейнера
+ - GITEA__database__NAME=gitea # Название базы данных
+ - GITEA__database__USER=superuser # Пользователь базы данных
+ - GITEA__database__PASSWD=superpassword # Пароль пользователя базы данных
+ ports: # Перечисляются пробросы портов на хостовую машину. Слева порт хостовой машины, справа порт контейнера
+ - "3000:3000" # Web интерфейс
+ - "222:22" # SSH
+ volumes: # Указываются монтированные тома, папки, файлы. В данном случае в папку /data монтируется объявленный ниже том gitea
+ - gitea:/data
+ depends_on: # Указывается зависимость запуска контейнера от другого сервиса, в данном случае запускается только после запуска сервиса бд
+ - postgres
+ # Дальше всё по аналогии, различаются лишь названия, переменные окружения, образы, порты и тома
+ postgres:
+ image: postgres:14
+ restart: always
+ environment:
+ - POSTGRES_USER=superuser
+ - POSTGRES_PASSWORD=superpassword
+ - POSTGRES_DB=gitea
+ ports:
+ - "5432:5432"
+ volumes:
+ - postgres:/var/lib/postgresql/data
+
+ rabbitmq:
+ image: rabbitmq:3-management
+ environment:
+ RABBITMQ_DEFAULT_USER: superuser
+ RABBITMQ_DEFAULT_PASS: superpassword
+ ports:
+ - "5672:5672"
+ - "15672:15672"
+
+volumes: # Перечисление томов, которые можно использовать как в одном, так и в нескольких сервисах
+ postgres:
+ gitea:
\ No newline at end of file
diff --git a/polevoy_sergey_lab_1/readme.md b/polevoy_sergey_lab_1/readme.md
new file mode 100644
index 0000000..a8aae30
--- /dev/null
+++ b/polevoy_sergey_lab_1/readme.md
@@ -0,0 +1,25 @@
+# Лабораторная работа №1
+В рамках данной лабораторной работы будут развёрнуты следующие сервисы:
+1. **Gitea** - система управления версиями
+2. **Postgres** - реляционая база данных
+3. **Rabbitmq** - брокер сообщений
+
+Инструкции к запуску контейнеров и пояснения к ним находятся в файле ```docker-compose.yml```
+
+## Порядок запуска
+#### 1. Установить docker или убедиться, что он установлен
+#### 2. Перейти в папку с файлом ```docker-compose.yml```
+#### 3. Выполнить команду в терминале: ```docker-compose up --build --remove-orphans```
+
+Проверить успешность запуска можно командой ```docker ps -a```. Если всё прошло успешно, то в терминале будет написано:
+```
+CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
+1a794331b32b gitea/gitea:1.22.2 "/usr/bin/entrypoint…" 20 seconds ago Up 18 seconds 0.0.0.0:3000->3000/tcp, 0.0.0.0:222->22/tcp polevoy_sergey_lab_1-gitea-1
+b5fe33c61c1d rabbitmq:3-management "docker-entrypoint.s…" 20 seconds ago Up 19 seconds 4369/tcp, 5671/tcp, 0.0.0.0:5672->5672/tcp, 15671/tcp, 15691-15692/tcp, 25672/tcp, 0.0.0.0:15672->15672/tcp rabbitmq
+3d2db73d15c5 postgres:14 "docker-entrypoint.s…" 20 seconds ago Up 19 seconds 0.0.0.0:5432->5432/tcp polevoy_sergey_lab_1-postgres-1
+```
+
+Работать со всеми перечисленными сервисами можно сразу после запуска за исключением **gitea**. После первого запуска необходимо зайти на сервис, выполнить первоначальную настройку и создать суперпользователя.
+
+## Видеодемонстрация работы
+### Видео доступно по [ссылке](https://disk.yandex.ru/i/3Out4mUV6NEJuA)
\ No newline at end of file
diff --git a/tukaeva_alfiya_lab_1/.env b/tukaeva_alfiya_lab_1/.env
new file mode 100644
index 0000000..b022097
--- /dev/null
+++ b/tukaeva_alfiya_lab_1/.env
@@ -0,0 +1,4 @@
+DB_HOST = wp_database
+DB_USER = wordpress
+DB_PASSWORD = wordpress
+DB_NAME = wordpress
\ No newline at end of file
diff --git a/tukaeva_alfiya_lab_1/Dockerfile b/tukaeva_alfiya_lab_1/Dockerfile
new file mode 100644
index 0000000..2850456
--- /dev/null
+++ b/tukaeva_alfiya_lab_1/Dockerfile
@@ -0,0 +1,13 @@
+FROM wordpress:latest
+
+# Установка WP-CLI
+RUN apt-get update && apt-get install -y less \
+ && curl -O https://raw.githubusercontent.com/wp-cli/builds/gh-pages/phar/wp-cli.phar \
+ && chmod +x wp-cli.phar \
+ && mv wp-cli.phar /usr/local/bin/wp
+
+# Копируем скрипт entrypoint
+COPY entrypoint.sh /usr/local/bin/entrypoint.sh
+RUN chmod +x /usr/local/bin/entrypoint.sh
+
+ENTRYPOINT ["/usr/local/bin/entrypoint.sh"]
\ No newline at end of file
diff --git a/tukaeva_alfiya_lab_1/README.md b/tukaeva_alfiya_lab_1/README.md
new file mode 100644
index 0000000..5dff343
--- /dev/null
+++ b/tukaeva_alfiya_lab_1/README.md
@@ -0,0 +1,137 @@
+# Лабораторная работа №1 - Знакомство с docker и docker-compose
+
+## Задание
+
+Нужно развернуть 3 сервиса в контейнерах docker через docker-compose.
+
+Необходимые требования:
+
+* Несколько контейнеров.
+* Хотя бы один volume.
+* Хотя бы один порт, проброшенный на хост.
+* Разворачивание системы должно пройти до конца.
+
+## Запуск ЛР:
+
+Введем в терминале команду:
+```
+docker-compose up -d
+```
+## Использованные сервисы:
+
+ 1. ```db``` - база данные MySQL
+
+ 2. ```redmine``` - Система учёта багов, т.е. баг-трекер.
+
+ 3. ```mediawiki``` - движок вики
+
+ 4. ```wordpress``` - платформа для управления контентом
+
+## Описание программы:
+
+Развернутые сервисы:
+
+### wordpress
+
+```
+wordpress: # Определение сервиса WordPress
+ image: wordpress:latest # Используемый образ WordPress последней версии
+ containername: wp_app # Имя контейнера
+ restart: always
+ ports: # Настройка портов
+ - "8000:80"
+ environment: # Переменные окружения
+ WORDPRESSDBHOST: ${DBHOST}
+ WORDPRESSDBUSER: ${DBUSER}
+ WORDPRESSDBPASSWORD: ${DBPASSWORD}
+ WORDPRESSDBNAME: ${DBNAME}
+ WORDPRESSADMINUSER: admin
+ WORDPRESSADMINPASSWORD: adminpassword
+ WORDPRESSADMINEMAIL: admin@example.com
+ volumes: # Настройка томов
+ - wordpress_data:/var/www/html
+ dependson: # Зависимости
+ - db_wordpress # Зависит от сервиса MySQL
+
+```
+Эта строка отвечает за образ сброки:
+```
+image: wordpress:latest
+```
+Задание имени контейнера:
+```
+containername: wp_app
+```
+Проброс портов:
+```
+ports:
+ - 8000:80
+```
+Тома для хранения данных:
+```
+volumes:
+ - wordpress_data:/var/www/html
+
+```
+Переменные окружения
+```
+environment:
+ WORDPRESSDBHOST: ${DBHOST}
+ WORDPRESSDBUSER: ${DBUSER}
+ WORDPRESSDBPASSWORD: ${DBPASSWORD}
+ WORDPRESSDBNAME: ${DBNAME}
+ WORDPRESSADMINUSER: admin
+ WORDPRESSADMINPASSWORD: adminpassword
+ WORDPRESSADMINEMAIL: admin@example.com
+
+```
+Зависимости
+
+```
+dependson:
+ - db_wordpress
+
+```
+Аналогично со другими сервисами:
+
+### mediawiki
+
+```
+mediawiki: # Определение сервиса MediaWiki
+ image: mediawiki:1.35 # Используемый образ MediaWiki версии 1.35
+ ports: # Настройка портов
+ - "8080:80"
+ containername: mediawiki # Имя контейнера
+ volumes: # Настройка томов
+ - mediawiki_data:/var/www/html/images mediawiki: # Определение сервиса MediaWiki
+ image: mediawiki:1.35 # Используемый образ MediaWiki версии 1.35
+ ports: # Настройка портов
+ - "8080:80"
+ containername: mediawiki # Имя контейнера
+ volumes: # Настройка томов
+ - mediawiki_data:/var/www/html/images
+
+```
+
+### redmine
+
+```
+
+redmine: # Определение сервиса Redmine
+ image: redmine:latest # Используемый образ Redmine последней версии
+ containername: redmine # Имя контейнера
+ ports: # Настройка портов
+ - "3000:3000"
+ volumes: # Настройка томов
+ - redmine_data:/usr/src/redmine/files
+
+```
+
+# Скрины работы программы:
+
+Панель консоли
+![](lab_1.png "")
+
+# Видео
+
+https://vk.com/video230744264_456239102
\ No newline at end of file
diff --git a/tukaeva_alfiya_lab_1/docker-compose.yml b/tukaeva_alfiya_lab_1/docker-compose.yml
new file mode 100644
index 0000000..681a721
--- /dev/null
+++ b/tukaeva_alfiya_lab_1/docker-compose.yml
@@ -0,0 +1,53 @@
+services:
+ mediawiki: # Определение сервиса MediaWiki
+ image: mediawiki:1.35 # Используемый образ MediaWiki версии 1.35
+ ports: # Настройка портов
+ - "8080:80"
+ containername: mediawiki # Имя контейнера
+ volumes: # Настройка томов
+ - mediawiki_data:/var/www/html/images
+
+ db_wordpress: # Определение сервиса MySQL для WordPress
+ image: mysql:5.7 # Используемый образ MySQL версии 5.7
+ containername: wp_database # Имя контейнера
+ environment: # Переменные окружения
+ MYSQLROOTPASSWORD: rootsecret
+ MYSQLDATABASE: ${DBNAME}
+ MYSQLUSER: ${DBUSER}
+ MYSQLPASSWORD: ${DBPASSWORD}
+ volumes: # Настройка томов
+ - db_wordpress_data:/var/lib/mysql
+
+ wordpress: # Определение сервиса WordPress
+ image: wordpress:latest # Используемый образ WordPress последней версии
+ containername: wp_app # Имя контейнера
+ restart: always
+ ports: # Настройка портов
+ - "8000:80"
+ user: www-data
+ environment: # Переменные окружения
+ WORDPRESSDBHOST: ${DBHOST}
+ WORDPRESSDBUSER: ${DBUSER}
+ WORDPRESSDBPASSWORD: ${DBPASSWORD}
+ WORDPRESSDBNAME: ${DBNAME}
+ WORDPRESSADMINUSER: admin
+ WORDPRESSADMINPASSWORD: adminpassword
+ WORDPRESSADMINEMAIL: admin@example.com
+ volumes: # Настройка томов
+ - wordpress_data:/var/www/html
+ dependson: # Зависимости
+ - db_wordpress # Зависит от сервиса MySQL
+
+ redmine: # Определение сервиса Redmine
+ image: redmine:latest # Используемый образ Redmine последней версии
+ containername: redmine # Имя контейнера
+ ports: # Настройка портов
+ - "3000:3000"
+ volumes: # Настройка томов
+ - redmine_data:/usr/src/redmine/files
+
+volumes: # Определение томов
+ mediawiki_data: # ТОМ для MediaWiki
+ wordpress_data: # ТОМ для WordPress
+ db_wordpress_data: # ТОМ для MySQL
+ redmine_data: # ТОМ для Redmine
\ No newline at end of file
diff --git a/tukaeva_alfiya_lab_1/entrypoint.sh b/tukaeva_alfiya_lab_1/entrypoint.sh
new file mode 100644
index 0000000..4d2aadd
--- /dev/null
+++ b/tukaeva_alfiya_lab_1/entrypoint.sh
@@ -0,0 +1,15 @@
+#!/bin/bash
+set -e
+
+# Ожидание готовности базы данных
+until wp db check; do
+ echo "Ожидание базы данных..."
+ sleep 5
+done
+
+# Установка WordPress
+if ! wp core is-installed; then
+ wp core install --url="http://localhost:8000" --title="Библиотека" --admin_user="admin" --admin_password="admin_password" --admin_email="admin@example.com" --skip-email
+fi
+
+exec apache2-foreground
\ No newline at end of file
diff --git a/tukaeva_alfiya_lab_1/lab_1.png b/tukaeva_alfiya_lab_1/lab_1.png
new file mode 100644
index 0000000..48fbc48
Binary files /dev/null and b/tukaeva_alfiya_lab_1/lab_1.png differ