Как установить Docker на Ubuntu 22.04
(1).jpg)
Docker – это открытая платформа для разработки, доставки и запуска приложений. Она позволяет упаковывать приложения и их зависимости в так называемые контейнеры. Контейнеры изолируют приложения от окружающей среды, что позволяет им работать одинаково независимо от конфигурации хост-системы.
Почему нужно выбрать Docker
Docker предоставляет множество преимуществ для разработчиков, системных администраторов и команд DevOps.
- Изоляция и консистентность. Контейнеры изолируют приложения и их зависимости от друг друга и от хост-системы. Это обеспечивает согласованность и целостность в разных окружениях, позволяя избегать возникновения конфликтов и снижать вероятность ошибок.
- Портабельность. Контейнеры можно легко переносить между разными средами, будь то машина для разработки, облачные серверы или локальный компьютер. Это упрощает процесс развертывания и тестирования.
- Быстрое развёртывание и масштабирование. Создание и запуск контейнеров занимает всего лишь секунды, что значительно ускоряет процесс разработки и развёртывания приложений. Контейнеры также предлагают горизонтальное масштабирование, добавляя экземпляры контейнеров по мере необходимости.
- Эффективное использование ресурсов. Docker использует общее ядро операционной системы, что позволяет оптимально использовать ресурсы хост-системы. Это означает, что контейнеры могут работать с минимальным объёмом вычислительных и памятных ресурсов.
- Инфраструктура как код. Docker-контейнеры описываются с помощью кода, что упрощает автоматизацию и управление инфраструктурой. Это способствует управляемости и воспроизводимости процессов развертывания.
- Лёгкая обновляемость и откат. Образы контейнеров можно легко обновить, а также быстро вернуться к предыдущей версии в случае проблемы. Это упрощает управление приложениями на производственных серверах.
- Модульность и микросервисная архитектура. Docker способствует разделению приложения на мелкие компоненты, которые могут работать в отдельных контейнерах. Это улучшает модульность и поддерживаемость приложения, а также позволяет использовать микросервисную архитектуру.
Требования к ОС
Для установки Docker вам потребуется 64-разрядная версия одной из следующих версий Ubuntu:
- Ubuntu Lunar 23.04,
- Ubuntu Kinetic 22.10,
- Ubuntu Jammy 22.04 (LTS),
- Ubuntu Focal 20.04 (LTS).
Это все версии Ubuntu, которые, согласно официальной документации, совместимы с Docker.
Docker для Ubuntu совместим с несколькими архитектурами процессоров, включая:
- x86_64 (или amd64),
- armhf,
- arm64,
- s390x
- ppc64le (или ppc64el).
- Системные ресурсы
Docker не требует больших системных ресурсов, но для запуска контейнеров и выполнения приложений потребуется достаточно оперативной памяти, мощности процессора и дискового пространства.
Рекомендуется иметь как минимум 2 ГБ оперативной памяти.
Перенос сайта в RU-CENTER за 1 рубль

Мы приглашаем вас воспользоваться специальными условиями для упрощённого перехода на обслуживание в RU-CENTER. Получите все преимущества за символическую стоимость:
- Полгода хостинга на выбранном тарифе – всего за 1 рубль!
- Перенос доменов .ru и .рф на обслуживание.
- Бесплатный перенос любого количества ваших сайтов на наш хостинг.
Просто воспользуйтесь промокодом WELCOME и присоединяйтесь к RU-CENTER уже сегодня.
Как удалить старые версии Docker
Перед установкой Docker необходимо убедиться, что вы удалили любые конфликтующие пакеты.
К примеру, это могут быть неофициальные версии пакетов Docker, которые разработчики дистрибутивов предоставляют через APT. Прежде чем установить официальную версию Docker, их необходимо удалить.
Неофициальными считаются следующие пакеты:
- docker.io,
- docker-compose,
- docker-doc,
- podman-docker.
Кроме того, Docker зависит от контейнерных технологий «containerd» и «runc» и поставляется с этими зависимостями в одном пакете – «containerd.io».
Если вы ранее устанавливали пакеты «containerd» или «runc», их также следует удалить, чтобы избежать конфликтов с версиями, поставляемыми с Docker.
Выполните следующую команду для удаления всех конфликтующих пакетов:
for pkg in docker.io docker-doc docker-compose podman-docker containerd runc; do sudo apt-get remove $pkg; done
В конце система apt-get сообщит, что ни одного из этих пакетов не установлено.
Важно! Образы, контейнеры, тома и сети, хранящиеся в /var/lib/docker/, не будут автоматически очищены при удалении Docker. Если вы хотите начать с «чистой» установки и предпочли бы удалить уже существующие данные, воспользуйтесь инструкцией в конце этой статьи.
Установка Docker на Ubuntu 22.04
(1).jpg)
Способ 1. Установка с помощью apt
Перед тем как впервые установить Docker на новом хостинге, вам нужно настроить репозиторий Docker. Затем вы сможете устанавливать и обновлять Docker из этого репозитория.
- Обновите apt и установите пакеты, необходимые для работы с репозиторием:
sudo apt-get update
sudo apt-get install ca-certificates curl gnupg
- Добавьте официальный GPG-ключ Docker:
sudo install -m 0755 -d /etc/apt/keyrings
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo gpg —dearmor -o /etc/apt/keyrings/docker.gpg
sudo chmod a+r /etc/apt/keyrings/docker.gpg
- Используйте следующую команду для настройки репозитория:
«deb [arch=»$(dpkg —print-architecture)» signed-by=/etc/apt/keyrings/docker.gpg] https://download.docker.com/linux/ubuntu \
«$(. /etc/os-release && echo «$VERSION_CODENAME»)» stable» | \
sudo tee /etc/apt/sources.list.d/docker.list > /dev/null
- Обновите пакеты apt:
sudo apt-get update
- Для установки последней версии выполните:
sudo apt-get install docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin
- Теперь Docker должен быть установлен, демон запущен, и процесс активирован для автоматического запуска при загрузке. Проверьте, что он работает:
sudo systemctl status docker
При условии, что служба активна и корректно работает, вывод должен быть примерно следующим:
- docker.service — Docker Application Container Engine
Loaded: loaded (/lib/systemd/system/docker.service; enabled; vendor preset: enabled)
Active: active (running) since Fri 2022-04-01 21:30:25 UTC; 22s ago
Main PID: 7854 (dockerd)
└─7854 /usr/bin/dockerd -H fd:// —containerd=/run/containerd/containerd.sock
Теперь вы успешно установили и запустили Docker.
Способ 2. Ручная установка
Если вы не можете использовать репозиторий apt для установки Docker, можете загрузить файл .deb для вашей версии ОС и установить его вручную.
Важно! Вам потребуется загружать новый файл каждый раз, когда вы хотите обновить Docker.
- Перейдите по на официальный сайт Docker.
- Выберите вашу версию Ubuntu из списка.

