Compare commits
2 Commits
klementeva
...
klementeva
| Author | SHA1 | Date | |
|---|---|---|---|
| 8fb52539f0 | |||
| 6a5999478a |
@@ -6,7 +6,7 @@
|
||||
## Лабораторные работы
|
||||
|
||||
1. [Знакомство с docker и docker-compose](labs/lab_1/README.md)
|
||||
2. [Разработка простейшего распределённого приложения](labs/lab_2/README.md)
|
||||
2. TBA
|
||||
3. TBA
|
||||
4. TBA
|
||||
5. TBA
|
||||
|
||||
|
Before Width: | Height: | Size: 74 KiB |
@@ -1,158 +0,0 @@
|
||||
# Отчёт по лабораторной работе №1
|
||||
|
||||
Выполнил: студент гр. ИСЭБД-41 Клементьева Жанна.
|
||||
|
||||
## Разворачивание сервера Wordpress
|
||||
|
||||
Содержимое файла `docker-compose.yml`:
|
||||
|
||||
```yaml
|
||||
version: '3'
|
||||
|
||||
services: # Описание контейнеров
|
||||
db: # База данных
|
||||
image: mysql:5.7 # Образ базы данных и версия
|
||||
volumes: # Тома для хранения данных, для контейнеров
|
||||
- db_data:/var/lib/mysql
|
||||
restart: always # Параметр перезапуска БД
|
||||
environment: # Переменные среды для контейнера
|
||||
MYSQL_ROOT_PASSWORD: password
|
||||
MYSQL_DATABASE: wordpress
|
||||
MYSQL_USER: wordpress
|
||||
MYSQL_PASSWORD: wordpress
|
||||
networks: # Параметры сети
|
||||
- wpsite
|
||||
|
||||
wordpress: # Контейнер с Wordpress
|
||||
depends_on: # Параметр зависимости от работы базы данных (в данном случае)
|
||||
- db
|
||||
image: wordpress:latest # Образ Wordpress (последняя версия)
|
||||
ports: # Порт, проложенный из контейнера в хост
|
||||
- '8000:80'
|
||||
restart: always # Параметр перезапуска
|
||||
volumes: ['./:/var/www/html'] # Тома для хранения данных, для контейнеров
|
||||
environment: # Переменные среды для контейнера
|
||||
WORDPRESS_DB_HOST: db:3306
|
||||
WORDPRESS_DB_USER: wordpress
|
||||
WORDPRESS_DB_PASSWORD: wordpress
|
||||
networks: # Параметры сети
|
||||
- wpsite
|
||||
networks:
|
||||
wpsite:
|
||||
volumes:
|
||||
db_data:
|
||||
```
|
||||
|
||||
Разворачивается командой `docker-compose up`.
|
||||
|
||||
Убеждаемся, что всё работает, прописываем в браузере "localhost:8000", так как docker-compose.yaml мы указали порт 8000:
|
||||
|
||||

|
||||
|
||||

|
||||
|
||||
Открывается стартовое окно Wordpress, где мы можем выбрать язык и приступить к работе, если это потребуется:
|
||||

|
||||
|
||||

|
||||
|
||||
|
||||
|
||||
Удаляется всё командой `docker-compose down` или `docker-compose down -v`.
|
||||
|
||||
|
||||
## Разворачивание сервера Gitea
|
||||
|
||||
Содержимое файла `docker-compose.yml`:
|
||||
|
||||
```yaml
|
||||
version: "3"
|
||||
|
||||
networks:
|
||||
gitea:
|
||||
external: false
|
||||
|
||||
services: # Описание служб (контейнеров).
|
||||
server: # Сервер
|
||||
image: gitea/gitea:1.20.4 # Образ базы данных и версия
|
||||
container_name: gitea # Наименование контейнера
|
||||
environment: # Переменные среды для контейнера
|
||||
- USER_UID=1000
|
||||
- USER_GID=1000
|
||||
- GITEA__database__DB_TYPE=mysql
|
||||
- GITEA__database__HOST=db:3306
|
||||
- GITEA__database__NAME=gitea
|
||||
- GITEA__database__USER=gitea
|
||||
- GITEA__database__PASSWD=gitea
|
||||
restart: always # Параметр перезапуска
|
||||
networks: # Параметры сети
|
||||
- gitea
|
||||
volumes: # Тома для хранения данных, для контейнеров
|
||||
- ./gitea:/data
|
||||
- /etc/timezone:/etc/timezone:ro
|
||||
- /etc/localtime:/etc/localtime:ro
|
||||
ports: # Порты, проложенные из контейнера в хост
|
||||
- "3000:80"
|
||||
- "222:22"
|
||||
depends_on: # Параметр зависимости от работы базы данных (в данном случае)
|
||||
- db
|
||||
|
||||
db: # База данных
|
||||
image: mysql:8 # Образ базы данных и версия
|
||||
restart: always # Параметр перезапуска БД
|
||||
environment: # Переменные среды для контейнера
|
||||
- MYSQL_ROOT_PASSWORD=gitea
|
||||
- MYSQL_USER=gitea
|
||||
- MYSQL_PASSWORD=gitea
|
||||
- MYSQL_DATABASE=gitea
|
||||
networks: # Параметры сети
|
||||
- gitea
|
||||
volumes: # Тома для хранения данных, для контейнеров
|
||||
- ./mysql:/var/lib/mysql
|
||||
```
|
||||
|
||||
Разворачивается командой `docker-compose up`.
|
||||
|
||||
Убеждаемся, что всё работает, прописываем в браузере "localhost:3000", так как docker-compose.yaml мы указали порт 3000. Открывается стартовое окно Gitea, где мы можем настроить систему и приступить к работе, если это потребуется:
|
||||
|
||||

|
||||
|
||||
Удаляется всё командой `docker-compose down` или `docker-compose down -v`.
|
||||
|
||||
|
||||
## Разворачивание сервера Mediawiki
|
||||
|
||||
Содержимое файла `docker-compose.yml`:
|
||||
|
||||
```yaml
|
||||
version: '3.2'
|
||||
services: # Описание контейнеров
|
||||
web: # Контейнер с Mediawiki
|
||||
image: mediawiki:lts # Образ Mediawiki
|
||||
ports: # Порт, проложенный из контейнера в хост
|
||||
- 9999:80
|
||||
links: # Ссылка на контейнер "database"
|
||||
- database
|
||||
restart: unless-stopped # Параметр перезапуска
|
||||
volumes: # Тома для хранения данных, для контейнеров
|
||||
- ./images:/var/www/html/images
|
||||
|
||||
database: # База данных
|
||||
image: mariadb # Образ базы данных
|
||||
environment: # Переменные среды для контейнера
|
||||
MYSQL_DATABASE: 'wiki'
|
||||
MYSQL_USER: 'wikiuser234234'
|
||||
MYSQL_PASSWORD: 'YOUR_SECURE_PASSWORD'
|
||||
MYSQL_RANDOM_ROOT_PASSWORD: 'yes'
|
||||
volumes: # Тома для хранения данных, для контейнеров
|
||||
- ./database:/var/lib/mysql
|
||||
restart: unless-stopped # Параметр перезапуска
|
||||
```
|
||||
|
||||
Разворачивается командой `docker-compose up`.
|
||||
|
||||
Убеждаемся, что всё работает, прописываем в браузере "localhost:9999", так как docker-compose.yaml мы указали порт 9999. Открывается стартовое окно Mediawiki, где мы можем настроить систему и приступить к работе, если это потребуется:
|
||||
|
||||

