forked from Alexey/DAS_2024_1
Compare commits
1 Commits
kuzarin_ma
...
balakhonov
| Author | SHA1 | Date | |
|---|---|---|---|
| 221f3e248b |
59
balakhonov_danila_lab_1/README.md
Normal file
59
balakhonov_danila_lab_1/README.md
Normal file
@@ -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-контейнерах.
|
||||
58
balakhonov_danila_lab_1/docker-compose.yaml
Normal file
58
balakhonov_danila_lab_1/docker-compose.yaml
Normal file
@@ -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
|
||||
@@ -1,14 +0,0 @@
|
||||
# Переменные для базы данных
|
||||
POSTGRES_TAG=latest # Берём последнююю версию postgres. Пока это не принципиально
|
||||
POSTGRES_DATA_DIR=./postgres-data
|
||||
POSTGRES_PASSWORD=postgres_password
|
||||
|
||||
# Переменные для Web gui для БД
|
||||
DB_GUI_IMAGE=adminer # Самый легковесный Web gui для postgres(и не только)
|
||||
DB_GUI_CONTEINER_PORT=8080
|
||||
|
||||
# Переменные для брокера сообщения RabbitMQ
|
||||
RABBIT_TAG=3.10.7-management # Тут есть встроенный Web интерфейс
|
||||
RABBIT_DATA_DIR=./rabbit-data
|
||||
RABBIT_USERNAME=user
|
||||
RABBIT_PASSWORD=password
|
||||
2
kuzarin_maxim_lab_1/.gitignore
vendored
2
kuzarin_maxim_lab_1/.gitignore
vendored
@@ -1,2 +0,0 @@
|
||||
postgres-data/
|
||||
rabbit-data/
|
||||
@@ -1,27 +0,0 @@
|
||||
# Лабораторная работа 1
|
||||
Данная работа посвящена работе с docker compose и поднятию сервисов, необходимых для последующего выполнения работ.
|
||||
## Описание
|
||||
В качестве сервисов были выбраны:
|
||||
- СУБД - Postgres
|
||||
- Web интерфейс для БД Postgres - Adminer
|
||||
- Брокер сообщений - RabbitMQ (+ Web интерфейс)
|
||||
## Запуск
|
||||
Для запуска лабораторной работы необходимо иметь запущенный движок Docker на устройстве.
|
||||
Необходимо перейти в папку, где располагается данный файл. Далее открыть терминал и ввести команду:
|
||||
```
|
||||
docker compose up -d
|
||||
```
|
||||
В данном случае флаг `-d` не обязателен. Он лишь позволит оставить консоль интерактивной (запускает все контейнеры в фоновом режиме).
|
||||
В случае, если в консоли отобразился подобный текст и появилась возможность вводить команды - сервисы успешно запущены.
|
||||
```
|
||||
[+] Running 4/4
|
||||
✔ Network kuzarin_maxim_lab_1_default Created 0.0s
|
||||
✔ Container kuzarin_maxim_lab_1-db-1 Started 0.7s
|
||||
✔ Container kuzarin_maxim_lab_1-rabbit-1 Started 0.7s
|
||||
✔ Container kuzarin_maxim_lab_1-db_web_gui-1 Started 0.7s
|
||||
```
|
||||
## Описание compose файла
|
||||
В docker-compose файле все уникальные строчки помечены комментариями. Они описывают их предназначения, и иногда обосновывают принятые решения.
|
||||
Так же комментарии присутствуют в файле .env, где хранятся переменные среды, нужные для работы compose файла.
|
||||
## Видео демонстрация
|
||||
Был записан видеоролик, демонстрирующий процесс запуска и работы сервисов. Он расположен по [адресу](https://drive.google.com/file/d/1ouUc-3eYhaJIR0HhD4b_Lj73oxEqORpA/view?usp=sharing)
|
||||
@@ -1,31 +0,0 @@
|
||||
services:
|
||||
db: # База данных
|
||||
image: postgres:${POSTGRES_TAG} # Берём тег образа из переменной среды
|
||||
restart: always # Автоматический перезапуск контейнера, если он упал
|
||||
ports: # проброс портов
|
||||
- 5432:5432 # Так как на хосте нет postgres, порт по умолчанию можно использовать свободно
|
||||
volumes: # Указываем проброс папок
|
||||
- ${POSTGRES_DATA_DIR}:/var/lib/postgresql/data # Данные postgres хранятся в /var/lib/postgresql/data.
|
||||
# А на хосте монтируем туда, куда указано в переменной
|
||||
environment: # Указываем переменные среды
|
||||
POSTGRES_PASSWORD: ${POSTGRES_PASSWORD} # Пароль от учётки postgres берём из переменных среды
|
||||
|
||||
db_web_gui: # Интерфейс для доступа к БД (на компе нет PgAdmin)
|
||||
image: ${DB_GUI_IMAGE} # Их есть много разных, так что имя образа из env
|
||||
restart: always
|
||||
ports:
|
||||
- 8080:${DB_GUI_CONTEINER_PORT} # Так как Web GUI разные, то и порт может быть разный. Берём из env
|
||||
|
||||
rabbit: # Rabbit тоже понадобится в будущем
|
||||
image: rabbitmq:${RABBIT_TAG} # Определяем тегом версию
|
||||
restart: always
|
||||
ports:
|
||||
- 5672:5672 # Это порт доступа к брокеру (если буду разрабатывать на локале)
|
||||
- 8081:15672 # А это порт для Web GUI. Для удобста на хосте это 8081, близко к БД
|
||||
volumes:
|
||||
- ${RABBIT_DATA_DIR}:/var/lib/rabbitmq # У Rabbit так же можно пробросить папку, чтобы не терять данные
|
||||
environment:
|
||||
RABBITMQ_DEFAULT_USER: ${RABBIT_USERNAME} # Логин для пользователя Rabbit Берём из env
|
||||
RABBITMQ_DEFAULT_PASS: ${RABBIT_PASSWORD} # Пароль для пользователя Rabbit. Берём из env
|
||||
|
||||
|
||||
Reference in New Issue
Block a user