- Перейдите в каталог «pool/», затем в «stable/» и выберите соответствующую архитектуру (amd64, armhf, arm64 или s390x).
- Загрузите следующие файлы .deb для пакетов Docker Engine, CLI, containerd и Docker Compose:
- containerd.io__.deb.
- docker-ce__.deb,
- docker-ce-cli__.deb,
- docker-buildx-plugin__.deb,
- docker-compose-plugin__.deb.
- Установите пакеты .deb. Обновите пути в следующем примере в соответствии с местоположением загруженных пакетов Docker.
Демон Docker будет запущен автоматически.
- Проверьте успешность установки Docker, выполнив команду:
sudo service docker start
sudo docker run hello-world
Эта команда загрузит тестовый образ и запустит его в контейнере. Когда контейнер успешно запустится, вы получите примерно следующее сообщение:
Hello from Docker!
This message shows that your installation appears to be working correctly.
To generate this message, Docker took the following steps:
The Docker client contacted the Docker daemon.
The Docker daemon pulled the «hello-world» image from the Docker Hub.
The Docker daemon created a new container from that image which runs the
executable that produces the output you are currently reading.
The Docker daemon streamed that output to the Docker client, which sent it
to your terminal.
To try something more ambitious, you can run an Ubuntu container with:
$ docker run -it ubuntu bash
Share images, automate workflows, and more with a free Docker ID:
For more examples and ideas, visit:
Установка Docker Compose на Ubuntu 22.04
Способ 1. Установка с помощью apt-get
- Обновите пакеты и установите последнюю версию Docker Compose:
sudo apt-get update
sudo apt-get install docker-compose-plugin
- Убедитесь, что Docker Compose установлен корректно, проверив его версию:
docker compose version
Ответ отобразится в формате «v2.20.3», где вместо v2.20.3 будет указана последняя установленная версия Docker Compose.
Способ 2. Вручную
- Чтобы скачать и установить плагин Compose, выполните следующие действия:
mkdir -p $DOCKER_CONFIG/cli-plugins
curl -SL https://github.com/docker/compose/releases/download/v2.20.3/docker-compose-linux-x86_64 -o $DOCKER_CONFIG/cli-plugins/docker-compose
Эта команда загружает последний релиз Docker Compose (из репозитория релизов Compose) и устанавливает Compose для активного пользователя в директорию $HOME.
- Для установки Docker Compose для всех пользователей пропишите:
sudo chmod +x /usr/local/lib/docker/cli-plugins/docker-compose
- Убедитесь, что установка прошла корректно:
docker compose version
Версия Docker Compose будет отображена в формате «v2.20.3».
Способ 3. Установка с помощью git
sudo apt-get install git
- Чтобы убедиться в успешной установке, проверьте версию Git:
Вы увидите примерно следующий вывод:
git version 2.20.3
- Для того чтобы клонировать репозиторий, перейдите на страницу Docker Compose на GitHub и скопируйте ссылку в разделе «Code».

- Пропишите её вместе с командой git clone:
git clone https://github.com/docker/compose.git
После выполнения этой команды начнётся процесс клонирования репозитория с GitHub.
Как удалить Docker на Ubuntu 22.04
Чтобы удалить пакеты Docker Engine, CLI, containerd и Docker Compose, выполните следующую команду:
$ sudo apt-get purge docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin docker-ce-rootless-extras
Однако в таком случае все образы, контейнеры, тома или настроенные файлы конфигурации на вашем компьютере не будут автоматически удалены.
Чтобы удалить все образы, контейнеры и тома, примените:
$ sudo rm -rf /var/lib/docker
$ sudo rm -rf /var/lib/containerd
Любые изменённые файлы конфигурации также нужно будет удалить вручную.
Заключение
В этой статье мы рассмотрели процесс установки Docker и Docker Compose на Ubuntu 22.04. Теперь вы готовы начать работу с контейнеризацией и воспользоваться всеми преимуществами, которые предоставляет Docker.
Не забудьте, что на нашем сайте есть ещё больше информации об этой платформе. Ознакомьтесь со статьями «Краткий экскурс в Docker» и «Что такое Docker контейнер», где вы найдёте полезные советы и руководства для централизованного управления контейнерами.
Установка и настройка Docker в Ubuntu
Docker — программное обеспечение для облегчения создания, развертывания и запуска приложений. Разработчик может упаковать приложение и все его зависимости в изолированную среду. Managed Kubernetes помогает разворачивать контейнерные приложения в инфраструктуре Selectel. Сосредоточьтесь на разработке, а мы займемся рутинными операциями по обеспечению работы вашего кластера Kubernetes. Создавая аналогичную изолированную среду, Docker схож с виртуальным сервером. Однако, […]

Docker — программное обеспечение для облегчения создания, развертывания и запуска приложений. Разработчик может упаковать приложение и все его зависимости в изолированную среду.
Managed Kubernetes помогает разворачивать контейнерные приложения в инфраструктуре Selectel. Сосредоточьтесь на разработке, а мы займемся рутинными операциями по обеспечению работы вашего кластера Kubernetes.
Создавая аналогичную изолированную среду, Docker схож с виртуальным сервером. Однако, в случае с Docker, значительный прирост производительности дает то, что контейнеры, в отличие от виртуальных машин, используют общее ядро Linux, разделяя его ресурсы.
Еще один важный момент — Docker имеет открытый исходный код. Это означает отсутствие необходимости внесения оплаты за лицензии и большое комьюнити, в котором легко получить ответ на любой вопрос относительно работы Docker.
В этой статье мы разберемся с установкой Docker на операционную систему Ubuntu, создадим образ контейнера на Docker Hub и запустим собственный репозиторий. Также расскажем об утилите Docker Compose для работы с мультиконтейнерными приложениями.
Перед началом установки всех необходимых компонентов, подготовим сервер. Это будет облачный сервер с готовой конфигурацией.
В консоли управления Selectel перейдем в представление Облачная платформа и нажмем на кнопку Создать сервер.