|
||||
|
||||
Удаляется всё командой `docker-compose down` или `docker-compose down -v`.
|
||||
|
Before Width: | Height: | Size: 38 KiB |
|
Before Width: | Height: | Size: 60 KiB |
|
Before Width: | Height: | Size: 71 KiB |
|
Before Width: | Height: | Size: 1.8 KiB |
|
Before Width: | Height: | Size: 8.3 KiB |
@@ -24,7 +24,7 @@
|
||||
4. Что такое образ (image) в docker, и в чём отличие от контейнера (container).
|
||||
5. Что такое Docker Hub.
|
||||
6. Что такое раздел/том (volume), и как это помогает обмениваться файлами между контейнерами или с хостом (host).
|
||||
7. Зачем нужно отображение портов из контейнера в хост.
|
||||
7. Зачем нужно отображение портов из контейнера в хоста.
|
||||
|
||||
## Изучение docker-compose
|
||||
|
||||
|
||||
@@ -1,113 +0,0 @@
|
||||
# Лабораторная работа №2 - Разработка простейшего распределённого приложения
|
||||
|
||||
**Цель**: изучение техники создания простого распределённого приложения.
|
||||
|
||||
**Задачи**:
|
||||
|
||||
1. **Согласно вашему варианту** разработать два приложения такие, что результат первого является исходными данными для второго.
|
||||
2. Изучить файлы сборки образов docker и разработать их для созданных приложений.
|
||||
3. Собрать файл `docker-compose.yml` для запуска приложений.
|
||||
Разобраться с монтированием каталогов из хост-системы.
|
||||
4. Правильно закоммитить результат без лишних файлов.
|
||||
5. Оформить pull request по правилам и отправить его на проверку.
|
||||
|
||||
## Разработка двух приложений
|
||||
|
||||
Необходимо разработать 2 приложения согласно варианту.
|
||||
Описание поиска своего варианта расположено ниже.
|
||||
|
||||
Общее для всех вариантов:
|
||||
|
||||
* Язык разработки приложений — любой.
|
||||
* Содержимое исходных файлов - целые числа.
|
||||
* Результат выполнения программы 2 необходимо дополнительно вывести на экран.
|
||||
|
||||
> Автор советует использовать dotnet, java, go или python.
|
||||
|
||||
Каждая программа должна лежать в отдельной подпапке в репозитории, например: `tasks/moiseev-vv/lab_2/worker-1` и `tasks/moiseev-vv/lab_2/worker-2`.
|
||||
|
||||
[Пример от автора](../../tasks/moiseev-vv/lab_2/).
|
||||
|
||||
## Добавление файлов сборки `Dockerfile`
|
||||
|
||||
В каталоге с каждым приложением необходимо создать файл `Dockerfile`, где будут расположены инструкции по сборке образа с вашими приложениями.
|
||||
|
||||
> Для многих языков программирования шаблоны `Dockerfile` можно найти в Интернете.
|
||||
|
||||
В рамках задания необходимо расписать, за что отвечает каждая значимая строка в `Dockerfile`.
|
||||
Хотя бы одном.
|
||||
|
||||
Если у вас используется multi-stage build (как в примере выше, где в одном `Dockerfile` несколько конструкций `FROM`), необходимо расписать, зачем.
|
||||
|
||||
## Формирование файла `docker-compose.yml`
|
||||
|
||||
Необходимо в каталоге с вашей работой создать файл `docker-compose.yml`, чтобы можно было собрать и запустить программы следующей командой:
|
||||
|
||||
```
|
||||
distributed-computing\tasks\moiseev-vv\lab_2$ docker compose up --build
|
||||
```
|
||||
|
||||
> До `$` - каталог относительно корня репозитория, чтобы понять, откуда запускается `docker compose`.
|
||||
|
||||
Необходимо, чтобы в файле было:
|
||||
|
||||
1. Два сервиса.
|
||||
Каждый соответствует вашим программам.
|
||||
2. Объявлена директива `build` для каждого сервиса.
|
||||
3. Была работа с монтированием папок.
|
||||
4. Были описаны зависимости одного сервиса от другого.
|
||||
|
||||
## Оформление отчёта
|
||||
|
||||
Правила именования папки с отчётом и исходными текстами - `/tasks/фамилия-инициалы/lab_номер`, например, `/tasks/moiseev-vv/lab_2`.
|
||||
|
||||
[Пример отчёта и всего остального](../../tasks/moiseev-vv/lab_2/README.md).
|
||||
|
||||
## Коммит результата
|
||||
|
||||
Перед началом работы над задачей необходимо актуализировать свой форк, выполненный в работе №1.
|
||||
|
||||
Как это сделать зависит от конкретного хранилища git-репозиториев.
|
||||
|
||||
> TODO: Так как всё-таки?!
|
||||
|
||||
Также необходимо не забыть добавить файл `.gitignore` в каталог с вашей работой.
|
||||
Если вы этого не сделаете, на коммит "полезут" файлы сборки и прочие вещи, который быть в публичном репозитории не должны.
|
||||
|
||||
> Для `dotnet` файл `.gitignore` создаётся при помощи команды `dotnet new gitignore`.
|
||||
|
||||
Правила именования ветки: `фамилия-инициалы-lab-номер`, например, `moiseev-vv-lab-2`.
|
||||
|
||||
## Правила оформления pull request
|
||||
|
||||
Название pull request: `[Л/Р 2] ФАМИЛИЯ ИМЯ`, например, `[Л/Р 2] Моисеев Владислав`.
|
||||
|
||||
## Варианты
|
||||
|
||||
Расчёт варианта также представляет собой задачку:
|
||||
|
||||
1. Необходимо найти номер своей зачёткой книжки.
|
||||
Пусть будет _20/614_.
|
||||
2. Далее необходимо найти **остаток от деления номера на 7**.
|
||||
Это будет вариант для программы 1.
|
||||
В нашем примере это `614 : 7 = 87 и остаток` **5**.
|
||||
3. Вариант для программы 2 - **остаток от деления номера зачётки на 5**
|
||||
В нашем случае это `614 : 5 = 122 и остаток` **4**.
|
||||
|
||||
### Варианты программы 1:
|
||||
|
||||
0. Ищет в каталоге `/var/data` самый большой по объёму файл и перекладывает его в `/var/result/data.txt`.
|
||||
1. Ищет в каталоге `/var/data` файл с наибольшим количеством строк и перекладывает его в `/var/result/data.txt`.
|
||||
2. Формирует файл `/var/result/data.txt` из первых строк всех файлов каталога `/var/data`.
|
||||
3. Формирует файл `/var/result/data.txt` так, что каждая строка файла - количество строк в файлах из каталога `/var/data`.
|
||||
4. Формирует файл `/var/result/data.txt` так, что каждая строка файла - количество символов в именах файлов из каталога `/var/data`.
|
||||
5. Ищет в каталоге `/var/data` файл с самым коротким названием и перекладывает его в `/var/result/data.txt`.
|
||||
6. Берёт из каталога `/var/data` случайный файл и перекладывает его в `/var/result/data.txt`.
|
||||
|
||||
### Варианты программы 2:
|
||||
|
||||
0. Сохраняет произведение первого и последнего числа из файла `/var/data/data.txt` в `/var/result/result.txt`.
|
||||
1. Ищет набольшее число из файла `/var/data/data.txt` и сохраняет его вторую степень в `/var/result/result.txt`.
|
||||
2. Ищет наименьшее число из файла `/var/data/data.txt` и сохраняет его третью степень в `/var/result/result.txt`.
|
||||
3. Ищет набольшее число из файла `/var/data/data.txt` и сохраняет количество таких чисел из последовательности в `/var/result/result.txt`.
|
||||
4. Ищет наименьшее число из файла `/var/data/data.txt` и сохраняет количество таких чисел из последовательности в `/var/result/result.txt`.
|
||||
@@ -1,157 +0,0 @@
|
||||
# Отчёт по лабораторной работе №1
|
||||
|
||||
Выполнил: студент гр. ИСЭбд-41 Фомичев А.И.
|
||||
|
||||
## Разворачивание сервиса Redmine
|
||||
|
||||
Содержимое файла `docker-compose.yml` в папке Redmine:
|
||||
|
||||
```yaml
|
||||
version: "3.8"
|
||||
|
||||
services: # Задаем сервисы.
|
||||
db: # Сервис 1. База данных Postgres.
|
||||
image: postgres:13.2-alpine # Образ БД.
|
||||
restart: unless-stopped
|
||||
environment: # Переменные окружения.
|
||||
POSTGRES_PASSWORD: example # Пароль от postgres.
|
||||
container_name: db_redmine # Название контейнера.
|
||||
volumes: # Место хранения данных для БД.
|
||||
- database:/var/lib/postgresql/data
|
||||
redmine: # Сервис 2. Редмайн.
|
||||
image: redmine:4.1-alpine # Образ.
|
||||
environment: # Переменные окружения.
|
||||
- REDMINE_DB_POSTGRES=db
|
||||
- REDMINE_DB_PASSWORD=example
|
||||
ports: # Прослушиваемые порты.
|
||||
- 9999:3000
|
||||
volumes: # Файлы редмайна.
|
||||
- files:/usr/src/redmine/files
|
||||
depends_on: # Зависимость от БД.
|
||||
- db
|
||||
|
||||
volumes:
|
||||
database:
|
||||
files:
|
||||
```
|
||||
|
||||
Далее в командной строке разворачиваем сервис командой `docker-compose up -d`:
|
||||

|
||||
|
||||
Смотрим в Docker Desktop, что контейнеры БД и сервиса Redmine запущены успешно.
|
||||

|
||||
|
||||
Переходим на http://localhost:9999 и авторизовываемся под администратором.
|
||||

|
||||
|
||||
Создаем проект и некоторые данные.
|
||||

|
||||
|
||||
Наблюдаем полностью рабочий сервис с БД.
|
||||
|
||||
## Разворачивание сервиса Wordpress
|
||||
|
||||
Также в файл `docker-compose.yml` в папке Wordpress прописываем следующий код:
|
||||
|
||||
```yaml
|
||||
version: '3.1'
|
||||
|
||||
services:
|
||||
wordpress:
|
||||
image: wordpress
|
||||
restart: always
|
||||
ports:
|
||||
- 8080:80
|
||||
environment:
|
||||
WORDPRESS_DB_HOST: db
|
||||
WORDPRESS_DB_USER: test2
|
||||
WORDPRESS_DB_PASSWORD: test123
|
||||
WORDPRESS_DB_NAME: wordpressDB
|
||||
volumes:
|
||||
- wordpress:/var/www/html
|
||||
|
||||
db:
|
||||
image: mysql:5.7
|
||||
restart: always
|
||||
environment:
|
||||
MYSQL_DATABASE: wordpressDB
|
||||
MYSQL_USER: test2
|
||||
MYSQL_PASSWORD: test123
|
||||
MYSQL_RANDOM_ROOT_PASSWORD: '1'
|
||||
volumes:
|
||||
- db:/var/lib/mysql
|
||||
|
||||
volumes:
|
||||
wordpress:
|
||||
db:
|
||||
```
|
||||
|
||||
Далее в командной строке разворачиваем сервис командой `docker-compose up -d`:
|
||||

|
||||
|
||||
Смотрим в Docker Desktop, что контейнеры БД и сервиса Wordpress запущены успешно.
|
||||

|
||||
|
||||
Переходим на http://localhost:8080, авторизовываемся под администратором и создаем наш сайт.
|
||||

