Docker Compose — это инструмент, который позволяет определять и настраивать многоконтейнерные приложения Docker. Он использует файл YAML для настройки контейнеров, сетей и томов приложения.
Compose можно использовать для различных целей. Развертывание приложений с одним хостом, автоматическое тестирование и локальная разработка — самые популярные варианты использования Docker Compose.
В этом руководстве будет рассмотрен процесс установки последней версии Docker Compose на Debian 9. Мы также рассмотрим основные концепции и команды Docker Compose.
Содержание
Подготовка
Прежде чем продолжить изучение этого руководства, убедитесь, что вы выполнили следующие предварительные требования:
- Вы вошли в систему как пользователь с привилегиями sudo .
- Установите Docker на свой компьютер Debian 9 .
Установите Docker Compose в Debian
Установочный пакет Docker Compose доступен в официальных репозиториях Debian 9, но он не всегда может быть последней версией. Рекомендуемый подход — установить Docker Compose из репозитория Docker GitHub.
На момент написания этой статьи последней стабильной версией Docker Compose была версия 1.23.1
. Перед загрузкой двоичного файла Compose посетите страницу выпуска репозитория Compose на GitHub и проверьте, доступна ли для загрузки новая версия.
Выполните следующие шаги, чтобы установить последнюю версию Docker Compose в Debian 9:
-
Начните с загрузки двоичного файла Docker Compose в каталог
/usr/local/bin
используя следующую командуcurl
:sudo curl -L "https://github.com/docker/compose/releases/download/1.23.1/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
-
Когда загрузка будет завершена, дайте исполняемые разрешения для двоичного файла Compose:
sudo chmod +x /usr/local/bin/docker-compose
-
Проверьте установку, набрав:
docker-compose --version
Результат будет выглядеть примерно так:
docker-compose version 1.23.1, build b02f1306
Начало работы с Docker Compose
В этом разделе мы покажем, как использовать Docker Compose для управления стеком WordPress на вашем компьютере Debian 9.
Начните с создания каталога для проекта и перехода в него :
mkdir wordpress_app
cd wordpress_app
Откройте текстовый редактор и создайте файл с именем docker-compose.yml
в каталоге проекта:
nano docker-compose.yml
Вставьте следующий контент:
version: '3.3'
services:
db:
image: mysql:5.7
restart: always
volumes:
- db_data:/var/lib/mysql
environment:
MYSQL_ROOT_PASSWORD: password
MYSQL_DATABASE: wordpress
wordpress:
image: wordpress
restart: always
volumes:
- ./wp_data:/var/www/html
ports:
- "8080:80"
environment:
WORDPRESS_DB_HOST: db:3306
WORDPRESS_DB_NAME: wordpress
WORDPRESS_DB_USER: root
WORDPRESS_DB_PASSWORD: password
depends_on:
- db
volumes:
db_data:
wp_data:
Итак, что делает приведенный выше код?
В первой строке мы указываем версию файла Compose . Существует несколько различных версий формата файла Compose с поддержкой определенных выпусков Docker.
Далее мы определяем две службы: db
и wordpress
. Каждая служба запускает один образ и создает отдельный контейнер при запуске docker-compose.
Служба db
:
- Использует образ
mysql:5.7
. Если образ отсутствует в вашей системе, Compose извлечет его из общедоступного репозитория Docker Hub. - Использует политику перезапуска
always
которая указывает контейнеру всегда перезапускаться. - Создает именованный том
db_data
для сохранения базы данных. - Определяет переменные среды для образа
mysql:5.7
.
Сервис wordpress
:
- Использует изображение
wordpress
. Если образ отсутствует в вашей системе, Compose извлечет его из общедоступного репозитория Docker Hub. - Использует политику перезапуска
always
которая указывает контейнеру всегда перезапускаться. - Устанавливает каталог
wp_data
на хосте в/var/lib/mysql
внутри контейнера. - Перенаправляет открытый порт 80 на контейнере на порт 8080 на хост-машине.
- Определяет переменные среды для изображения
wordpress
. - Инструкция
depends_on
определяет зависимость между двумя службами. В этом примереdb
будет запущен раньшеwordpress
.
Из каталога проекта запустите приложение WordPress, выполнив следующую команду:
docker-compose up
Результат должен выглядеть примерно так:
...
wordpress_1_70f2f980e1fb | [Mon Nov 19 18:00:31.002748 2018] [mpm_prefork:notice] [pid 1] AH00163: Apache/2.4.25 (Debian) PHP/7.2.12 configured -- resuming normal operations
wordpress_1_70f2f980e1fb | [Mon Nov 19 18:00:31.002912 2018] [core:notice] [pid 1] AH00094: Command line: 'apache2 -D FOREGROUND'
Compose извлечет оба изображения, запустит два контейнера и создаст каталог wp_data
каталоге вашего проекта.
Введите http://0.0.0.0:8080/
в своем браузере, и вы увидите экран установки WordPress.
На данный момент приложение WordPress запущено и работает, и вы можете начать работу над своей темой или плагином.
Чтобы остановить создание, нажмите CTRL+C
Вы также можете запустить Compose в автономном режиме, передав флаг -d
.
docker-compose up -d
Чтобы проверить запущенные службы, используйте опцию ps
:
docker-compose ps
Name Command State Ports
----------------------------------------------------------------------------------
wordpress_app_db_1 docker-entrypoint.sh mysqld Up 3306/tcp, 33060/tcp
wordpress_app_wordpress_1 docker-entrypoint.sh apach ... Up 0.0.0.0:8080->80/tcp
Когда Compose работает в автономном режиме, чтобы остановить использование служб:
docker-compose stop
Если вы хотите полностью удалить контейнеры, используйте опцию down
:
docker-compose down
Передача переключателя --volumes
также удалит тома данных:
docker-compose down --volumes
Удаление Docker Compose
Если вам нужно удалить Docker Compose, вы можете просто удалить двоичный файл, набрав:
sudo rm /usr/local/bin/docker-compose
Выводы
Вы узнали, как установить и использовать Docker Compose в Debian 9. Если у вас есть какие-либо вопросы, оставьте комментарий ниже.