На следующем представлении вводим имя сервера, выбираем образ операционной системы (в нашем случае это Ubuntu 18.04 LTS 64-bit) и фиксированную конфигурацию сервера с 1 vCPU и 2 ГБ RAM. Для тестовых целей будет достаточно диска с 10 ГБ. Еще раз проверяем конфигурацию сервера и нажимаем Создать.

Подождем минуту или две пока сервер не перейдет в состояние Active.

Теперь можем приступать к установке Docker. Поехали!
Docker: системные требования для установки
Один из компонентов окружения Docker — Docker Engine. Эти клиент-серверное приложение, которое обеспечивает следующие компоненты:
- серверная часть с процессом-демоном dockerd;
- API-интерфейсы, которые программы могут использовать для взаимодействия с демоном Docker;
- клиента интерфейса командной строки (CLI), вызываемый командой docker.
Docker Engine поставляется в виде .deb и .rpm пакетов и может быть установлен на любые дистрибутивы семейства Linux (CentOS, Debian, Fedora, Raspbian, Ubuntu). Также есть специальная утилита Docker Desktop, которая позволяет исполнять Docker Engine на операционных системах Windows и MacOS. В обоих случаях, все равно будет использоваться ядро Linux.
Установка Docker на Ubuntu
Чтобы установить Docker на Ubuntu, выполним подготовительные действия. Для начала, обновим состав установочных пакетов, чтобы иметь представление об их актуальных версиях:
sudo apt update
Предварительно установим набор пакетов, необходимый для доступа к репозиториям по протоколу HTTPS:
- apt-transport-https — активирует передачу файлов и данных через https;
- ca-сertificates — активирует проверку сертификаты безопасности;
- curl — утилита для обращения к веб-ресурсам;
- software-properties-common — активирует возможность использования скриптов для управления программным обеспечением.
sudo apt install apt-transport-https ca-certificates curl software-properties-common
Далее добавим в систему GPG-ключ для работы с официальным репозиторием Docker:
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add -
Теперь добавим репозиторий Docker в локальный список репозиториев:
sudo add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable"
Повторно обновим данные о пакетах операционной системы:
sudo apt update
Приступаем к установке пакета Docker.
sudo apt install docker-ce -y
После завершения установки запустим демон Docker и добавим его в автозагрузку:
sudo systemctl start docker
sudo systemctl enable docker
На этом установка Docker завершена и можно начинать с ним работу.
Установка Docker Compose на Ubuntu
Docker Compose — это инструмент для описания и запуска мультиконтейнерных приложений Docker. Инструмент позволяет пользователям запускать, выполнять, общаться и закрывать контейнеры с помощью одной команды.
Посмотрим последнюю сборку Docker Compose в репозитории на Github и загрузим ее при помощи утилиты curl со следующими параметрами:
- –L разрешает редиректы, если файл перемещен;
- –o модифицирует имя файла для удобства его запуска и указывает каталог для сохранения.
sudo curl -L "https://github.com/docker/compose/releases/download/1.28.6/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
После завершения загрузки, добавим загруженному бинарному файлу права на выполнение:
sudo chmod +x /usr/local/bin/docker-compose
Заметим, что выполнить установку Docker Compose можно было из репозитория Ubuntu командой sudo apt-get install docker-compose. Однако, в репозитории может быть не самая последняя версия. Способ, который мы описали выше, позволит загрузить актуальную версию утилиты Docker Compose.
Чтобы проверить корректность работы утилиты, выполним проверку ее версии:
sudo docker–compose –version
Если команда вернула номер версии, значит Docker Compose готов к работе.
Когда нужно удалить Docker Compose, достаточно выполнить команду удаления файла:
sudo rm /usr/local/bin/docker-compose
Если установка выполнялась через пакетный менеджер apt, нужно его вызвать с параметром purge:
sudo apt purge docker-compose
И следом удалить все невостребованные зависимости:
sudo apt autoremove
Команды Docker и работа с ним
Перед началом работы с Docker, нужно подготовить контейнер. Есть два пути: создать новый контейнер, описав его в Dockerfile или загрузить уже готовый из Docker Hub или другого репозитория. В этом разделе мы рассмотрим вариант создания собственного контейнера с нуля при помощи Dockerfile.
Dockerfile — это скрипт с инструкциями по созданию образа Docker. Эти инструкции представляют собой группу команд, автоматически выполняемых в среде Docker для создания определенного образа Docker.
Создадим новую директорию, перейдем в нее и создадим Dockerfile:
mkdir docker_images
cd docker_images
touch Dockerfile
Откроем Dockerfile и добавим в него несколько строк:
nano Dockerfile
FROM ubuntu MAINTAINER selectel RUN apt-get update CMD ["echo", "Hello World"]
- FROM определяет основу создаваемого изображения. Можно начать с родительского (как в примере выше) или базового образа. При использовании родительского образа вы используете существующий образ, на котором основан новый. Использование базового образа означает, что вы начинаете с нуля (именно так его и определяют: FROM scratch).
- MAINTAINER указывает автора образа. Здесь вы можете ввести ваше имя и/или фамилию (или добавить адрес электронной почты). Также сюда можно вписать инструкцию по добавлению метаданных (LABEL) к образу.
- RUN определяет инструкции по выполнению команды при построении образа в слоях поверх него. В этом примере система ищет обновления репозитория после начала сборки образа Docker. В Dockerfile может быть несколько инструкций RUN.
- CMD отвечает за значение команды по умолчанию, которая будет исполнено. Система выполнит ее, если вы запустите контейнер без указания команды. Внутри Dockerfile может быть только одна инструкция CMD.
Сохраним изменения и выйдем из режима редактирования. Теперь можно приступать к сборке контейнера. Для этого используем утилиту Docker. Базовый синтаксис выглядит так:
sudo docker build [OPTIONS] PATH | URL | -
Запустим утилиту с параметром -t, который указывает на имя образа. Это упростит управление образами, когда их станет несколько.
sudo docker build -t my_image .
После сборки образа, проверим, что он появился в локальном каталоге образов. Получим следующий вывод:
sudo docker images
REPOSITORY TAG IMAGE ID CREATED SIZE my_image latest 889af78121ad 4 seconds ago 100MB ubuntu latest 4dd97cefde62 2 weeks ago 72.9MB
Казалось бы мы создали только один образ. Откуда там появилось два? Все просто — мы создавали свой контейнер my_ubuntu на на базе образа ubuntu, поэтому вначале скачался образ ubuntu и лишь потом был создан my_image.
Запустим новый контейнер Docker на основе образа, созданного на предыдущих шагах. Назовем контейнер «test» и получим вывод «Hello world» в результате выполнения команды docker run. Ubuntu, CentOS или Debian — операционная система значения не имеет, синтаксис везде будет одинаковый.
sudo docker run --name test my_image
Hello World
После выключения контейнера, все данные, которые он генерировал за время работы удаляются. Чтобы этого не происходило, предусмотрена возможность монтирования внешних хранилищ. Docker автоматически создает каталог /var/lib/docker/volume, в который можно сохранять данные на постоянной основе и совместно их использовать между несколькими контейнерами. Создадим новое хранилище с именем «selectel»:
sudo docker volume create selectel
Теперь запустим контейнер с примонтированным внешним хранилищем:
sudo docker run --name=test --mount source=selectel,destination=/selectel my_image
Таким образом, все данные, которые появятся в директории /selectel внутри контейнера будут надежно храниться на файловой системе сервера.
Контейнеры Docker предназначены для обеспечения изолированной среды со всеми библиотеками и конфигурациями, необходимыми для работы программного обеспечения. Во время разработки их количество может хаотично, в результате появятся устаревшие и неиспользуемые контейнеры. Ниже мы покажем как удалить ненужные контейнеры.
Предварительно выведем в терминал запущенные контейнеры:
sudo docker container ls -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES b52480dd6110 my_image "echo 'Hello World'" 4 minutes ago Exited (0) 4 minutes ago test
Увидим контейнер, который мы только что запустили. Еще один вариант получить список запущенных контейнеров — добавить параметр -a. Так мы увидим список id контейнеров:
sudo docker container ls –aq
b52480dd6110
Можно остановить один контейнер:
sudo docker container stop [container_id]
А можно все разом:
sudo docker container stop $(docker container ls –aq)
Чтобы очистить все данные, созданные контейнером, можно выполнить следующую команду:
sudo docker container stop $(docker container ls –aq) && docker system prune –af ––volumes
Команда выполняет остановку контейнеров, перечисленных в круглых скобках. Атрибут && предписывает Docker удалить все остановленные контейнеры и тома. Параметры –af указывает, что это должно применяться ко всем контейнерам (a) без необходимости подтверждения (f).
А теперь удалим контейнер. Один или все сразу:
sudo docker container rm [container_id]
sudo docker container rm $(docker container ls –aq)
При удалении ненужных контейнеров можно также задавать фильтры. Например, в примере ниже мы удалим все контейнеры без метки мейнтейнера «selectel».
sudo docker container prune --filter=”label!=maintainer=selectel”
Фильтры имеют следующий синтаксис:
Образы Docker — это файлы, которые включают несколько слоев, используемых для запуска кода в контейнере. В процессе разработки некоторые образы могут устаревать и, соответственно, занимать место на диске. Посмотрим какие образы сейчас находятся на файловой системе:
sudo docker image ls
REPOSITORY TAG IMAGE ID CREATED SIZE my_image latest 889af78121ad 24 hours ago 100MB ubuntu latest 4dd97cefde62 2 weeks ago 72.9MB
Чтобы удалить неиспользуемые образы, нужно воспользоваться их идентификатором из колонки IMAGE ID.
docker image rm [image_id1] [image_id2]
Аналогичным контейнерам образом, удаляемые образы можно фильтровать по меткам или по дате создания. Первая команда удаляет образы с меткой «selectel», а вторая все образы, созданные за последние 24 часа.
sudo docker image prune ––filter=”label=selectel”
sudo docker image prune –a ––filter “until=24h”
Так как контейнеры после остановки не сохраняют внутри себя никакие данные. Например, если в контейнере работала база данных и там за время работы контейнера были созданы объекты и данные, после остановки они пропадут. Для этого, к контейнеру монтируются каталоги, расположенные, непосредственно на диске операционной системы. Чтобы просмотреть все такие каталоги, выполним команду:
sudo docker volume ls
Чтобы удалить ненужные разделы Docker, воспользуемся командой:
sudo docker volume rm [VolumeName]
Сети Docker позволяют различным контейнерам свободно обмениваться данными друг с другом, а также изолировать этот трафик. Обычно это делается с помощью сетевого моста Docker. Чтобы посмотреть все имеющиеся сети, выполним:
sudo docker network ls
NETWORK ID NAME DRIVER SCOPE 1e31297e1d6a bridge bridge local 783575476ed4 host host local c7c5d2496494 none null local
Чтобы удалить ненужные сети Docker, воспользуемся командой:
sudo docker network rm [networkID]
Команда prune автоматически удаляет все ресурсы, не связанные с контейнером. Это упрощенный способ очистки неиспользуемых образов, контейнеров, томов и сетей.
sudo docker system prune
Можно использовать дополнительные параметры:
- -a — для удаления всех остановленных контейнеров и неиспользуемых образов.
- -f — Обойти диалоговое окно подтверждения
- —volumes — Удаляет все неиспользуемые тома.
Эту команду также можно использовать точечно для контейнеров, образов, дисковых разделов и сетей:
sudo docker container prune
sudo docker image prune
sudo docker volume prune
sudo docker network prune
Можно использовать дополнительный параметр -a, в этом случае удаляются неиспользуемые и зависшие объекты.
Работа с репозиторием Docker Hub
Docker Hub — это общедоступный репозиторий образов контейнеров Docker. Каждый раз когда вы создаете собственный контейнер (в примере выше мы делали контейнер на основе операционной системе Ubuntu), с Docker Hub загружается соответствующий образ. Но образы можно не только загружать, но и выгружать. В этом разделе мы расскажем как это сделать.
Прежде чем начать, понадобится учетная запись на Docker Hub. Регистрация бесплатная. Сейчас в нашем тестовом окружении на Docker Hub нет ни одного репозитория. Прежде чем начинать выгрузку создадим один с помощью кнопки Create Repository.