|
||||
|
||||
Сервис развернут успешно.
|
||||
|
||||
## Разворачивание сервиса Gitea
|
||||
|
||||
В файл `docker-compose.yml` прописываем следующий код:
|
||||
|
||||
```yaml
|
||||
version: "3"
|
||||
|
||||
networks:
|
||||
gitea:
|
||||
external: false
|
||||
services:
|
||||
server:
|
||||
image: gitea/gitea:1.20.4
|
||||
container_name: gitea
|
||||
environment:
|
||||
- USER_UID=1000
|
||||
- USER_GID=1000
|
||||
- GITEA__database__DB_TYPE=mysql
|
||||
- GITEA__database__HOST=db:3306
|
||||
- GITEA__database__NAME=gitea
|
||||
- GITEA__database__USER=gitea
|
||||
- GITEA__database__PASSWD=gitea
|
||||
restart: always
|
||||
networks:
|
||||
- gitea
|
||||
volumes:
|
||||
- ./gitea:/data
|
||||
- /etc/timezone:/etc/timezone:ro
|
||||
- /etc/localtime:/etc/localtime:ro
|
||||
ports:
|
||||
- "3000:3000"
|
||||
- "222:22"
|
||||
depends_on:
|
||||
- db
|
||||
db:
|
||||
image: mysql:8
|
||||
restart: always
|
||||
environment:
|
||||
- MYSQL_ROOT_PASSWORD=gitea
|
||||
- MYSQL_USER=gitea
|
||||
- MYSQL_PASSWORD=gitea
|
||||
- MYSQL_DATABASE=gitea
|
||||
networks:
|
||||
- gitea
|
||||
volumes:
|
||||
- ./mysql:/var/lib/mysql
|
||||
```
|
||||
|
||||
Далее в командной строке разворачиваем сервис командой `docker-compose up -d`:
|
||||

|
||||
|
||||
Смотрим в Docker Desktop, что контейнеры БД и сервиса Wordpress запущены успешно.
|
||||

|
||||
|
||||
Переходим на http://localhost:3000, авторизовываемся под администратором и создаем наш сайт.
|
||||

|
||||
|
||||
Сервис развернут успешно.
|
||||
|
Before Width: | Height: | Size: 20 KiB |
|
Before Width: | Height: | Size: 14 KiB |
|
Before Width: | Height: | Size: 48 KiB |
|
Before Width: | Height: | Size: 81 KiB |
|
Before Width: | Height: | Size: 59 KiB |
|
Before Width: | Height: | Size: 23 KiB |
|
Before Width: | Height: | Size: 77 KiB |
|
Before Width: | Height: | Size: 204 KiB |
|
Before Width: | Height: | Size: 72 KiB |
|
Before Width: | Height: | Size: 274 KiB |
@@ -1,151 +0,0 @@
|
||||
# Отчёт по лабораторной работе №1
|
||||
|
||||
Выполнила: студентка гр. ИСЭбд-41, Гренадерова А.А.
|
||||
|
||||
## Разворачивание сервиса Gitea
|
||||
|
||||
Содержимое файла `docker-compose.yml` в папке Gitea:
|
||||
```yaml
|
||||
version: "3"
|
||||
|
||||
networks:
|
||||
gitea:
|
||||
external: false
|
||||
# Контейнер Gitea
|
||||
services: # Описание служб
|
||||
server:
|
||||
image: gitea/gitea:1.20.4 # Образ gitea
|
||||
container_name: gitea # Наименование контейнера
|
||||
environment: # Наши параметры
|
||||
- USER_UID=1000
|
||||
- USER_GID=1000
|
||||
- GITEA__database__DB_TYPE=mysql
|
||||
- GITEA__database__HOST=db:3306
|
||||
- GITEA__database__NAME=gitea
|
||||
- GITEA__database__USER=gitea
|
||||
- GITEA__database__PASSWD=gitea
|
||||
restart: always
|
||||
networks: # Параметры сети
|
||||
- gitea
|
||||
volumes: # Каталоги для хранения данных контейнера
|
||||
- ./gitea:/data
|
||||
- /etc/timezone:/etc/timezone:ro
|
||||
- /etc/localtime:/etc/localtime:ro
|
||||
ports: # Порт локальный и внутри сети
|
||||
- "3000:3000"
|
||||
- "222:22"
|
||||
depends_on:
|
||||
- db
|
||||
# База данных
|
||||
db:
|
||||
image: mysql:8 # Образ БД и версия
|
||||
restart: always # Параметр перезапуска
|
||||
environment: # Подключаем каталог с базой данных
|
||||
- MYSQL_ROOT_PASSWORD=gitea
|
||||
- MYSQL_USER=gitea
|
||||
- MYSQL_PASSWORD=gitea
|
||||
- MYSQL_DATABASE=gitea
|
||||
networks: # Параметры сети
|
||||
- gitea
|
||||
volumes: # Том для хранения данных БД
|
||||
- ./mysql:/var/lib/mysql
|
||||
```
|
||||
Далее в командной строке разворачиваем сервис командой `docker-compose up -d`:
|
||||

|
||||
|
||||
Открываем Docker Desktop и проверяем, что контейнер сервера БД и Gitea созданы и запущены:
|
||||

|
||||
|
||||
Переходим на http://localhost:222:
|
||||

|
||||
|
||||
Регистрируемся и автоматически входим в учетную запись:
|
||||

|
||||

|
||||
|
||||
## Разворачивание сервиса Wordpress
|
||||
|
||||
Также в файл `docker-compose.yml` в папке Wordpress прописываем следующий код:
|
||||
|
||||
```yaml
|
||||
version: '3.1'
|
||||
|
||||
services:
|
||||
# Контейнер Wordpress
|
||||
wordpress:
|
||||
image: wordpress # Образ
|
||||
restart: always # Параметр перезапуска
|
||||
ports: # На каком порте запускаем
|
||||
- 7071:80
|
||||
environment: # Настройки БД WordPress для подключения
|
||||
WORDPRESS_DB_HOST: database # Имя хоста БД MySQL
|
||||
WORDPRESS_DB_USER: user # Имя пользователя БД
|
||||
WORDPRESS_DB_PASSWORD: password # Пароль пользователя БД
|
||||
WORDPRESS_DB_NAME: name_database # Имя БД
|
||||
volumes: # Каталог хранения файлов WordPress
|
||||
- wordpress:/var/www/html
|
||||
# Контейнер MySQL
|
||||
database:
|
||||
image: mysql:5.7 # Образ и его версия
|
||||
restart: always # Параметр перезапуска
|
||||
environment: # Настройки БД для подключения
|
||||
MYSQL_DATABASE: name_database
|
||||
MYSQL_USER: user
|
||||
MYSQL_PASSWORD: password
|
||||
MYSQL_RANDOM_ROOT_PASSWORD: '12345'
|
||||
volumes: # Каталог хранения данных БД
|
||||
- database:/var/lib/mysql
|
||||
|
||||
volumes:
|
||||
wordpress:
|
||||
database:
|
||||
```
|
||||
Далее в командной строке разворачиваем сервис командой `docker-compose up -d`:
|
||||

|
||||
|
||||
Открываем Docker Desktop и проверяем, что контейнер сервера БД и Wordpress созданы и запущены:
|
||||

|
||||
|
||||
Устанавливаем Wordpress и проверяем, что все работает:
|
||||

|
||||

|
||||

|
||||

|
||||
|
||||
## Разворачивание сервиса Redmine
|
||||
|
||||
Также в файл `docker-compose.yml` в папке Redmine прописываем код:
|
||||
|
||||
```yaml
|
||||
version: '3.1'
|
||||
|
||||
services:
|
||||
# Контейнер Redmine
|
||||
redmine:
|
||||
image: redmine # Образ контейнера
|
||||
restart: always
|
||||
ports: # На какой порт запускать
|
||||
- 8080:3000
|
||||
environment:
|
||||
REDMINE_DB_MYSQL: db
|
||||
REDMINE_DB_PASSWORD: example
|
||||
REDMINE_SECRET_KEY_BASE: supersecretkey
|
||||
# Контейнер БД MySQL
|
||||
db:
|
||||
image: mysql:5.7 # Образ БД и ее версия
|
||||
restart: always
|
||||
environment: # Название и пароль админа БД
|
||||
MYSQL_ROOT_PASSWORD: example
|
||||
MYSQL_DATABASE: redmine
|
||||
```
|
||||
Далее в командной строке разворачиваем сервис командой `docker-compose up -d`:
|
||||

|
||||
|
||||
Открываем Docker Desktop и проверяем, что контейнер сервера БД и Redmine созданы и запущены:
|
||||

|
||||
|
||||
Переходим на http://localhost:8080:
|
||||

|
||||
|
||||
Регистрируемся и проверяем, что все работает:
|
||||

|
||||
|
Before Width: | Height: | Size: 63 KiB |
|
Before Width: | Height: | Size: 203 KiB |
|
Before Width: | Height: | Size: 411 KiB |
|
Before Width: | Height: | Size: 26 KiB |
|
Before Width: | Height: | Size: 77 KiB |
|
Before Width: | Height: | Size: 195 KiB |
|
Before Width: | Height: | Size: 226 KiB |
|
Before Width: | Height: | Size: 64 KiB |
|
Before Width: | Height: | Size: 305 KiB |
|
Before Width: | Height: | Size: 43 KiB |
|
Before Width: | Height: | Size: 246 KiB |
|
Before Width: | Height: | Size: 36 KiB |
|
Before Width: | Height: | Size: 70 KiB |
|
Before Width: | Height: | Size: 255 KiB |
|
Before Width: | Height: | Size: 268 KiB |
@@ -1,162 +0,0 @@
|
||||
# Отчёт по лабораторной работе №1
|
||||
|
||||
Выполнила: студентка гр. ИСЭбд-41 Халитова А.М.
|
||||
|
||||
## Разворачивание сервиса MediaWiki
|
||||
|
||||
Содержимое файла `docker-compose.yml` в папке MediaWiki:
|
||||
|
||||
```yaml
|
||||
version: "3.2"
|
||||
|
||||
services: #описание контейнеров
|
||||
#Контейнер Mysql используется как сервер для запуска
|
||||
mysql:
|
||||
image: mysql:5.7.23 #образ контейнера
|
||||
container_name: mysql
|
||||
hostname: mysql
|
||||
volumes: #подключаем каталог с базой данных
|
||||
- /var/lib/mysql:/var/lib/mysql
|
||||
env_file: #файл с настройками БД для подключения к серверу
|
||||
- ./mysql.env
|
||||
restart: always
|
||||
|
||||
#Контейнер Mediawiki используется для запуска самого сервиса
|
||||
mediawiki:
|
||||
image: diouxx/mediawiki #образ контейнера
|
||||
container_name : wiki
|
||||
hostname: wiki
|
||||
ports: #указываем по какому порту мы получаем доступ к сервису по адресу http://localhost:8081/
|
||||
- "8081:80"
|
||||
volumes: #прописываем каталоги для хранения данных контейнера
|
||||
- /etc/timezone:/etc/timezone:ro
|
||||
- /etc/localtime:/etc/localtime:ro
|
||||
- /var/www/html/wiki/:/var/www/html/wiki
|
||||
- ./data/LocalSettings.php:/var/www/html/LocalSettings.php
|
||||
|
||||
restart: always
|
||||
```
|
||||
Далее в командной строке разворачиваем сервис командой `docker-compose up`:
|
||||

