Как установить и использовать Docker Compose в Debian 9

Docker Compose — это инструмент, который позволяет определять и настраивать многоконтейнерные приложения Docker. Он использует файл YAML для настройки контейнеров, сетей и томов приложения.

Compose можно использовать для различных целей. Развертывание приложений с одним хостом, автоматическое тестирование и локальная разработка — самые популярные варианты использования Docker Compose.

В этом руководстве будет рассмотрен процесс установки последней версии Docker Compose на Debian 9. Мы также рассмотрим основные концепции и команды Docker Compose.

Подготовка

Прежде чем продолжить изучение этого руководства, убедитесь, что вы выполнили следующие предварительные требования:

Установите Docker Compose в Debian

Установочный пакет Docker Compose доступен в официальных репозиториях Debian 9, но он не всегда может быть последней версией. Рекомендуемый подход — установить Docker Compose из репозитория Docker GitHub.

На момент написания этой статьи последней стабильной версией Docker Compose была версия 1.23.1 . Перед загрузкой двоичного файла Compose посетите страницу выпуска репозитория Compose на GitHub и проверьте, доступна ли для загрузки новая версия.

Выполните следующие шаги, чтобы установить последнюю версию Docker Compose в Debian 9:

  1. Начните с загрузки двоичного файла 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
  2. Когда загрузка будет завершена, дайте исполняемые разрешения для двоичного файла Compose:

     sudo chmod +x /usr/local/bin/docker-compose
  3. Проверьте установку, набрав:

     docker-compose --version

    Результат будет выглядеть примерно так:

     docker-compose version 1.23.1, build b02f1306

Начало работы с Docker Compose

В этом разделе мы покажем, как использовать Docker Compose для управления стеком WordPress на вашем компьютере Debian 9.

Начните с создания каталога для проекта и перехода в него :

mkdir wordpress_appcd wordpress_app

Откройте текстовый редактор и создайте файл с именем docker-compose.yml в каталоге проекта:

nano docker-compose.yml

Вставьте следующий контент:

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. Если у вас есть какие-либо вопросы, оставьте комментарий ниже.

Оставьте комментарий