В командной строке введем специальную команду для подключения к Docker Hub. На вход подадим имя учетной записи, которое указывали при регистрации. Затем укажем пароль.
sudo docker login -u [docker-hub-username]
Осталось выгрузить образ в репозиторий. Установим образу метку, а затем зальем его в репозиторий.
sudo docker tag my_image [docker-hub-username]/my_image:0.0.1
sudo docker push [docker-hub-username]/my_image:0.0.1
The push refers to repository [docker.io/[docker-hub-username]/my_image] 8c25b6d14dcf: Pushed c20d459170d8: Pushed db978cae6a05: Pushed aeb3f02e9374: Pushed 0.0.1: digest: sha256: size: 1155
В результате, образ появится в репозитории.

Работа с частным репозиторием
Частный репозиторий — это аналог Docker Hub, только находиться он будет в окружении под вашим управлением.
Запустим локальный репозиторий в контейнере:
docker run -d -p 5000:5000 --restart=always --name registry registry:2
Теперь добавим специальный тег к образу, добавляем созданный образ my_image в репозиторий и для проверки получаем его обратно:
docker tag my_image localhost:5000/my_image
docker push localhost:5000/my_image
docker pull localhost:5000/my_image
Частный репозиторий готов к работе.
Заключение
В статье мы рассмотрели работу с контейнерами на основе Docker, их создание, удаление и размещение в Docker Hub и локальном репозитории. Docker сильно упрощает работу разработчиков и системных администраторов. Легковесные контейнеры потребляют меньшее количество ресурсов (в отличие от виртуальных машин) и полноценно готовы к работе за считанные минуты.
Как установить Docker на Ubuntu
Если вам кажется, что установка Docker на Ubuntu — это сложный и долгий процесс, попробуйте настроить Docker по нашей инструкции. Мы поможем разобраться, что такое Docker и контейнеры, покажем простой путь настройки Docker на Ubuntu 18.04 и 20.04 и расскажем, как работать в утилите docker.
Что такое Docker
Docker – это платформа с открытым исходным кодом, которая позволяет оптимизировать управление разработкой, тестированием и размещением веб-приложений. В основе работы Docker лежит упаковка программ (вместе с окружением и зависимостями) в виртуальные блоки — контейнеры.
Контейнеры можно развертывать, масштабировать и перемещать в разные среды (например, персональные компьютеры и дата-центры) без потери работоспособности кода. Также с помощью контейнера можно отделить инфраструктуру приложения от самого приложения и работать только с ней.
Контейнер можно быстро создать и так же быстро удалить. Чтобы создать контейнер, нужно активировать образ docker — шаблонный элемент. Образы запускаются из публичного репозитория Docker Hub. После запуска срабатывает разметка файловой системы, создается сетевой интерфейс и назначается IP-адрес. После этого контейнер готов к работе.
На одном хосте можно параллельно запускать около тысячи контейнеров. Чтобы управлять сразу несколькими контейнерами, из которых построен проект, можно установить пакетный менеджер Docker Compose.
Преимущества Docker:
- работает не только на Linux, но и на Windows и MacOS,
- не нужно устанавливать такие вспомогательные инструменты, как Elasticsearch, PostgreSQL и Redis — они запускаются сразу из контейнера,
- простое масштабирование и инкапсуляция,
- с платформой можно работать на виртуальном сервере.
Как установить Docker на Ubuntu
Перед началом установки проверьте системные требования:
- 64-битная архитектура,
- ядро не ниже версии 3.10 — подойдёт Ubuntu версии 16.04 и выше.
Установка Docker в дистрибутиве Ubuntu состоит из 12 шагов. Рассмотрим каждый из них подробно.
Обновите пакеты:
sudo apt update
Установите пакеты, которые необходимы для работы пакетного менеджера apt по протоколу HTTPS:
sudo apt install apt-transport-https ca-certificates curl software-properties-common
Добавьте GPG-ключ репозитория Docker:
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add -
Добавьте репозиторий Docker:
sudo add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/ubuntu bionic stable"
Обновите пакеты:
sudo apt update
Установка и использование Docker в Ubuntu 20.04