|
||||
|
||||
Открываем Docker Desktop и проверяем, что контейнер сервера базы данных и MediaWiki созданы и запущены:
|
||||

|
||||
|
||||
Переходим на http://localhost:8081:
|
||||

|
||||
|
||||
Переходим к установке MediaWiki и прописываем указанные нами в файле `mysql.env` значения хоста, имя пользователя и пароль:
|
||||

|
||||

|
||||

|
||||
|
||||
Далее заполняем данные страницы вики:
|
||||

|
||||
|
||||
И завершаем установку путем скачивания и открытия файла настроек страницы:
|
||||

|
||||
|
||||
## Разворачивание сервиса Wordpress
|
||||
|
||||
Также в файл `docker-compose.yml` в папке Wordpress прописываем следующий код:
|
||||
|
||||
```yaml
|
||||
version: '3.1'
|
||||
#Задаем контейнеры
|
||||
services:
|
||||
#Контейнер Wordpress
|
||||
wordpress:
|
||||
image: wordpress #образ
|
||||
restart: always
|
||||
ports: #на каком порте запускаем
|
||||
- 8080:80
|
||||
environment: #настройки БД вордпресса для подключения к серверу
|
||||
WORDPRESS_DB_HOST: db
|
||||
WORDPRESS_DB_USER: exampleuser
|
||||
WORDPRESS_DB_PASSWORD: examplepass
|
||||
WORDPRESS_DB_NAME: exampledb
|
||||
volumes: #каталог хранения файлов сервиса
|
||||
- wordpress:/var/www/html
|
||||
|
||||
db: #Контейнер MySQL
|
||||
image: mysql:5.7 #образ и его версия
|
||||
restart: always
|
||||
environment: #настройки БД для подключения
|
||||
MYSQL_DATABASE: exampledb
|
||||
MYSQL_USER: exampleuser
|
||||
MYSQL_PASSWORD: examplepass
|
||||
MYSQL_RANDOM_ROOT_PASSWORD: '1'
|
||||
volumes: #каталог хранения данных БД
|
||||
- db:/var/lib/mysql
|
||||
|
||||
volumes:
|
||||
wordpress:
|
||||
db:
|
||||
```
|
||||
|
||||
Через командную строку разворачиваем сервис:
|
||||

|
||||
|
||||
В Docker Desktop проверяем, что оба контейнера запущены:
|
||||

|
||||
|
||||
Теперь переходим на http://localhost:8080:
|
||||

|
||||
|
||||
И устанавливаем Wordpress:
|
||||

|
||||
|
||||
Далее осуществляем вход и попадаем на главную страницу, что говорит об успешной установке:
|
||||

|
||||

|
||||
|
||||
## Разворачивание сервиса Redmine
|
||||
|
||||
Содержимое файла `docker-compose.yml` в папке Redmine:
|
||||
|
||||
```yaml
|
||||
version: '3.1'
|
||||
#Задаем контейнеры
|
||||
services:
|
||||
#Контейнер Redmine
|
||||
redmine:
|
||||
image: redmine #образ
|
||||
restart: always
|
||||
ports: #на какой порт запускать
|
||||
- 8082:3000
|
||||
environment:
|
||||
REDMINE_DB_MYSQL: db
|
||||
REDMINE_DB_PASSWORD: example
|
||||
REDMINE_SECRET_KEY_BASE: supersecretkey
|
||||
#Контейнер базы данных MySQL
|
||||
db:
|
||||
image: mysql:5.7 #образ и версия
|
||||
restart: always
|
||||
environment: #название и пароль админа БД
|
||||
MYSQL_ROOT_PASSWORD: example
|
||||
MYSQL_DATABASE: redmine
|
||||
```
|
||||
Далее в командной строке разворачиваем сервис командой `docker-compose up`:
|
||||

|
||||
|
||||
В Docker Desktop проверяем, что работают все три развернутых сервиса:
|
||||

|
||||
|
||||
Переходим на http://localhost:8082:
|
||||

|
||||
|
||||
Здесь мы можем выполнить вход как администратор или зарегистрироваться как пользователь. Попробуем зарегистрироваться:
|
||||

|
||||
|
||||
Теперь попробуем войти в качестве пользователя:
|
||||

|
||||
И получаем ответ, что мы не можем этого сделать без подтверждения учетной записи админом.
|
||||
|
||||
Заходим в качестве администратора под логином и паролем admin/admin:
|
||||

|
||||
|
||||
И попадаем в профиль администратора:
|
||||

|
||||
|
||||
И так как мы являемся администратором, то в разделе администрирование/пользователи, мы можем подтвердить созданного нами ранее пользователя:
|
||||

|
||||
|
Before Width: | Height: | Size: 86 KiB |
|
Before Width: | Height: | Size: 130 KiB |
|
Before Width: | Height: | Size: 102 KiB |
|
Before Width: | Height: | Size: 126 KiB |
|
Before Width: | Height: | Size: 69 KiB |
|
Before Width: | Height: | Size: 226 KiB |
|
Before Width: | Height: | Size: 117 KiB |
|
Before Width: | Height: | Size: 137 KiB |
|
Before Width: | Height: | Size: 72 KiB |
|
Before Width: | Height: | Size: 90 KiB |
|
Before Width: | Height: | Size: 84 KiB |
|
Before Width: | Height: | Size: 170 KiB |
|
Before Width: | Height: | Size: 84 KiB |
|
Before Width: | Height: | Size: 151 KiB |
|
Before Width: | Height: | Size: 140 KiB |
|
Before Width: | Height: | Size: 130 KiB |
|
Before Width: | Height: | Size: 204 KiB |
|
Before Width: | Height: | Size: 55 KiB |
|
Before Width: | Height: | Size: 90 KiB |
|
Before Width: | Height: | Size: 151 KiB |
|
Before Width: | Height: | Size: 300 KiB |
|
Before Width: | Height: | Size: 190 KiB |
|
Before Width: | Height: | Size: 74 KiB |
@@ -1,6 +1,6 @@
|
||||
# Отчёт по лабораторной работе №1
|
||||
|
||||
Выполнил: студентка группы ИСЭБД-41 Клементьева Жанна.
|
||||
Выполнил: студент гр. ИСЭБД-41 Клементьева Жанна.
|
||||
|
||||
## Разворачивание сервера Wordpress
|
||||
|
||||
@@ -22,7 +22,7 @@ services: # Описание контейнеров
|
||||
MYSQL_PASSWORD: wordpress
|
||||
networks: # Параметры сети
|
||||
- wpsite
|
||||
|
||||
|
||||
wordpress: # Контейнер с Wordpress
|
||||
depends_on: # Параметр зависимости от работы базы данных (в данном случае)
|
||||
- db
|
||||
@@ -47,14 +47,14 @@ volumes:
|
||||
|
||||
Убеждаемся, что всё работает, прописываем в браузере "localhost:8000", так как docker-compose.yaml мы указали порт 8000:
|
||||
|
||||

|
||||

|
||||
|
||||

|
||||

|
||||
|
||||
Открывается стартовое окно Wordpress, где мы можем выбрать язык и приступить к работе, если это потребуется:
|
||||

|
||||

|
||||
|
||||

|
||||

|
||||
|
||||
|
||||
|
||||
@@ -92,7 +92,7 @@ services: # Описание служб (контейнеров).
|
||||
- /etc/timezone:/etc/timezone:ro
|
||||
- /etc/localtime:/etc/localtime:ro
|
||||
ports: # Порты, проложенные из контейнера в хост
|
||||
- "3000:80"
|
||||
- "3000:80"
|
||||
- "222:22"
|
||||
depends_on: # Параметр зависимости от работы базы данных (в данном случае)
|
||||
- db
|
||||
@@ -115,7 +115,7 @@ services: # Описание служб (контейнеров).
|
||||
|
||||
Убеждаемся, что всё работает, прописываем в браузере "localhost:3000", так как docker-compose.yaml мы указали порт 3000. Открывается стартовое окно Gitea, где мы можем настроить систему и приступить к работе, если это потребуется:
|
||||
|
||||

|
||||

|
||||
|
||||
Удаляется всё командой `docker-compose down` или `docker-compose down -v`.
|
||||
|
||||
@@ -153,6 +153,6 @@ services: # Описание контейнеров
|
||||
|
||||
Убеждаемся, что всё работает, прописываем в браузере "localhost:9999", так как docker-compose.yaml мы указали порт 9999. Открывается стартовое окно Mediawiki, где мы можем настроить систему и приступить к работе, если это потребуется:
|
||||
|
||||

|
||||