Docker — это приложение, упрощающее процесс управления процессами приложения в контейнерах. Контейнеры позволяют запускать приложения в процессах с изолированными ресурсами. Они похожи на виртуальные машины, но более портативные, более эффективно расходуют ресурсы и в большей степени зависят от операционной системы хоста.
Подробное описание различных компонентов контейнера Docker см. в статье Экосистема Docker: знакомство с базовыми компонентами.
В этом обучающем модуле мы установим и начнем использовать Docker Community Edition (CE) на сервере Ubuntu 20.04. Вы самостоятельно установите Docker, поработаете с контейнерами и образами и разместите образ в репозитории Docker.
Предварительные требования
Для выполнения этого руководства вам потребуется следующее:
- Один сервер Ubuntu 20.04, настроенный в соответствии с руководством по начальной настройке сервера Ubuntu 20.04, включая пользователя non-root user с привилегиями sudo и брандмауэр.
- Учетная запись на Docker Hub, если вы хотите создавать собственные образы и загружать их на Docker Hub, как показано в шагах 7 и 8.
Шаг 1 — Установка Docker
Пакет установки Docker, доступный в официальном репозитории Ubuntu, может содержать не самую последнюю версию. Чтобы точно использовать самую актуальную версию, мы будем устанавливать Docker из официального репозитория Docker. Для этого мы добавим новый источник пакета, ключ GPG от Docker, чтобы гарантировать загрузку рабочих файлов, а затем установим пакет.
Первым делом обновите существующий список пакетов:
Затем установите несколько необходимых пакетов, которые позволяют apt использовать пакеты через HTTPS:
Добавьте ключ GPG для официального репозитория Docker в вашу систему:
Добавьте репозиторий Docker в источники APT:
-
sudo add-apt-repository «deb [arch=amd64] https://download.docker.com/linux/ubuntu focal stable»
Потом обновите базу данных пакетов и добавьте в нее пакеты Docker из недавно добавленного репозитория:
Убедитесь, что установка будет выполняться из репозитория Docker, а не из репозитория Ubuntu по умолчанию:
Вы должны получить следующий вывод, хотя номер версии Docker может отличаться:
Output of apt-cache policy docker-ce
docker-ce: Installed: (none) Candidate: 5:19.03.9~3-0~ubuntu-focal Version table: 5:19.03.9~3-0~ubuntu-focal 500 500 https://download.docker.com/linux/ubuntu focal/stable amd64 Packages
Обратите внимание, что docker-ce не установлен, но является кандидатом на установку из репозитория Docker для Ubuntu 20.04 (версия focal ).
Docker должен быть установлен, демон-процесс запущен, а для процесса активирован запуск при загрузке. Проверьте, что он запущен:
Вывод должен выглядеть примерно следующим образом, указывая, что служба активна и запущена:
Output● docker.service - Docker Application Container Engine Loaded: loaded (/lib/systemd/system/docker.service; enabled; vendor preset: enabled) Active: active (running) since Tue 2020-05-19 17:00:41 UTC; 17s ago TriggeredBy: ● docker.socket Docs: https://docs.docker.com Main PID: 24321 (dockerd) Tasks: 8 Memory: 46.4M CGroup: /system.slice/docker.service └─24321 /usr/bin/dockerd -H fd:// --containerd=/run/containerd/containerd.sock
После установки Docker у вас будет доступ не только к службе Docker (демон-процесс), но и к утилите командной строки docker или клиенту Docker. Мы узнаем, как использовать команду docker позже в этом обучающем руководстве.
Шаг 2 — Настройка команды Docker без sudo (необязательно)
По умолчанию команда docker может быть запущена только пользователем root или пользователем из группы docker, которая автоматически создается при установке Docker. Если вы попытаетесь запустить команду docker без префикса sudo или с помощью пользователя, который не находится в группе docker, то получите следующий вывод:
Outputdocker: Cannot connect to the Docker daemon. Is the docker daemon running on this host?. See 'docker run --help'.
Если вы не хотите каждый раз вводить sudo при запуске команды docker , добавьте свое имя пользователя в группу docker :
Чтобы применить добавление нового члена группы, выйдите и войдите на сервер или введите следующее:
Вы должны будете ввести пароль вашего пользователя, чтобы продолжить.
Проверьте, что ваш пользователь добавлен в группу docker, введя следующее:
Outputsammy sudo docker
Если вам нужно добавить пользователя в группу docker , для которой вы не выполнили вход, объявите имя пользователя явно, используя следующую команду:
В дальнейшем в статье подразумевается, что вы запускаете команду docker от имени пользователя в группе docker. В обратном случае вам необходимо добавлять к командам префикс sudo .
Давайте перейдем к знакомству с командой docker .
Шаг 3 — Использование команды Docker
Использование docker подразумевает передачу ему цепочки опций и команд, за которыми следуют аргументы. Синтаксис имеет следующую форму:
Чтобы просмотреть все доступные субкоманды, введите:
Для 19-й версии Docker полный список субкоманд выглядит следующим образом:
Output attach Attach local standard input, output, and error streams to a running container build Build an image from a Dockerfile commit Create a new image from a container's changes cp Copy files/folders between a container and the local filesystem create Create a new container diff Inspect changes to files or directories on a container's filesystem events Get real time events from the server exec Run a command in a running container export Export a container's filesystem as a tar archive history Show the history of an image images List images import Import the contents from a tarball to create a filesystem image info Display system-wide information inspect Return low-level information on Docker objects kill Kill one or more running containers load Load an image from a tar archive or STDIN login Log in to a Docker registry logout Log out from a Docker registry logs Fetch the logs of a container pause Pause all processes within one or more containers port List port mappings or a specific mapping for the container ps List containers pull Pull an image or a repository from a registry push Push an image or a repository to a registry rename Rename a container restart Restart one or more containers rm Remove one or more containers rmi Remove one or more images run Run a command in a new container save Save one or more images to a tar archive (streamed to STDOUT by default) search Search the Docker Hub for images start Start one or more stopped containers stats Display a live stream of container(s) resource usage statistics stop Stop one or more running containers tag Create a tag TARGET_IMAGE that refers to SOURCE_IMAGE top Display the running processes of a container unpause Unpause all processes within one or more containers update Update configuration of one or more containers version Show the Docker version information wait Block until one or more containers stop, then print their exit codes
Чтобы просмотреть параметры, доступные для конкретной команды, введите:
Чтобы просмотреть общесистемную информацию о Docker, введите следующее:
Давайте изучим некоторые из этих команд. Сейчас мы начнем работать с образами.
Шаг 4 — Работа с образами Docker
Контейнеры Docker получают из образов Docker. По умолчанию Docker загружает эти образы из Docker Hub, реестр Docker, контролируемые Docker, т.е. компанией, реализующей проект Docker. Любой может размещать свои образы Docker на Docker Hub, поэтому большинство приложений и дистрибутивов Linux, которые вам потребуется, хранят там свои образы.
Чтобы проверить, можно ли получить доступ к образам из Docker Hub и загрузить их, введите следующую команду:
Данный вывод говорит о том, что Docker работает корректно:
OutputUnable to find image 'hello-world:latest' locally latest: Pulling from library/hello-world 0e03bdcc26d7: Pull complete Digest: sha256:6a65f928fb91fcfbc963f7aa6d57c8eeb426ad9a20c7ee045538ef34847f44f1 Status: Downloaded newer image for hello-world:latest Hello from Docker! This message shows that your installation appears to be working correctly. .
Docker первоначально не смог найти локальный образ hello-world , поэтому он загрузил образ из Docker Hub, который является репозиторием по умолчанию. После того как образ был загружен, Docker создал контейнер из образа, а приложение внутри контейнера было исполнено, отобразив сообщение.
Вы можете выполнять поиск доступных на Docker Hub с помощью команды docker с субкомандой search . Например, чтобы найти образ Ubuntu, введите:
Скрипт пробежится по Docker Hub и вернет список всех образов с именами, совпадающими со строкой запроса. В данном случае вывод будет выглядеть примерно следующим образом:
OutputNAME DESCRIPTION STARS OFFICIAL AUTOMATED ubuntu Ubuntu is a Debian-based Linux operating sys… 10908 [OK] dorowu/ubuntu-desktop-lxde-vnc Docker image to provide HTML5 VNC interface … 428 [OK] rastasheep/ubuntu-sshd Dockerized SSH service, built on top of offi… 244 [OK] consol/ubuntu-xfce-vnc Ubuntu container with "headless" VNC session… 218 [OK] ubuntu-upstart Upstart is an event-based replacement for th… 108 [OK] ansible/ubuntu14.04-ansible Ubuntu 14.04 LTS with .
В столбце OFFICIAL OK указывает на образ, созданный и поддерживаемый компанией, реализующей проект. После того как вы определили образ, который хотели бы использовать, вы можете загрузить его на свой компьютер с помощью субкоманды pull .
Запустите следующую команду, чтобы загрузить официальный образ ubuntu на свой компьютер:
Вывод должен выглядеть следующим образом:
OutputUsing default tag: latest latest: Pulling from library/ubuntu d51af753c3d3: Pull complete fc878cd0a91c: Pull complete 6154df8ff988: Pull complete fee5db0ff82f: Pull complete Digest: sha256:747d2dbbaaee995098c9792d99bd333c6783ce56150d1b11e333bbceed5c54d7 Status: Downloaded newer image for ubuntu:latest docker.io/library/ubuntu:latest
После того как образ будет загружен, вы сможете запустить контейнер с помощью загруженного образа с помощью субкоманды run . Как вы уже видели на примере hello-world , если образ не был загружен, когда docker выполняется с субкомандой run , клиент Docker сначала загружает образ, а затем запускает контейнер с этим образом.
Чтобы просмотреть образы, которые были загружены на ваш компьютер, введите:
Вывод команды должен выглядеть примерно следующим образом:
OutputREPOSITORY TAG IMAGE ID CREATED SIZE ubuntu latest 1d622ef86b13 3 weeks ago 73.9MB hello-world latest bf756fb1ae65 4 months ago 13.3kB
Как вы увидите далее в этом обучающем руководстве, образы, которые вы используете для запуска контейнеров, можно изменить и использовать для создания новых образов, которые затем могут быть загружены (помещены) на Docker Hub или другие реестры Docker.
Давайте более подробно рассмотрим, как запускаются контейнеры.
Шаг 5 — Запуск контейнеров Docker
Контейнер hello-world , который вы запустили на предыдущем шаге, служит примером контейнера, который запускается и завершает работу после отправки тестового сообщения. Контейнеры могут быть гораздо более полезными, чем в примере выше, а также могут быть интерактивными. В конечном счете они очень похожи на виртуальные машины, но более бережно расходуют ресурсы.
В качестве примера мы запустим контейнер с самым последним образом образ Ubuntu. Сочетание переключателей -i и -t предоставляет вам доступ к интерактивной командной оболочке внутри контейнера:
Необходимо изменить приглашение к вводу команды, чтобы отразить тот факт, что вы работаете внутри контейнера, и должны иметь следующую форму:
Outputroot@d9b100f2f636:/#
Обратите внимание на идентификатор контейнер в запросе команды. В данном примере это d9b100f2f636 . Вам потребуется этот идентификатор для определения контейнера, когда вы захотите его удалить.
Теперь вы можете запустить любую команду внутри контейнера. Например, сейчас мы обновим базу данных пакетов внутри контейнера. Вам не потребуется начинать любую команду с sudo , потому что вы работаете внутри контейнера как root-пользователь:
После этого вы можете установите любое приложение внутри контейнера. Давайте установим Node.js:
Эта команда устанавливает Node.js внутри контейнера из официального репозитория Ubuntu. После завершения установки проверьте, что Node.js был установлен успешно:
Вы увидите номер версии, отображаемый в терминале:
Outputv10.19.0
Любые изменения, которые вы вносите внутри контейнера, применяются только к контейнеру.
Чтобы выйти из контейнера, введите exit .
Далее мы рассмотрим управление контейнерами в нашей системе.
Шаг 6 — Управление контейнерами Docker
После использования Docker в течение определенного времени, у вас будет много активных (запущенных) и неактивных контейнеров на компьютере. Чтобы просмотреть активные, используйте следующую команду:
Вывод будет выглядеть примерно следующим образом:
OutputCONTAINER ID IMAGE COMMAND CREATED
В этом обучающем руководстве вы запустили два контейнера: один из образа hello-world и другой из образа ubuntu . Оба контейнера больше не запущены, но все еще существуют в вашей системе.
Чтобы просмотреть все контейнеры — активные и неактивные, воспользуйтесь командой docker ps с переключателем -a :
Вывод будет выглядеть следующим образом:
1c08a7a0d0e4 ubuntu "/bin/bash" 2 minutes ago Exited (0) 8 seconds ago quizzical_mcnulty a707221a5f6c hello-world "/hello" 6 minutes ago Exited (0) 6 minutes ago youthful_curie
Чтобы просмотреть последний созданный вами контейнер, передайте переключатель -l :
Чтобы запустить остановленный контейнер, воспользуйтесь docker start с идентификатором контейнера или именем контейнера. Давайте запустим контейнер на базе Ubuntu с идентификатором 1c08a7a0d0e4 :
Контейнер будет запущен, а вы сможете использовать docker ps , чтобы просматривать его статус:
OutputCONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES 1c08a7a0d0e4 ubuntu "/bin/bash" 3 minutes ago Up 5 seconds quizzical_mcnulty
Чтобы остановить запущенный контейнер, используйте docker stop с идентификатором или именем контейнера. На этот раз мы будем использовать имя, которое Docker присвоил контейнеру, т.е. quizzical_mcnulty :
После того как вы решили, что вам больше не потребуется контейнер, удалите его с помощью команды docker rm , снова добавив идентификатор контейнера или его имя. Используйте команду docker ps -a , чтобы найти идентификатор или имя контейнера, связанного с образом hello-world , и удалить его.
Вы можете запустить новый контейнер и присвоить ему имя с помощью переключателя —name . Вы также можете использовать переключатель —rm , чтобы создать контейнер, который удаляется после остановки. Изучите команду docker run help , чтобы получить больше информации об этих и прочих опциях.
Контейнеры можно превратить в образы, которые вы можете использовать для создания новых контейнеров. Давайте посмотрим, как это работает.
Шаг 7 — Внесение изменений в контейнер для образа Docker
После запуска образа Docker вы можете создавать, изменять и удалять файлы так же, как и с помощью виртуальной машины. Эти изменения будут применяться только к данному контейнеру. Вы можете запускать и останавливать его, но после того как вы уничтожите его с помощью команды docker rm , изменения будут утрачены навсегда.
Данный раздел показывает, как сохранить состояние контейнера в виде нового образа Docker.
После установки Node.js внутри контейнера Ubuntu у вас появился контейнер, запускающий образ, но этот контейнер отличается от образа, который вы использовали для его создания. Но позже вам может снова потребоваться этот контейнер Node.js в качестве основы для новых образов.
Затем внесите изменения в новый экземпляр образа Docker с помощью следующей команды.
Переключатель -m используется в качестве сообщения о внесении изменений, которое помогает вам и остальным узнать, какие изменения вы внесли, в то время как -a используется для указания автора. container_id — это тот самый идентификатор, который вы отмечали ранее в этом руководстве, когда запускали интерактивную сессию Docker. Если вы не создавали дополнительные репозитории на Docker Hub, repository , как правило, является вашим именем пользователя на Docker Hub.
Например, для пользователя sammy с идентификатором контейнера d9b100f2f2f6 команда будет выглядеть следующим образом:
Когда вы вносите образ, новый образ сохраняется локально на компьютере. Позже в этом обучающем руководстве вы узнаете, как добавить образ в реестр Docker, например, на Docker Hub, чтобы другие могли получить к нему доступ.
Список образов Docker теперь будет содержать новый образ, а также старый образ, из которого он будет получен:
Вывод будет выглядеть следующим образом:
OutputREPOSITORY TAG IMAGE ID CREATED SIZE sammy/ubuntu-nodejs latest 7c1f35226ca6 7 seconds ago 179MB .
В данном примере ubuntu-nodejs является новым образом, который был получен из образа ubuntu на Docker Hub. Разница в размере отражает внесенные изменения. В данном примере изменение состояло в том, что NodeJS был установлен. В следующий раз, когда вам потребуется запустить контейнер, использующий Ubuntu с предустановленным NodeJS, вы сможете использовать новый образ.
Вы также можете создавать образы из Dockerfile , что позволяет автоматизировать установку программного обеспечения в новом образе. Однако это не относится к предмету данного обучающего руководства.
Теперь мы поделимся новым образом с другими, чтобы они могли создавать из него контейнеры.
Шаг 8 — Загрузка образов Docker в репозиторий Docker
Следующим логическим шагом после создания нового образа из существующего является предоставление доступа к этому образу нескольким вашим друзьям или всему миру на Docker Hub или в другом реестре Docker, к которому вы имели доступ. Чтобы добавить образ на Docker Hub или любой другой реестр Docker, у вас должна быть там учетная запись.
Данный раздел посвящен добавлению образа Docker на Docker Hub. Чтобы узнать, как создать свой собственный частный реестр Docker, ознакомьтесь со статьей Настройка частного реестра Docker на Ubuntu 14.04.
Чтобы загрузить свой образ, выполните вход в Docker Hub.
Вам будет предложено использовать для аутентификации пароль Docker Hub. Если вы указали правильный пароль, аутентификация должна быть выполнена успешно.
Примечание. Если ваше имя пользователя в реестре Docker отличается от локального имени пользователя, которое вы использовали при создании образа, вам потребуется пометить ваш образ именем пользователя в реестре. Для примера, приведенного на последнем шаге, вам необходимо ввести следующую команду:
Затем вы можете загрузить свой образ с помощью следующей команды:
Чтобы загрузить образ ubuntu-nodejs в репозиторий sammy, необходимо использовать следующую команду:
Данный процесс может занять некоторое время, необходимое на загрузку образов, но после завершения вывод будет выглядеть следующим образом:
OutputThe push refers to a repository [docker.io/sammy/ubuntu-nodejs] e3fbbfb44187: Pushed 5f70bf18a086: Pushed a3b5c80a4eba: Pushed 7f18b442972b: Pushed 3ce512daaf78: Pushed 7aae4540b42d: Pushed .
После добавления образа в реестр он должен отображаться в панели вашей учетной записи, как на изображении ниже.

Если при попытке добавления возникает подобная ошибка, вы, скорее всего, не выполнили вход:
OutputThe push refers to a repository [docker.io/sammy/ubuntu-nodejs] e3fbbfb44187: Preparing 5f70bf18a086: Preparing a3b5c80a4eba: Preparing 7f18b442972b: Preparing 3ce512daaf78: Preparing 7aae4540b42d: Waiting unauthorized: authentication required
Выполните вход с помощью команды docker login и повторите попытку загрузки. Проверьте, появился ли образ на вашей странице репозитория Docker Hub.
Теперь вы можете использовать docker pull sammy / ubuntu-nodejs , чтобы загрузить образ на новый компьютер и использовать его для запуска нового контейнера.
Заключение
В этом обучающем руководстве вы установили Docker, поработали с образами и контейнерами, а также добавили измененный образ на Docker Hub. После знакомства с основами, вы можете переходить к другим обучающим руководствам Docker в сообществе.
Thanks for learning with the DigitalOcean Community. Check out our offerings for compute, storage, networking, and managed databases.