|
||||
|
||||
Удаляется всё командой `docker-compose down` или `docker-compose down -v`.
|
||||
|
||||
|
Before Width: | Height: | Size: 38 KiB |
|
Before Width: | Height: | Size: 60 KiB |
|
Before Width: | Height: | Size: 71 KiB |
|
Before Width: | Height: | Size: 1.8 KiB |
|
Before Width: | Height: | Size: 8.3 KiB |
@@ -1,7 +1,3 @@
|
||||
## Наши данные для работы программы
|
||||
result-1/
|
||||
result/
|
||||
|
||||
## Ignore Visual Studio temporary files, build results, and
|
||||
## files generated by popular Visual Studio add-ons.
|
||||
##
|
||||
@@ -1,15 +1,15 @@
|
||||
# Отчёт по лабораторной работе №1
|
||||
# Отчёт по лабораторной работе №2
|
||||
|
||||
Выполнил: студент гр. ИСТбд-41 Моисеев Владислав.
|
||||
Выполнил: студентка гр. ИСЭбд-41 Клементьева Жанна.
|
||||
|
||||
Вариант программы 1: Формирует файл `/var/result/data.txt` из содержимого всех файлов каталога `/var/data`.
|
||||
Вариант программы 1: Ищет в каталоге `/var/data` файл с наибольшим количеством строк и перекладывает его в `/var/result/data.txt`.
|
||||
|
||||
Вариант программы 2: Сохраняет сумму чисел из файла `/var/data/data.txt` в `/var/result/result.txt`.
|
||||
Вариант программы 2: Ищет наименьшее число из файла `/var/data/data.txt` и сохраняет количество таких чисел из последовательности в `/var/result/result.txt`.
|
||||
|
||||
## Создание приложений
|
||||
|
||||
Создадим 2 приложения.
|
||||
Был выбран язык C# и технология .NET 7, потому что хочется.
|
||||
Был выбран язык C# и технология .NET 6, потому что потому.
|
||||
|
||||
Для создания обычных консольных приложений воспользуемся командами:
|
||||
|
||||
@@ -18,12 +18,11 @@ dotnet new console -o worker-1
|
||||
dotnet new console -o worker-2
|
||||
```
|
||||
|
||||
Согласно варианту программа 1 должна брать все файлы из папки `/var/data`, считывать оттуда строки и укладывать их в файл `/var/result/data.txt`.
|
||||
Согласно варианту программа 1 ищет в каталоге `/var/data` файл с наибольшим количеством строк и перекладывает его в `/var/result/data.txt`.
|
||||
|
||||
[Исходный текст программы worker-1](worker-1/Program.cs)
|
||||
|
||||
Согласно варианту программа 2 должна брать строки из файла `/var/data/data.txt`, пытаться привести их к числам, а затем заниматься их сложением.
|
||||
Затем результат вычислений копируется в файл `/var/result/result.txt`.
|
||||
Согласно варианту программа 2 ищет наименьшее число из файла `/var/data/data.txt` и сохраняет количество таких чисел из последовательности в `/var/result/result.txt`.
|
||||
|
||||
[Исходный текст программы worker-2](worker-2/Program.cs)
|
||||
|
||||
@@ -42,16 +41,16 @@ dotnet new console -o worker-2
|
||||
4. Каталог `./result` должен быть примонтирован в каталог `/var/result` для программы 2.
|
||||
Туда будут складывать результаты финальной обработки.
|
||||
|
||||
Для каждой программы были созданы файлы Dockerfile ([программа 1](worker-1/Dockerfile), [программа 2](worker-1/Dockerfile)) с подробным описанием процесса сборки.
|
||||
Для каждой программы были созданы файлы Dockerfile ([программа 1](worker-1/Dockerfile.yml), [программа 2](worker-1/Dockerfile.yml)) с подробным описанием процесса сборки.
|
||||
|
||||
Был создан файл [docker-compose.yml](docker-compose.yml), в котором указан манифест для запуска распределённого приложения.
|
||||
|
||||
Дополнительно был создан файл [.dockerignore](.dockerignore) и дополнен [.gitignore](.gitignore), чтобы исключить для сборки и коммита всё лишнее.
|
||||
Дополнительно был создан файл [.gitignore](.gitignore), чтобы исключить для сборки и коммита всё лишнее.
|
||||
|
||||
## Сборка и запуск
|
||||
|
||||
В каталог `./data` помещены 2 файла.
|
||||
Сумма чисел в первом - 10, во втором - 40.
|
||||
В первом файле были числа 1 2 3, во втором 1 1 7 5 3 1.
|
||||
|
||||
Для запуска приложения необходимо ввести команду `docker compose up ---build`.
|
||||
|
||||
@@ -69,6 +68,8 @@ lab_2-worker-2-1 | Чисел для обработки: 8
|
||||
lab_2-worker-2-1 exited with code 0
|
||||
```
|
||||
|
||||
В результате в каталоге `./result` создался файл `result.txt` с содержимым `50`, что соответствует входным данным.
|
||||
В результате в каталоге `./result` создался файл `result.txt` с содержимым `3`, что соответствует входным данным.
|
||||
|
||||
Изменение значений в файлах из каталога `./data` также изменяет содержимое в файлах из каталогов `./result-1` и `./result`.
|
||||
|
||||

|
||||
16
tasks/klementeva-ja/lab_2/docker-compose.yml
Normal file
@@ -0,0 +1,16 @@
|
||||
version: "3.1"
|
||||
services:
|
||||
worker-1:
|
||||
build: ./worker-1
|
||||
volumes:
|
||||
#монтируем локальную папку в запущенный образ контейнера
|
||||
- ./data:/var/data
|
||||
- ./result-1:/var/result
|
||||
worker-2:
|
||||
build: ./worker-2
|
||||
volumes:
|
||||
- ./result-1:/var/data
|
||||
- ./result:/var/result
|
||||
#добавляется зависимость, так как по условию второе приложение зависит от первого
|
||||
depends_on:
|
||||
- worker-1
|
||||
BIN
tasks/klementeva-ja/lab_2/resultat.png
Normal file
|
After Width: | Height: | Size: 3.8 KiB |
31
tasks/klementeva-ja/lab_2/rvip_j2.sln
Normal file
@@ -0,0 +1,31 @@
|
||||
|
||||
Microsoft Visual Studio Solution File, Format Version 12.00
|
||||
# Visual Studio Version 17
|
||||
VisualStudioVersion = 17.5.002.0
|
||||
MinimumVisualStudioVersion = 10.0.40219.1
|
||||
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "worker-1", "worker-1\worker-1.csproj", "{F6B29C3F-FC5C-4B48-A594-4B9316A21F56}"
|
||||
EndProject
|
||||
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "worker-2", "worker-2\worker-2.csproj", "{B18DF6BB-6783-4F53-A5EE-140D07BF447C}"
|
||||
EndProject
|
||||
Global
|
||||
GlobalSection(SolutionConfigurationPlatforms) = preSolution
|
||||
Debug|Any CPU = Debug|Any CPU
|
||||
Release|Any CPU = Release|Any CPU
|
||||
EndGlobalSection
|
||||
GlobalSection(ProjectConfigurationPlatforms) = postSolution
|
||||
{F6B29C3F-FC5C-4B48-A594-4B9316A21F56}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
|
||||
{F6B29C3F-FC5C-4B48-A594-4B9316A21F56}.Debug|Any CPU.Build.0 = Debug|Any CPU
|
||||
{F6B29C3F-FC5C-4B48-A594-4B9316A21F56}.Release|Any CPU.ActiveCfg = Release|Any CPU
|
||||
{F6B29C3F-FC5C-4B48-A594-4B9316A21F56}.Release|Any CPU.Build.0 = Release|Any CPU
|
||||
{B18DF6BB-6783-4F53-A5EE-140D07BF447C}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
|
||||
{B18DF6BB-6783-4F53-A5EE-140D07BF447C}.Debug|Any CPU.Build.0 = Debug|Any CPU
|
||||
{B18DF6BB-6783-4F53-A5EE-140D07BF447C}.Release|Any CPU.ActiveCfg = Release|Any CPU
|
||||
{B18DF6BB-6783-4F53-A5EE-140D07BF447C}.Release|Any CPU.Build.0 = Release|Any CPU
|
||||
EndGlobalSection
|
||||
GlobalSection(SolutionProperties) = preSolution
|
||||
HideSolutionNode = FALSE
|
||||
EndGlobalSection
|
||||
GlobalSection(ExtensibilityGlobals) = postSolution
|
||||
SolutionGuid = {D0BD68D2-E574-457E-B29C-4A1167DE76D6}
|
||||
EndGlobalSection
|
||||
EndGlobal
|
||||
3
tasks/klementeva-ja/lab_2/var/data/anotherData.txt
Normal file
@@ -0,0 +1,3 @@
|
||||
1
|
||||
2
|
||||
3
|
||||
6
tasks/klementeva-ja/lab_2/var/data/data.txt
Normal file
@@ -0,0 +1,6 @@
|
||||
1
|
||||
1
|
||||
7
|
||||
5
|
||||
3
|
||||
1
|
||||
@@ -1,4 +1,5 @@
|
||||
1
|
||||
2
|
||||
3
|
||||
4
|
||||
4
|
||||
5
|
||||
1
tasks/klementeva-ja/lab_2/var/result/result.txt
Normal file
@@ -0,0 +1 @@
|
||||
3147483647
|
||||
15
tasks/klementeva-ja/lab_2/worker-1/Dockerfile
Normal file
@@ -0,0 +1,15 @@
|
||||
#указываем образ из которого будем брать все слои
|
||||
FROM mcr.microsoft.com/dotnet/sdk:6.0 AS build-env
|
||||
#папка, с которой мы будем работать
|
||||
WORKDIR /App
|
||||
#копируем файл в рабочую дерикторию
|
||||
COPY . ./
|
||||
#запускаем команду
|
||||
RUN dotnet restore
|
||||
RUN dotnet publish -c Release -o out
|
||||
|
||||
FROM mcr.microsoft.com/dotnet/aspnet:6.0
|
||||
WORKDIR /App
|
||||
#копирует не из файловой системы хоста, а из того, что собрали на прерыдущей стадии
|
||||
COPY --from=build-env /App/out .
|
||||
ENTRYPOINT ["dotnet", "worker-1.dll"]
|
||||
13
tasks/klementeva-ja/lab_2/worker-1/Program.cs
Normal file
@@ -0,0 +1,13 @@
|
||||
var files = Directory.GetFiles("/var/data");
|
||||
int maxCount = 0;
|
||||
string lagrestFile = "";
|
||||
foreach(var file in files){
|
||||
var lines = File.ReadAllLines(file);
|
||||
if(lines.Count() > maxCount){
|
||||
maxCount = lines.Count();
|
||||
lagrestFile = file;
|
||||
}
|
||||
}
|
||||
if(File.Exists("/var/result/data.txt"))
|
||||
File.Delete("/var/result/data.txt");
|
||||
File.Move(lagrestFile, "/var/result/data.txt");
|
||||
@@ -2,7 +2,7 @@
|
||||
|
||||
<PropertyGroup>
|
||||
<OutputType>Exe</OutputType>
|
||||
<TargetFramework>net7.0</TargetFramework>
|
||||
<TargetFramework>net6.0</TargetFramework>
|
||||
<RootNamespace>worker_1</RootNamespace>
|
||||
<ImplicitUsings>enable</ImplicitUsings>
|
||||
<Nullable>enable</Nullable>
|
||||
15
tasks/klementeva-ja/lab_2/worker-2/Dockerfile
Normal file
@@ -0,0 +1,15 @@
|
||||
#указываем образ из которого будем брать все слои
|
||||
FROM mcr.microsoft.com/dotnet/sdk:6.0 AS build-env
|
||||
#папка, с которой мы будем работать
|
||||
WORKDIR /App
|
||||
#копируем файл в рабочую дерикторию
|
||||
COPY . ./
|
||||
#запускаем команду
|
||||
RUN dotnet restore
|
||||
RUN dotnet publish -c Release -o out
|
||||
|
||||
FROM mcr.microsoft.com/dotnet/aspnet:6.0
|
||||
WORKDIR /App
|
||||
#копирует не из файловой системы хоста, а из того, что собрали на прерыдущей стадии
|
||||
COPY --from=build-env /App/out .
|
||||
ENTRYPOINT ["dotnet", "worker-2.dll"]
|
||||
23
tasks/klementeva-ja/lab_2/worker-2/Program.cs
Normal file
@@ -0,0 +1,23 @@
|
||||
using System.Text;
|
||||
|
||||
int[] numbers = File.ReadAllLines("/var/data/data.txt").Select(x=> int.Parse(x)).ToArray();
|
||||
int minNumber = int.MaxValue;
|
||||
int minNumberCount = 0;
|
||||
foreach(var number in numbers){
|
||||
if(number > minNumber){
|
||||
continue;
|
||||
}
|
||||
if(number == minNumber){
|
||||
minNumberCount++;
|
||||
continue;
|
||||
}
|
||||
if(number < minNumber){
|
||||
minNumber = number;
|
||||
minNumberCount = 1;
|
||||
}
|
||||
}
|
||||
using(FileStream fstream = new FileStream("/var/result/result.txt", FileMode.OpenOrCreate)){
|
||||
byte[] buffer = Encoding.Default.GetBytes(minNumberCount.ToString());
|
||||
await fstream.WriteAsync(buffer, 0, buffer.Length);
|
||||
}
|
||||
Console.WriteLine(minNumberCount);
|
||||
@@ -2,7 +2,7 @@
|
||||
|
||||
<PropertyGroup>
|
||||
<OutputType>Exe</OutputType>
|
||||
<TargetFramework>net7.0</TargetFramework>
|
||||
<TargetFramework>net6.0</TargetFramework>
|
||||
<RootNamespace>worker_2</RootNamespace>
|
||||
<ImplicitUsings>enable</ImplicitUsings>
|
||||
<Nullable>enable</Nullable>
|
||||
226
tasks/klementeva-ja/lab_3/.gitignore
vendored
Normal file
@@ -0,0 +1,226 @@
|
||||
# The following command works for downloading when using Git for Windows:
|
||||
# curl -LOf http://gist.githubusercontent.com/kmorcinek/2710267/raw/.gitignore
|
||||
#
|
||||
# Download this file using PowerShell v3 under Windows with the following comand:
|
||||
# Invoke-WebRequest https://gist.githubusercontent.com/kmorcinek/2710267/raw/ -OutFile .gitignore
|
||||
#
|
||||
# or wget:
|
||||
# wget --no-check-certificate http://gist.githubusercontent.com/kmorcinek/2710267/raw/.gitignore
|
||||
|
||||
# User-specific files
|
||||
*.suo
|
||||
*.user
|
||||
*.sln.docstates
|
||||
|
||||
# Build results
|
||||
[Dd]ebug/
|
||||
[Rr]elease/
|
||||
x64/
|
||||
[Bb]in/
|
||||
[Oo]bj/
|
||||
# build folder is nowadays used for build scripts and should not be ignored
|
||||
#build/
|
||||
|
||||
# NuGet Packages
|
||||
*.nupkg
|
||||
# The packages folder can be ignored because of Package Restore
|
||||
**/packages/*
|
||||
# except build/, which is used as an MSBuild target.
|
||||
!**/packages/build/
|
||||
# Uncomment if necessary however generally it will be regenerated when needed
|
||||
#!**/packages/repositories.config
|
||||
|
||||
# MSTest test Results
|
||||
[Tt]est[Rr]esult*/
|
||||
[Bb]uild[Ll]og.*
|
||||
|
||||
*_i.c
|
||||
*_p.c
|
||||
*.ilk
|
||||
*.meta
|
||||
*.obj
|
||||
*.pch
|
||||
*.pdb
|
||||
*.pgc
|
||||
*.pgd
|
||||
*.rsp
|
||||
*.sbr
|
||||
*.tlb
|
||||
*.tli
|
||||
*.tlh
|
||||
*.tmp
|
||||
*.tmp_proj
|
||||
*.log
|
||||
*.vspscc
|
||||
*.vssscc
|
||||
.builds
|
||||
*.pidb
|
||||
*.scc
|
||||
|
||||
# Visual C++ cache files
|
||||
ipch/
|
||||
*.aps
|
||||
*.ncb
|
||||
*.opensdf
|
||||
*.sdf
|
||||
*.cachefile
|
||||
|
||||
# Visual Studio profiler
|
||||
*.psess
|
||||
*.vsp
|
||||
*.vspx
|
||||
|
||||
# Guidance Automation Toolkit
|
||||
*.gpState
|
||||
|
||||
# ReSharper is a .NET coding add-in
|
||||
_ReSharper*/
|
||||
*.[Rr]e[Ss]harper
|
||||
|
||||
# TeamCity is a build add-in
|
||||
_TeamCity*
|
||||
|
||||
# DotCover is a Code Coverage Tool
|
||||
*.dotCover
|
||||
|
||||
# NCrunch
|
||||
*.ncrunch*
|
||||
.*crunch*.local.xml
|
||||
|
||||
# Installshield output folder
|
||||
[Ee]xpress/
|
||||
|
||||
# DocProject is a documentation generator add-in
|
||||
DocProject/buildhelp/
|
||||
DocProject/Help/*.HxT
|
||||
DocProject/Help/*.HxC
|
||||
DocProject/Help/*.hhc
|
||||
DocProject/Help/*.hhk
|
||||
DocProject/Help/*.hhp
|
||||
DocProject/Help/Html2
|
||||
DocProject/Help/html
|
||||
|
||||
# Click-Once directory
|
||||
publish/
|
||||
|
||||
# Publish Web Output
|
||||
*.Publish.xml
|
||||
|
||||
# Windows Azure Build Output
|
||||
csx
|
||||
*.build.csdef
|
||||
|
||||
# Windows Store app package directory
|
||||
AppPackages/
|
||||
|
||||
# Others
|
||||
*.Cache
|
||||
ClientBin/
|
||||
[Ss]tyle[Cc]op.*
|
||||
~$*
|
||||
*~
|
||||
*.dbmdl
|
||||
*.[Pp]ublish.xml
|
||||
*.pfx
|
||||
*.publishsettings
|
||||
modulesbin/
|
||||
tempbin/
|
||||
|
||||
# EPiServer Site file (VPP)
|
||||
AppData/
|
||||
|
||||
# RIA/Silverlight projects
|
||||
Generated_Code/
|
||||
|
||||
# Backup & report files from converting an old project file to a newer
|
||||
# Visual Studio version. Backup files are not needed, because we have git ;-)
|
||||
_UpgradeReport_Files/
|
||||
Backup*/
|
||||
UpgradeLog*.XML
|
||||
UpgradeLog*.htm
|
||||
|
||||
# vim
|
||||
*.txt~
|
||||
*.swp
|
||||
*.swo
|
||||
|
||||
# Temp files when opening LibreOffice on ubuntu
|
||||
.~lock.*
|
||||
|
||||
# svn
|
||||
.svn
|
||||
|
||||
# CVS - Source Control
|
||||
**/CVS/
|
||||
|
||||
# Remainings from resolving conflicts in Source Control
|
||||
*.orig
|
||||
|
||||
# SQL Server files
|
||||
**/App_Data/*.mdf
|
||||
**/App_Data/*.ldf
|
||||
**/App_Data/*.sdf
|
||||
|
||||
|
||||
#LightSwitch generated files
|
||||
GeneratedArtifacts/
|
||||
_Pvt_Extensions/
|
||||
ModelManifest.xml
|
||||
|
||||
# =========================
|
||||
# Windows detritus
|
||||
# =========================
|
||||
|
||||
# Windows image file caches
|
||||
Thumbs.db
|
||||
ehthumbs.db
|
||||
|
||||
# Folder config file
|
||||
Desktop.ini
|
||||
|
||||
# Recycle Bin used on file shares
|
||||
$RECYCLE.BIN/
|
||||
|
||||
# OS generated files #
|
||||
Icon?
|
||||
|
||||
# Mac desktop service store files
|
||||
.DS_Store
|
||||
|
||||
# SASS Compiler cache
|
||||
.sass-cache
|
||||
|
||||
# Visual Studio 2014 CTP
|
||||
**/*.sln.ide
|
||||
|
||||
# Visual Studio temp something
|
||||
.vs/
|
||||
|
||||
# dotnet stuff
|
||||
project.lock.json
|
||||
|
||||
# VS 2015+
|
||||
*.vc.vc.opendb
|
||||
*.vc.db
|
||||
|
||||
# Rider
|
||||
.idea/
|
||||
|
||||
# Visual Studio Code
|
||||
.vscode/
|
||||
|
||||
# Output folder used by Webpack or other FE stuff
|
||||
**/node_modules/*
|
||||
**/wwwroot/*
|
||||
|
||||
# SpecFlow specific
|
||||
*.feature.cs
|
||||
*.feature.xlsx.*
|
||||
*.Specs_*.html
|
||||
|
||||
# UWP Projects
|
||||
AppPackages/
|
||||
|
||||
#####
|
||||
# End of core ignore list, below put you custom 'per project' settings (patterns or path)
|
||||
#####
|
||||
76
tasks/klementeva-ja/lab_3/README.md
Normal file
@@ -0,0 +1,76 @@
|
||||
# Отчет по лабораторной работе №3 REST API, Gateway и синхронный обмен между микросервисами
|
||||
Выполнила студентка гр. ИСЭбд-41 Клементьева Ж.А.
|
||||
|
||||
## Создание микросервисов
|
||||
Создание микросервисов было реализовано следующим образом:
|
||||
|
||||
1. С помощью команды `dotnet new web -n worker-2` в терминале создала первый микросервис, где решение добавила командой `dotnet new sln`.
|
||||
2. Также использовала данную команду: `dotnet sln worker-2.sln add worker-2.csproj` с целью связки решения и проекта.
|
||||
3. Аналогичные действия были совершены со вторым микросервисом.
|
||||
4. Были добавлены библиотеки Swagger и OpenAi в проекты.
|
||||
5. Также проект был запущен с помощью команды `dotnet run`.
|
||||
|
||||
Скриншоты микросервисов worker 1 и worker 2:
|
||||

|
||||

|
||||
|
||||
Путь localhost:8080:
|
||||
|
||||

|
||||
|
||||
|
||||

|
||||
|
||||
## Синхронный обмен
|
||||
Также мною был реализован код, вызывающий сихронно данные из соседнего микросервиса.
|
||||
```cs
|
||||
//worker-2
|
||||
app.MapGet("/Requests/", async () =>
|
||||
{
|
||||
var httpClient = new HttpClient();
|
||||
var secondWorkerResponse = await httpClient.GetStringAsync("http://worker-1:8080/");
|
||||
|
||||
return secondWorkerResponse.ToArray();
|
||||
})
|
||||
.WithName("GetRequests")
|
||||
.WithOpenApi();
|
||||
```
|
||||
## Реализация gateway, используя nginx
|
||||
|
||||
Мною был добавлен nginx.conf:
|
||||
|
||||
```conf
|
||||
server {
|
||||
listen 8080;
|
||||
listen [::]:8080;
|
||||
server_name localhost;
|
||||
|
||||
location / {
|
||||
root /usr/share/nginx/html;
|
||||
index index.html index.htm;
|
||||
}
|
||||
|
||||
location /worker-1/ {
|
||||
proxy_pass http://worker-1:8080/;
|
||||
proxy_set_header Host $host;
|
||||
proxy_set_header X-Real-IP $remote_addr;
|
||||
proxy_set_header X-Forwarded-Proto $scheme;
|
||||
proxy_set_header X-Forwarded-Prefix /worker-1;
|
||||
}
|
||||
|
||||
location /worker-2/ {
|
||||
proxy_pass http://worker-2:8080/;
|
||||
proxy_set_header Host $host;
|
||||
proxy_set_header X-Real-IP $remote_addr;
|
||||
proxy_set_header X-Forwarded-Proto $scheme;
|
||||
proxy_set_header X-Forwarded-Prefix /worker-2;
|
||||
}
|
||||
}
|
||||
|
||||
```
|
||||
После выполнения команды `docker-compose up` были получены такие результаты:
|
||||
|
||||
Результат worker1:
|
||||

|
||||
Результат worker2:
|
||||

|
||||
15
tasks/klementeva-ja/lab_3/docker-compose.yml
Normal file
@@ -0,0 +1,15 @@
|
||||
version: "3.1"
|
||||
services:
|
||||
worker-1:
|
||||
build: ./worker-1
|
||||
worker-2:
|
||||
build: ./worker-2
|
||||
depends_on:
|
||||
- worker-1
|
||||
gateway:
|
||||
image: nginx:latest
|
||||
ports:
|
||||
- 8080:8080
|
||||
volumes:
|
||||
- ./static:/usr/share/nginx/html:ro
|
||||
- ./nginx.conf:/etc/nginx/conf.d/default.conf:ro
|
||||
26
tasks/klementeva-ja/lab_3/nginx.conf
Normal file
@@ -0,0 +1,26 @@
|
||||
server {
|
||||
listen 8080;
|
||||
listen [::]:8080;
|
||||
server_name localhost;
|
||||
|
||||
location / {
|
||||
root /usr/share/nginx/html;
|
||||
index index.html index.htm;
|
||||
}
|
||||
|
||||
location /worker-1/ {
|
||||
proxy_pass http://worker-1:8080/;
|
||||
proxy_set_header Host $host;
|
||||
proxy_set_header X-Real-IP $remote_addr;
|
||||
proxy_set_header X-Forwarded-Proto $scheme;
|
||||
proxy_set_header X-Forwarded-Prefix /worker-1;
|
||||
}
|
||||
|
||||
location /worker-2/ {
|
||||
proxy_pass http://worker-2:8080/;
|
||||
proxy_set_header Host $host;
|
||||
proxy_set_header X-Real-IP $remote_addr;
|
||||
proxy_set_header X-Forwarded-Proto $scheme;
|
||||
proxy_set_header X-Forwarded-Prefix /worker-2;
|
||||
}
|
||||
}
|
||||
BIN
tasks/klementeva-ja/lab_3/pic/1.png
Normal file
|
After Width: | Height: | Size: 41 KiB |
BIN
tasks/klementeva-ja/lab_3/pic/2.png
Normal file
|
After Width: | Height: | Size: 40 KiB |
BIN
tasks/klementeva-ja/lab_3/pic/3.png
Normal file
|
After Width: | Height: | Size: 3.3 KiB |
BIN
tasks/klementeva-ja/lab_3/pic/4.png
Normal file
|
After Width: | Height: | Size: 2.4 KiB |
BIN
tasks/klementeva-ja/lab_3/pic/5.png
Normal file
|
After Width: | Height: | Size: 78 KiB |
BIN
tasks/klementeva-ja/lab_3/pic/6.png
Normal file
|
After Width: | Height: | Size: 16 KiB |
13
tasks/klementeva-ja/lab_3/static/index.html
Normal file
@@ -0,0 +1,13 @@
|
||||
<!DOCTYPE html>
|
||||
<html lang="ru">
|
||||
<head>
|
||||
<meta charset="UTF-8">
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||
<title> Тестовое приложение по лабораторной работе №3 </title>
|
||||
</head>
|
||||
<body>
|
||||
<p>Клементьева Ж.А. ИСЭбд-41.</p>
|
||||
<p><a href="/worker-1/"> Запрос к worker-1</a></p>
|
||||
<p><a href="/worker-2/"> Запрос к worker-2</a></p>
|
||||
</body>
|
||||
</html>
|
||||
11
tasks/klementeva-ja/lab_3/worker-1/Dockerfile
Normal file
@@ -0,0 +1,11 @@
|
||||
FROM mcr.microsoft.com/dotnet/sdk:8.0 AS build-env
|
||||
WORKDIR /app
|
||||
|
||||
COPY . ./
|
||||
RUN dotnet restore
|
||||
RUN dotnet publish -c Release -o out
|
||||
|
||||
FROM mcr.microsoft.com/dotnet/aspnet:8.0
|
||||
WORKDIR /app
|
||||
COPY --from=build-env /app/out .
|
||||
ENTRYPOINT ["dotnet", "worker-1.dll"]
|
||||
124
tasks/klementeva-ja/lab_3/worker-1/Program.cs
Normal file
@@ -0,0 +1,124 @@
|
||||
List<Request> requests = new()
|
||||
{
|
||||
new Request() { Uuid= Guid.Parse("7184fa5f-b786-4478-863a-99cc000eb752"), Title = "Расход на внедрение системы менеджмента качества", SourceOfFunds = "Шуреков", Sum = 100000, IsCompleted = false },
|
||||
new Request() { Uuid= Guid.Parse("55a9aed1-218a-468e-92b9-99f6a6a34543"), Title = "Расход на сопровождение проекта", SourceOfFunds = "Клементьев", Sum = 25000, IsCompleted = true },
|
||||
};
|
||||
|
||||
var builder = WebApplication.CreateBuilder(args);
|
||||
|
||||
builder.Services.AddEndpointsApiExplorer();
|
||||
builder.Services.AddSwaggerGen();
|
||||
|
||||
var app = builder.Build();
|
||||
|
||||
if (app.Environment.IsDevelopment())
|
||||
{
|
||||
app.UseSwagger();
|
||||
app.UseSwaggerUI();
|
||||
}
|
||||
|
||||
app.UseHttpsRedirection();
|
||||
|
||||
app.MapGet("/", () =>
|
||||
{
|
||||
return requests.Select(r => new RequestEntityDto()
|
||||
{
|
||||
Uuid = r.Uuid,
|
||||
Title = r.Title,
|
||||
Sum = r.Sum,
|
||||
SourceOfFunds = r.SourceOfFunds,
|
||||
IsCompleted = r.IsCompleted,
|
||||
});
|
||||
})
|
||||
.WithName("GetRequests")
|
||||
.WithOpenApi();
|
||||
|
||||
app.MapGet("/{uuid}", (Guid uuid) =>
|
||||
{
|
||||
var request = requests.FirstOrDefault(r => r.Uuid == uuid);
|
||||
if (request == null)
|
||||
return Results.NotFound();
|
||||
return Results.Json(new RequestEntityDto()
|
||||
{
|
||||
Uuid = request.Uuid,
|
||||
Title = request.Title,
|
||||
Sum = request.Sum,
|
||||
SourceOfFunds = request.SourceOfFunds,
|
||||
IsCompleted = request.IsCompleted,
|
||||
});
|
||||
})
|
||||
.WithName("GetRequestByGUID")
|
||||
.WithOpenApi();
|
||||
|
||||
app.MapPost("/{title}/{sourceOfFunds}/{sum}/{isCompleted}", (string title, string sourceOfFunds, decimal sum, bool isCompleted) =>
|
||||
{
|
||||
Guid NewGuid = Guid.NewGuid();
|
||||
requests.Add(new Request() { Uuid = NewGuid, Title = (string)title, SourceOfFunds = (string)sourceOfFunds, Sum = (decimal)sum, IsCompleted = (bool)isCompleted});
|
||||
|
||||
var request = requests.FirstOrDefault(r => r.Uuid == NewGuid);
|
||||
if (request == null)
|
||||
return Results.NotFound();
|
||||
return Results.Json(new RequestEntityDto()
|
||||
{
|
||||
Uuid = request.Uuid,
|
||||
Title = request.Title,
|
||||
Sum = request.Sum,
|
||||
SourceOfFunds = request.SourceOfFunds,
|
||||
IsCompleted = request.IsCompleted,
|
||||
});
|
||||
})
|
||||
.WithName("PostRequest")
|
||||
.WithOpenApi();
|
||||
|
||||
app.MapPatch("/{uuid}/{title}/{sourceOfFunds}/{sum}/{isCompleted}", (Guid uuid, string ?title, string ?sourceOfFunds, decimal sum, bool isCompleted) =>
|
||||
{
|
||||
var request = requests.FirstOrDefault(r => r.Uuid == uuid);
|
||||
if (request == null)
|
||||
return Results.NotFound();
|
||||
if (title != null) request.Title = title;
|
||||
if (sourceOfFunds != ",") request.SourceOfFunds = sourceOfFunds;
|
||||
if (sum != request.Sum && sum != 0) request.Sum = sum;
|
||||
if (isCompleted != request.IsCompleted) request.IsCompleted = isCompleted;
|
||||
|
||||
return Results.Json(new RequestEntityDto()
|
||||
{
|
||||
Uuid = request.Uuid,
|
||||
Title = request.Title,
|
||||
Sum = request.Sum,
|
||||
SourceOfFunds = request.SourceOfFunds,
|
||||
IsCompleted = request.IsCompleted,
|
||||
});
|
||||
})
|
||||
.WithName("UpdateRequest")
|
||||
.WithOpenApi();
|
||||
|
||||
app.MapDelete("/{uuid}", (Guid uuid) =>
|
||||
{
|
||||
var request = requests.FirstOrDefault(r => r.Uuid == uuid);
|
||||
if (request == null)
|
||||
return Results.NotFound();
|
||||
requests.Remove(request);
|
||||
return Results.Json(new RequestEntityDto()
|
||||
{
|
||||
Uuid = request.Uuid,
|
||||
Title = request.Title,
|
||||
Sum = request.Sum,
|
||||
SourceOfFunds = request.SourceOfFunds,
|
||||
IsCompleted = request.IsCompleted,
|
||||
});
|
||||
})
|
||||
.WithName("DeleteRequestByGUID")
|
||||
.WithOpenApi();
|
||||
|
||||
app.Run();
|
||||
|
||||
public class Request
|
||||
{
|
||||
public Guid Uuid { get; set; }
|
||||
public string Title { get; set; } = string.Empty;
|
||||
public string SourceOfFunds { get; set; } = string.Empty;
|
||||
public decimal Sum { get; set; } = 0;
|
||||
public bool IsCompleted { get; set; }
|
||||
}
|
||||
|
||||
public class RequestEntityDto : Request { }
|
||||
@@ -0,0 +1,38 @@
|
||||
{
|
||||
"$schema": "http://json.schemastore.org/launchsettings.json",
|
||||
"iisSettings": {
|
||||
"windowsAuthentication": false,
|
||||
"anonymousAuthentication": true,
|
||||
"iisExpress": {
|
||||
"applicationUrl": "http://localhost:51956",
|
||||
"sslPort": 44303
|
||||
}
|
||||
},
|
||||
"profiles": {
|
||||
"http": {
|
||||
"commandName": "Project",
|
||||
"dotnetRunMessages": true,
|
||||
"launchBrowser": true,
|
||||
"applicationUrl": "http://localhost:5197",
|
||||
"environmentVariables": {
|
||||
"ASPNETCORE_ENVIRONMENT": "Development"
|
||||
}
|
||||
},
|
||||
"https": {
|
||||
"commandName": "Project",
|
||||
"dotnetRunMessages": true,
|
||||
"launchBrowser": true,
|
||||
"applicationUrl": "https://localhost:7027;http://localhost:5197",
|
||||
"environmentVariables": {
|
||||
"ASPNETCORE_ENVIRONMENT": "Development"
|
||||
}
|
||||
},
|
||||
"IIS Express": {
|
||||
"commandName": "IISExpress",
|
||||
"launchBrowser": true,
|
||||
"environmentVariables": {
|
||||
"ASPNETCORE_ENVIRONMENT": "Development"
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,8 @@
|
||||
{
|
||||
"Logging": {
|
||||
"LogLevel": {
|
||||
"Default": "Information",
|
||||
"Microsoft.AspNetCore": "Warning"
|
||||
}
|
||||
}
|
||||
}
|
||||
9
tasks/klementeva-ja/lab_3/worker-1/appsettings.json
Normal file
@@ -0,0 +1,9 @@
|
||||
{
|
||||
"Logging": {
|
||||
"LogLevel": {
|
||||
"Default": "Information",
|
||||
"Microsoft.AspNetCore": "Warning"
|
||||
}
|
||||
},
|
||||
"AllowedHosts": "*"
|
||||
}
|
||||
15
tasks/klementeva-ja/lab_3/worker-1/worker-1.csproj
Normal file
@@ -0,0 +1,15 @@
|
||||
<Project Sdk="Microsoft.NET.Sdk.Web">
|
||||
|
||||
<PropertyGroup>
|
||||
<TargetFramework>net8.0</TargetFramework>
|
||||
<Nullable>enable</Nullable>
|
||||
<ImplicitUsings>enable</ImplicitUsings>
|
||||
<RootNamespace>worker_1</RootNamespace>
|
||||
</PropertyGroup>
|
||||
|
||||
<ItemGroup>
|
||||
<PackageReference Include="Microsoft.AspNetCore.OpenApi" Version="8.0.0" />
|
||||
<PackageReference Include="Swashbuckle.AspNetCore" Version="6.5.0" />
|
||||
</ItemGroup>
|
||||
|
||||
</Project>
|
||||
22
tasks/klementeva-ja/lab_3/worker-1/worker-1.sln
Normal file
@@ -0,0 +1,22 @@
|
||||
|
||||
Microsoft Visual Studio Solution File, Format Version 12.00
|
||||
# Visual Studio Version 17
|
||||
VisualStudioVersion = 17.0.31903.59
|
||||
MinimumVisualStudioVersion = 10.0.40219.1
|
||||
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "worker-1", "worker-1.csproj", "{90F6C7BD-78E2-47C8-A702-DD47E74D3865}"
|
||||
EndProject
|
||||
Global
|
||||
GlobalSection(SolutionConfigurationPlatforms) = preSolution
|
||||
Debug|Any CPU = Debug|Any CPU
|
||||
Release|Any CPU = Release|Any CPU
|
||||
EndGlobalSection
|
||||
GlobalSection(SolutionProperties) = preSolution
|
||||
HideSolutionNode = FALSE
|
||||
EndGlobalSection
|
||||
GlobalSection(ProjectConfigurationPlatforms) = postSolution
|
||||
{90F6C7BD-78E2-47C8-A702-DD47E74D3865}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
|
||||
{90F6C7BD-78E2-47C8-A702-DD47E74D3865}.Debug|Any CPU.Build.0 = Debug|Any CPU
|
||||
{90F6C7BD-78E2-47C8-A702-DD47E74D3865}.Release|Any CPU.ActiveCfg = Release|Any CPU
|
||||
{90F6C7BD-78E2-47C8-A702-DD47E74D3865}.Release|Any CPU.Build.0 = Release|Any CPU
|
||||
EndGlobalSection
|
||||
EndGlobal
|
||||