Установка и настройка Docker — различия между версиями

Материал из ARK-HOSTER.RU | Документация хостинга
Перейти к: навигация, поиск
(Новая страница: «= Установка и настройка Docker = == 1. Подготовка системы == * Войдите в систему под учетной зап…»)
 
 
(не показана 1 промежуточная версия этого же участника)
Строка 6: Строка 6:
 
* Убедитесь, что у вас есть доступ к серверу через SSH или консоль.
 
* Убедитесь, что у вас есть доступ к серверу через SSH или консоль.
  
== 2. Установка Docker ===
+
== 2. Установка Docker ==
  
 
=== Установка через официальный репозиторий ===
 
=== Установка через официальный репозиторий ===
  
 
1. Обновите список пакетов:
 
1. Обновите список пакетов:
<code>
+
<pre>sudo apt update</pre>
sudo apt update
 
</code>
 
  
 
2. Установите необходимые пакеты:
 
2. Установите необходимые пакеты:
<code>
+
<pre>sudo apt install apt-transport-https ca-certificates curl gnupg lsb-release</pre>
sudo apt install apt-transport-https ca-certificates curl gnupg lsb-release
 
</code>
 
  
 
3. Добавьте официальный GPG ключ Docker:
 
3. Добавьте официальный GPG ключ Docker:
<code>
+
<pre>curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo gpg --dearmor -o /usr/share/keyrings/docker-archive-keyring.gpg</pre>
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo gpg --dearmor -o /usr/share/keyrings/docker-archive-keyring.gpg
 
</code>
 
  
 
4. Добавьте репозиторий Docker:
 
4. Добавьте репозиторий Docker:
<code>
+
<pre>echo "deb [arch=amd64 signed-by=/usr/share/keyrings/docker-archive-keyring.gpg] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable" | sudo tee /etc/apt/sources.list.d/docker.list > /dev/null</pre>
echo "deb [arch=amd64 signed-by=/usr/share/keyrings/docker-archive-keyring.gpg] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable" | sudo tee /etc/apt/sources.list.d/docker.list > /dev/null
 
</code>
 
  
 
5. Обновите список пакетов:
 
5. Обновите список пакетов:
<code>
+
<pre>sudo apt update</pre>
sudo apt update
 
</code>
 
  
 
6. Установите Docker:
 
6. Установите Docker:
<code>
+
<pre>sudo apt install docker-ce docker-ce-cli containerd.io docker-compose-plugin</pre>
sudo apt install docker-ce docker-ce-cli containerd.io docker-compose-plugin
 
</code>
 
  
 
=== Установка через snap ===
 
=== Установка через snap ===
  
 
1. Установите Docker через snap:
 
1. Установите Docker через snap:
<code>
+
<pre>sudo snap install docker</pre>
sudo snap install docker
 
</code>
 
  
 
2. Добавьте пользователя в группу docker:
 
2. Добавьте пользователя в группу docker:
<code>
+
<pre>sudo usermod -aG docker $USER</pre>
sudo usermod -aG docker $USER
 
</code>
 
  
== 3. Настройка Docker ===
+
== 3. Настройка Docker ==
  
 
=== Запуск и включение автозапуска ===
 
=== Запуск и включение автозапуска ===
  
 
1. Запустите Docker:
 
1. Запустите Docker:
<code>
+
<pre>sudo systemctl start docker</pre>
sudo systemctl start docker
 
</code>
 
  
 
2. Включите автозапуск:
 
2. Включите автозапуск:
<code>
+
<pre>sudo systemctl enable docker</pre>
sudo systemctl enable docker
 
</code>
 
  
 
3. Проверьте статус:
 
3. Проверьте статус:
<code>
+
<pre>sudo systemctl status docker</pre>
sudo systemctl status docker
 
</code>
 
  
 
=== Настройка пользователей ===
 
=== Настройка пользователей ===
  
 
1. Добавьте пользователя в группу docker:
 
1. Добавьте пользователя в группу docker:
<code>
+
<pre>sudo usermod -aG docker $USER</pre>
sudo usermod -aG docker $USER
 
</code>
 
  
 
2. Перезагрузите сессию или выполните:
 
2. Перезагрузите сессию или выполните:
<code>
+
<pre>newgrp docker</pre>
newgrp docker
 
</code>
 
  
 
3. Проверьте права:
 
3. Проверьте права:
<code>
+
<pre>docker run hello-world</pre>
docker run hello-world
 
</code>
 
  
== 4. Основы работы с Docker ===
+
== 4. Основы работы с Docker ==
  
 
=== Основные команды ===
 
=== Основные команды ===
  
 
1. '''Просмотр информации о Docker''':
 
1. '''Просмотр информации о Docker''':
<code>
+
<pre>docker --version</pre>
docker --version
+
<pre>docker info</pre>
docker info
 
</code>
 
  
 
2. '''Просмотр образов''':
 
2. '''Просмотр образов''':
<code>
+
<pre>docker images</pre>
docker images
 
</code>
 
  
 
3. '''Просмотр контейнеров''':
 
3. '''Просмотр контейнеров''':
<code>
+
<pre>docker ps</pre>
docker ps
+
<pre>docker ps -a</pre>
docker ps -a
 
</code>
 
  
 
4. '''Просмотр всех ресурсов''':
 
4. '''Просмотр всех ресурсов''':
<code>
+
<pre>docker system df</pre>
docker system df
 
</code>
 
  
 
=== Работа с образами ===
 
=== Работа с образами ===
  
 
1. '''Скачивание образа''':
 
1. '''Скачивание образа''':
<code>
+
<pre>docker pull nginx</pre>
docker pull nginx
+
<pre>docker pull ubuntu:20.04</pre>
docker pull ubuntu:20.04
 
</code>
 
  
 
2. '''Поиск образов''':
 
2. '''Поиск образов''':
<code>
+
<pre>docker search nginx</pre>
docker search nginx
 
</code>
 
  
 
3. '''Удаление образа''':
 
3. '''Удаление образа''':
<code>
+
<pre>docker rmi nginx</pre>
docker rmi nginx
+
<pre>docker rmi $(docker images -q)</pre>
docker rmi $(docker images -q)
 
</code>
 
  
 
=== Работа с контейнерами ===
 
=== Работа с контейнерами ===
  
 
1. '''Запуск контейнера''':
 
1. '''Запуск контейнера''':
<code>
+
<pre>docker run -d --name my-nginx nginx</pre>
docker run -d --name my-nginx nginx
 
</code>
 
  
 
2. '''Запуск с портами''':
 
2. '''Запуск с портами''':
<code>
+
<pre>docker run -d -p 8080:80 --name my-nginx nginx</pre>
docker run -d -p 8080:80 --name my-nginx nginx
 
</code>
 
  
 
3. '''Запуск с переменными окружения''':
 
3. '''Запуск с переменными окружения''':
<code>
+
<pre>docker run -d -e MYSQL_ROOT_PASSWORD=password --name my-mysql mysql</pre>
docker run -d -e MYSQL_ROOT_PASSWORD=password --name my-mysql mysql
 
</code>
 
  
 
4. '''Остановка контейнера''':
 
4. '''Остановка контейнера''':
<code>
+
<pre>docker stop my-nginx</pre>
docker stop my-nginx
 
</code>
 
  
 
5. '''Удаление контейнера''':
 
5. '''Удаление контейнера''':
<code>
+
<pre>docker rm my-nginx</pre>
docker rm my-nginx
 
</code>
 
  
== 5. Создание Dockerfile ===
+
== 5. Создание Dockerfile ==
  
 
=== Базовый Dockerfile ===
 
=== Базовый Dockerfile ===
  
 
1. Создайте Dockerfile:
 
1. Создайте Dockerfile:
<code>
+
<pre>nano Dockerfile</pre>
nano Dockerfile
 
</code>
 
  
 
2. Добавьте содержимое:
 
2. Добавьте содержимое:
<code>
+
<pre>FROM ubuntu:20.04</pre>
# Базовый образ
+
<pre>LABEL maintainer="admin@example.com"</pre>
FROM ubuntu:20.04
+
<pre>LABEL description="My custom application"</pre>
 
+
<pre>RUN apt update && apt install -y \</pre>
# Метаданные
+
<pre>nginx \</pre>
LABEL maintainer="admin@example.com"
+
<pre>curl \</pre>
LABEL description="My custom application"
+
<pre>&& rm -rf /var/lib/apt/lists/*</pre>
 
+
<pre>COPY index.html /var/www/html/</pre>
# Установка пакетов
+
<pre>COPY nginx.conf /etc/nginx/nginx.conf</pre>
RUN apt update && apt install -y \
+
<pre>EXPOSE 80</pre>
    nginx \
+
<pre>CMD ["nginx", "-g", "daemon off;"]</pre>
    curl \
 
    && rm -rf /var/lib/apt/lists/*
 
 
 
# Копирование файлов
 
COPY index.html /var/www/html/
 
COPY nginx.conf /etc/nginx/nginx.conf
 
 
 
# Открытие портов
 
EXPOSE 80
 
 
 
# Команда запуска
 
CMD ["nginx", "-g", "daemon off;"]
 
</code>
 
  
 
=== Создание образа ===
 
=== Создание образа ===
  
 
1. Создайте образ:
 
1. Создайте образ:
<code>
+
<pre>docker build -t my-app:latest .</pre>
docker build -t my-app:latest .
 
</code>
 
  
 
2. Создайте образ с тегом:
 
2. Создайте образ с тегом:
<code>
+
<pre>docker build -t my-app:v1.0 .</pre>
docker build -t my-app:v1.0 .
 
</code>
 
  
 
3. Запустите контейнер:
 
3. Запустите контейнер:
<code>
+
<pre>docker run -d -p 8080:80 --name my-app-container my-app:latest</pre>
docker run -d -p 8080:80 --name my-app-container my-app:latest
 
</code>
 
  
== 6. Настройка Docker Compose ===
+
== 6. Настройка Docker Compose ==
  
 
=== Установка Docker Compose ===
 
=== Установка Docker Compose ===
  
 
1. Установите Docker Compose:
 
1. Установите Docker Compose:
<code>
+
<pre>sudo apt install docker-compose</pre>
sudo apt install docker-compose
 
</code>
 
  
 
2. Проверьте версию:
 
2. Проверьте версию:
<code>
+
<pre>docker-compose --version</pre>
docker-compose --version
 
</code>
 
  
 
=== Создание docker-compose.yml ===
 
=== Создание docker-compose.yml ===
  
 
1. Создайте файл конфигурации:
 
1. Создайте файл конфигурации:
<code>
+
<pre>nano docker-compose.yml</pre>
nano docker-compose.yml
 
</code>
 
  
 
2. Добавьте содержимое:
 
2. Добавьте содержимое:
<code>
+
<pre>version: '3.8'</pre>
version: '3.8'
+
<pre>services:</pre>
 
+
<pre>web:</pre>
services:
+
<pre>image: nginx:latest</pre>
  web:
+
<pre>ports:</pre>
    image: nginx:latest
+
<pre>- "80:80"</pre>
    ports:
+
<pre>volumes:</pre>
      - "80:80"
+
<pre>- ./html:/usr/share/nginx/html</pre>
    volumes:
+
<pre>depends_on:</pre>
      - ./html:/usr/share/nginx/html
+
<pre>- app</pre>
    depends_on:
+
<pre>app:</pre>
      - app
+
<pre>image: node:16</pre>
 
+
<pre>working_dir: /app</pre>
  app:
+
<pre>volumes:</pre>
    image: node:16
+
<pre>- ./app:/app</pre>
    working_dir: /app
+
<pre>command: npm start</pre>
    volumes:
+
<pre>ports:</pre>
      - ./app:/app
+
<pre>- "3000:3000"</pre>
    command: npm start
+
<pre>database:</pre>
    ports:
+
<pre>image: mysql:8.0</pre>
      - "3000:3000"
+
<pre>environment:</pre>
 
+
<pre>MYSQL_ROOT_PASSWORD: rootpassword</pre>
  database:
+
<pre>MYSQL_DATABASE: myapp</pre>
    image: mysql:8.0
+
<pre>MYSQL_USER: user</pre>
    environment:
+
<pre>MYSQL_PASSWORD: password</pre>
      MYSQL_ROOT_PASSWORD: rootpassword
+
<pre>volumes:</pre>
      MYSQL_DATABASE: myapp
+
<pre>- mysql_data:/var/lib/mysql</pre>
      MYSQL_USER: user
+
<pre>ports:</pre>
      MYSQL_PASSWORD: password
+
<pre>- "3306:3306"</pre>
    volumes:
+
<pre>volumes:</pre>
      - mysql_data:/var/lib/mysql
+
<pre>mysql_data:</pre>
    ports:
 
      - "3306:3306"
 
 
 
volumes:
 
  mysql_data:
 
</code>
 
  
 
=== Управление Docker Compose ===
 
=== Управление Docker Compose ===
  
 
1. '''Запуск сервисов''':
 
1. '''Запуск сервисов''':
<code>
+
<pre>docker-compose up -d</pre>
docker-compose up -d
 
</code>
 
  
 
2. '''Остановка сервисов''':
 
2. '''Остановка сервисов''':
<code>
+
<pre>docker-compose down</pre>
docker-compose down
 
</code>
 
  
 
3. '''Просмотр логов''':
 
3. '''Просмотр логов''':
<code>
+
<pre>docker-compose logs</pre>
docker-compose logs
+
<pre>docker-compose logs web</pre>
docker-compose logs web
 
</code>
 
  
 
4. '''Перезапуск сервисов''':
 
4. '''Перезапуск сервисов''':
<code>
+
<pre>docker-compose restart</pre>
docker-compose restart
 
</code>
 
  
== 7. Настройка Docker Registry ===
+
== 7. Настройка Docker Registry ==
  
 
=== Установка локального Registry ===
 
=== Установка локального Registry ===
  
 
1. Запустите Docker Registry:
 
1. Запустите Docker Registry:
<code>
+
<pre>docker run -d -p 5000:5000 --name registry registry:2</pre>
docker run -d -p 5000:5000 --name registry registry:2
 
</code>
 
  
 
2. Создайте образ для Registry:
 
2. Создайте образ для Registry:
<code>
+
<pre>docker tag my-app:latest localhost:5000/my-app:latest</pre>
docker tag my-app:latest localhost:5000/my-app:latest
 
</code>
 
  
 
3. Отправьте образ в Registry:
 
3. Отправьте образ в Registry:
<code>
+
<pre>docker push localhost:5000/my-app:latest</pre>
docker push localhost:5000/my-app:latest
 
</code>
 
  
 
=== Настройка аутентификации ===
 
=== Настройка аутентификации ===
  
 
1. Создайте директорию для аутентификации:
 
1. Создайте директорию для аутентификации:
<code>
+
<pre>sudo mkdir -p /auth</pre>
sudo mkdir -p /auth
 
</code>
 
  
 
2. Создайте пользователя:
 
2. Создайте пользователя:
<code>
+
<pre>sudo htpasswd -Bbn username password > /auth/htpasswd</pre>
sudo htpasswd -Bbn username password > /auth/htpasswd
 
</code>
 
  
 
3. Запустите Registry с аутентификацией:
 
3. Запустите Registry с аутентификацией:
<code>
+
<pre>docker run -d -p 5000:5000 --name registry \</pre>
docker run -d -p 5000:5000 --name registry \
+
<pre>-v /auth:/auth \</pre>
  -v /auth:/auth \
+
<pre>-e "REGISTRY_AUTH=htpasswd" \</pre>
  -e "REGISTRY_AUTH=htpasswd" \
+
<pre>-e "REGISTRY_AUTH_HTPASSWD_REALM=Registry Realm" \</pre>
  -e "REGISTRY_AUTH_HTPASSWD_REALM=Registry Realm" \
+
<pre>-e "REGISTRY_AUTH_HTPASSWD_PATH=/auth/htpasswd" \</pre>
  -e "REGISTRY_AUTH_HTPASSWD_PATH=/auth/htpasswd" \
+
<pre>registry:2</pre>
  registry:2
 
</code>
 
  
== 8. Мониторинг Docker ===
+
== 8. Мониторинг Docker ==
  
 
=== Просмотр статистики ===
 
=== Просмотр статистики ===
  
 
1. Просмотрите статистику контейнеров:
 
1. Просмотрите статистику контейнеров:
<code>
+
<pre>docker stats</pre>
docker stats
 
</code>
 
  
 
2. Просмотрите статистику конкретного контейнера:
 
2. Просмотрите статистику конкретного контейнера:
<code>
+
<pre>docker stats my-container</pre>
docker stats my-container
 
</code>
 
  
 
3. Просмотрите использование ресурсов:
 
3. Просмотрите использование ресурсов:
<code>
+
<pre>docker system df</pre>
docker system df
 
</code>
 
  
 
=== Создание скрипта мониторинга ===
 
=== Создание скрипта мониторинга ===
  
 
1. Создайте скрипт мониторинга:
 
1. Создайте скрипт мониторинга:
<code>
+
<pre>sudo nano /usr/local/bin/docker-monitor.sh</pre>
sudo nano /usr/local/bin/docker-monitor.sh
 
</code>
 
  
 
2. Добавьте содержимое:
 
2. Добавьте содержимое:
<code>
+
<pre>echo "=== Docker Monitoring ==="</pre>
#!/bin/bash
+
<pre>echo "Date: $(date)"</pre>
 
+
<pre>echo ""</pre>
echo "=== Docker Monitoring ==="
+
<pre>if systemctl is-active --quiet docker; then</pre>
echo "Date: $(date)"
+
<pre>echo "Docker is running"</pre>
echo ""
+
<pre>else</pre>
 
+
<pre>echo "Docker is not running"</pre>
# Статус Docker
+
<pre>fi</pre>
if systemctl is-active --quiet docker; then
+
<pre>echo "Running containers: $(docker ps -q | wc -l)"</pre>
    echo "Docker is running"
+
<pre>echo "Total containers: $(docker ps -aq | wc -l)"</pre>
else
+
<pre>echo "Images: $(docker images -q | wc -l)"</pre>
    echo "Docker is not running"
+
<pre>echo "Disk usage:"</pre>
fi
+
<pre>docker system df</pre>
 
+
<pre>echo "Top containers by CPU:"</pre>
# Количество контейнеров
+
<pre>docker stats --no-stream --format "table {{.Container}}\t{{.CPUPerc}}\t{{.MemUsage}}" | head -10</pre>
echo "Running containers: $(docker ps -q | wc -l)"
 
echo "Total containers: $(docker ps -aq | wc -l)"
 
 
 
# Количество образов
 
echo "Images: $(docker images -q | wc -l)"
 
 
 
# Использование диска
 
echo "Disk usage:"
 
docker system df
 
 
 
# Топ контейнеров по использованию CPU
 
echo "Top containers by CPU:"
 
docker stats --no-stream --format "table {{.Container}}\t{{.CPUPerc}}\t{{.MemUsage}}" | head -10
 
</code>
 
  
 
3. Сделайте скрипт исполняемым:
 
3. Сделайте скрипт исполняемым:
<code>
+
<pre>sudo chmod +x /usr/local/bin/docker-monitor.sh</pre>
sudo chmod +x /usr/local/bin/docker-monitor.sh
 
</code>
 
  
== 9. Настройка сети Docker ===
+
== 9. Настройка сети Docker ==
  
 
=== Создание пользовательской сети ===
 
=== Создание пользовательской сети ===
  
 
1. Создайте сеть:
 
1. Создайте сеть:
<code>
+
<pre>docker network create my-network</pre>
docker network create my-network
 
</code>
 
  
 
2. Просмотрите сети:
 
2. Просмотрите сети:
<code>
+
<pre>docker network ls</pre>
docker network ls
 
</code>
 
  
 
3. Запустите контейнеры в сети:
 
3. Запустите контейнеры в сети:
<code>
+
<pre>docker run -d --name web --network my-network nginx</pre>
docker run -d --name web --network my-network nginx
+
<pre>docker run -d --name app --network my-network node:16</pre>
docker run -d --name app --network my-network node:16
 
</code>
 
  
 
=== Настройка моста ===
 
=== Настройка моста ===
  
 
1. Создайте мост:
 
1. Создайте мост:
<code>
+
<pre>docker network create --driver bridge --subnet=172.20.0.0/16 my-bridge</pre>
docker network create --driver bridge --subnet=172.20.0.0/16 my-bridge
 
</code>
 
  
 
2. Подключите контейнер к мосту:
 
2. Подключите контейнер к мосту:
<code>
+
<pre>docker run -d --name web --network my-bridge nginx</pre>
docker run -d --name web --network my-bridge nginx
 
</code>
 
  
== 10. Управление данными ===
+
== 10. Управление данными ==
  
 
=== Создание томов ===
 
=== Создание томов ===
  
 
1. Создайте том:
 
1. Создайте том:
<code>
+
<pre>docker volume create my-volume</pre>
docker volume create my-volume
 
</code>
 
  
 
2. Просмотрите тома:
 
2. Просмотрите тома:
<code>
+
<pre>docker volume ls</pre>
docker volume ls
 
</code>
 
  
 
3. Используйте том в контейнере:
 
3. Используйте том в контейнере:
<code>
+
<pre>docker run -d --name web -v my-volume:/var/www/html nginx</pre>
docker run -d --name web -v my-volume:/var/www/html nginx
 
</code>
 
  
 
=== Создание bind mount ===
 
=== Создание bind mount ===
  
 
1. Создайте bind mount:
 
1. Создайте bind mount:
<code>
+
<pre>docker run -d --name web -v /host/path:/container/path nginx</pre>
docker run -d --name web -v /host/path:/container/path nginx
 
</code>
 
  
 
2. Создайте read-only mount:
 
2. Создайте read-only mount:
<code>
+
<pre>docker run -d --name web -v /host/path:/container/path:ro nginx</pre>
docker run -d --name web -v /host/path:/container/path:ro nginx
 
</code>
 
  
== 11. Устранение неполадок ===
+
== 11. Устранение неполадок ==
  
 
=== Частые проблемы ===
 
=== Частые проблемы ===
  
 
1. '''Docker не запускается''':
 
1. '''Docker не запускается''':
* Проверьте статус: <code>sudo systemctl status docker</code>
+
* Проверьте статус: <pre>sudo systemctl status docker</pre>
* Проверьте логи: <code>sudo journalctl -u docker</code>
+
* Проверьте логи: <pre>sudo journalctl -u docker</pre>
* Проверьте права: <code>groups $USER</code>
+
* Проверьте права: <pre>groups $USER</pre>
  
 
2. '''Контейнеры не запускаются''':
 
2. '''Контейнеры не запускаются''':
* Проверьте логи: <code>docker logs container_name</code>
+
* Проверьте логи: <pre>docker logs container_name</pre>
* Проверьте ресурсы: <code>docker stats</code>
+
* Проверьте ресурсы: <pre>docker stats</pre>
* Проверьте образы: <code>docker images</code>
+
* Проверьте образы: <pre>docker images</pre>
  
 
3. '''Проблемы с сетью''':
 
3. '''Проблемы с сетью''':
* Проверьте сети: <code>docker network ls</code>
+
* Проверьте сети: <pre>docker network ls</pre>
* Проверьте подключения: <code>docker network inspect network_name</code>
+
* Проверьте подключения: <pre>docker network inspect network_name</pre>
  
 
=== Диагностика ===
 
=== Диагностика ===
  
 
1. Проверьте статус Docker:
 
1. Проверьте статус Docker:
<code>
+
<pre>sudo systemctl status docker</pre>
sudo systemctl status docker
 
</code>
 
  
 
2. Проверьте информацию о системе:
 
2. Проверьте информацию о системе:
<code>
+
<pre>docker info</pre>
docker info
 
</code>
 
  
 
3. Проверьте логи Docker:
 
3. Проверьте логи Docker:
<code>
+
<pre>sudo journalctl -u docker -f</pre>
sudo journalctl -u docker -f
 
</code>
 
  
 
4. Проверьте использование ресурсов:
 
4. Проверьте использование ресурсов:
<code>
+
<pre>docker system df</pre>
docker system df
+
<pre>docker stats --no-stream</pre>
docker stats --no-stream
 
</code>
 
  
== 12. Оптимизация производительности ===
+
== 12. Оптимизация производительности ==
  
 
=== Настройки производительности ===
 
=== Настройки производительности ===
  
 
1. Отредактируйте конфигурацию Docker:
 
1. Отредактируйте конфигурацию Docker:
<code>
+
<pre>sudo nano /etc/docker/daemon.json</pre>
sudo nano /etc/docker/daemon.json
 
</code>
 
  
 
2. Добавьте настройки:
 
2. Добавьте настройки:
<code>
+
<pre>{</pre>
{
+
<pre>"log-driver": "json-file",</pre>
    "log-driver": "json-file",
+
<pre>"log-opts": {</pre>
    "log-opts": {
+
<pre>"max-size": "10m",</pre>
        "max-size": "10m",
+
<pre>"max-file": "3"</pre>
        "max-file": "3"
+
<pre>},</pre>
    },
+
<pre>"storage-driver": "overlay2",</pre>
    "storage-driver": "overlay2",
+
<pre>"storage-opts": [</pre>
    "storage-opts": [
+
<pre>"overlay2.override_kernel_check=true"</pre>
        "overlay2.override_kernel_check=true"
+
<pre>]</pre>
    ]
+
<pre>}</pre>
}
 
</code>
 
  
 
3. Перезапустите Docker:
 
3. Перезапустите Docker:
<code>
+
<pre>sudo systemctl restart docker</pre>
sudo systemctl restart docker
 
</code>
 
  
 
=== Очистка системы ===
 
=== Очистка системы ===
  
 
1. Очистите неиспользуемые ресурсы:
 
1. Очистите неиспользуемые ресурсы:
<code>
+
<pre>docker system prune -a</pre>
docker system prune -a
 
</code>
 
  
 
2. Очистите только неиспользуемые образы:
 
2. Очистите только неиспользуемые образы:
<code>
+
<pre>docker image prune -a</pre>
docker image prune -a
 
</code>
 
  
 
3. Очистите неиспользуемые тома:
 
3. Очистите неиспользуемые тома:
<code>
+
<pre>docker volume prune</pre>
docker volume prune
 
</code>
 
  
 
4. Очистите неиспользуемые сети:
 
4. Очистите неиспользуемые сети:
<code>
+
<pre>docker network prune</pre>
docker network prune
 
</code>
 
  
 
== Заключение ==
 
== Заключение ==

Текущая версия на 10:42, 15 октября 2025

Содержание

Установка и настройка Docker

1. Подготовка системы

  • Войдите в систему под учетной записью с правами root или пользователя с правами sudo.
  • Убедитесь, что у вас есть доступ к серверу через SSH или консоль.

2. Установка Docker

Установка через официальный репозиторий

1. Обновите список пакетов:

sudo apt update

2. Установите необходимые пакеты:

sudo apt install apt-transport-https ca-certificates curl gnupg lsb-release

3. Добавьте официальный GPG ключ Docker:

curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo gpg --dearmor -o /usr/share/keyrings/docker-archive-keyring.gpg

4. Добавьте репозиторий Docker:

echo "deb [arch=amd64 signed-by=/usr/share/keyrings/docker-archive-keyring.gpg] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable" | sudo tee /etc/apt/sources.list.d/docker.list > /dev/null

5. Обновите список пакетов:

sudo apt update

6. Установите Docker:

sudo apt install docker-ce docker-ce-cli containerd.io docker-compose-plugin

Установка через snap

1. Установите Docker через snap:

sudo snap install docker

2. Добавьте пользователя в группу docker:

sudo usermod -aG docker $USER

3. Настройка Docker

Запуск и включение автозапуска

1. Запустите Docker:

sudo systemctl start docker

2. Включите автозапуск:

sudo systemctl enable docker

3. Проверьте статус:

sudo systemctl status docker

Настройка пользователей

1. Добавьте пользователя в группу docker:

sudo usermod -aG docker $USER

2. Перезагрузите сессию или выполните:

newgrp docker

3. Проверьте права:

docker run hello-world

4. Основы работы с Docker

Основные команды

1. Просмотр информации о Docker:

docker --version
docker info

2. Просмотр образов:

docker images

3. Просмотр контейнеров:

docker ps
docker ps -a

4. Просмотр всех ресурсов:

docker system df

Работа с образами

1. Скачивание образа:

docker pull nginx
docker pull ubuntu:20.04

2. Поиск образов:

docker search nginx

3. Удаление образа:

docker rmi nginx
docker rmi $(docker images -q)

Работа с контейнерами

1. Запуск контейнера:

docker run -d --name my-nginx nginx

2. Запуск с портами:

docker run -d -p 8080:80 --name my-nginx nginx

3. Запуск с переменными окружения:

docker run -d -e MYSQL_ROOT_PASSWORD=password --name my-mysql mysql

4. Остановка контейнера:

docker stop my-nginx

5. Удаление контейнера:

docker rm my-nginx

5. Создание Dockerfile

Базовый Dockerfile

1. Создайте Dockerfile:

nano Dockerfile

2. Добавьте содержимое:

FROM ubuntu:20.04
LABEL maintainer="admin@example.com"
LABEL description="My custom application"
RUN apt update && apt install -y \
nginx \
curl \
&& rm -rf /var/lib/apt/lists/*
COPY index.html /var/www/html/
COPY nginx.conf /etc/nginx/nginx.conf
EXPOSE 80
CMD ["nginx", "-g", "daemon off;"]

Создание образа

1. Создайте образ:

docker build -t my-app:latest .

2. Создайте образ с тегом:

docker build -t my-app:v1.0 .

3. Запустите контейнер:

docker run -d -p 8080:80 --name my-app-container my-app:latest

6. Настройка Docker Compose

Установка Docker Compose

1. Установите Docker Compose:

sudo apt install docker-compose

2. Проверьте версию:

docker-compose --version

Создание docker-compose.yml

1. Создайте файл конфигурации:

nano docker-compose.yml

2. Добавьте содержимое:

version: '3.8'
services:
web:
image: nginx:latest
ports:
- "80:80"
volumes:
- ./html:/usr/share/nginx/html
depends_on:
- app
app:
image: node:16
working_dir: /app
volumes:
- ./app:/app
command: npm start
ports:
- "3000:3000"
database:
image: mysql:8.0
environment:
MYSQL_ROOT_PASSWORD: rootpassword
MYSQL_DATABASE: myapp
MYSQL_USER: user
MYSQL_PASSWORD: password
volumes:
- mysql_data:/var/lib/mysql
ports:
- "3306:3306"
volumes:
mysql_data:

Управление Docker Compose

1. Запуск сервисов:

docker-compose up -d

2. Остановка сервисов:

docker-compose down

3. Просмотр логов:

docker-compose logs
docker-compose logs web

4. Перезапуск сервисов:

docker-compose restart

7. Настройка Docker Registry

Установка локального Registry

1. Запустите Docker Registry:

docker run -d -p 5000:5000 --name registry registry:2

2. Создайте образ для Registry:

docker tag my-app:latest localhost:5000/my-app:latest

3. Отправьте образ в Registry:

docker push localhost:5000/my-app:latest

Настройка аутентификации

1. Создайте директорию для аутентификации:

sudo mkdir -p /auth

2. Создайте пользователя:

sudo htpasswd -Bbn username password > /auth/htpasswd

3. Запустите Registry с аутентификацией:

docker run -d -p 5000:5000 --name registry \
-v /auth:/auth \
-e "REGISTRY_AUTH=htpasswd" \
-e "REGISTRY_AUTH_HTPASSWD_REALM=Registry Realm" \
-e "REGISTRY_AUTH_HTPASSWD_PATH=/auth/htpasswd" \
registry:2

8. Мониторинг Docker

Просмотр статистики

1. Просмотрите статистику контейнеров:

docker stats

2. Просмотрите статистику конкретного контейнера:

docker stats my-container

3. Просмотрите использование ресурсов:

docker system df

Создание скрипта мониторинга

1. Создайте скрипт мониторинга:

sudo nano /usr/local/bin/docker-monitor.sh

2. Добавьте содержимое:

echo "=== Docker Monitoring ==="
echo "Date: $(date)"
echo ""
if systemctl is-active --quiet docker; then
echo "Docker is running"
else
echo "Docker is not running"
fi
echo "Running containers: $(docker ps -q | wc -l)"
echo "Total containers: $(docker ps -aq | wc -l)"
echo "Images: $(docker images -q | wc -l)"
echo "Disk usage:"
docker system df
echo "Top containers by CPU:"
docker stats --no-stream --format "table {{.Container}}\t{{.CPUPerc}}\t{{.MemUsage}}" | head -10

3. Сделайте скрипт исполняемым:

sudo chmod +x /usr/local/bin/docker-monitor.sh

9. Настройка сети Docker

Создание пользовательской сети

1. Создайте сеть:

docker network create my-network

2. Просмотрите сети:

docker network ls

3. Запустите контейнеры в сети:

docker run -d --name web --network my-network nginx
docker run -d --name app --network my-network node:16

Настройка моста

1. Создайте мост:

docker network create --driver bridge --subnet=172.20.0.0/16 my-bridge

2. Подключите контейнер к мосту:

docker run -d --name web --network my-bridge nginx

10. Управление данными

Создание томов

1. Создайте том:

docker volume create my-volume

2. Просмотрите тома:

docker volume ls

3. Используйте том в контейнере:

docker run -d --name web -v my-volume:/var/www/html nginx

Создание bind mount

1. Создайте bind mount:

docker run -d --name web -v /host/path:/container/path nginx

2. Создайте read-only mount:

docker run -d --name web -v /host/path:/container/path:ro nginx

11. Устранение неполадок

Частые проблемы

1. Docker не запускается:

  • Проверьте статус:
    sudo systemctl status docker
  • Проверьте логи:
    sudo journalctl -u docker
  • Проверьте права:
    groups $USER

2. Контейнеры не запускаются:

  • Проверьте логи:
    docker logs container_name
  • Проверьте ресурсы:
    docker stats
  • Проверьте образы:
    docker images

3. Проблемы с сетью:

  • Проверьте сети:
    docker network ls
  • Проверьте подключения:
    docker network inspect network_name

Диагностика

1. Проверьте статус Docker:

sudo systemctl status docker

2. Проверьте информацию о системе:

docker info

3. Проверьте логи Docker:

sudo journalctl -u docker -f

4. Проверьте использование ресурсов:

docker system df
docker stats --no-stream

12. Оптимизация производительности

Настройки производительности

1. Отредактируйте конфигурацию Docker:

sudo nano /etc/docker/daemon.json

2. Добавьте настройки:

{
"log-driver": "json-file",
"log-opts": {
"max-size": "10m",
"max-file": "3"
},
"storage-driver": "overlay2",
"storage-opts": [
"overlay2.override_kernel_check=true"
]
}

3. Перезапустите Docker:

sudo systemctl restart docker

Очистка системы

1. Очистите неиспользуемые ресурсы:

docker system prune -a

2. Очистите только неиспользуемые образы:

docker image prune -a

3. Очистите неиспользуемые тома:

docker volume prune

4. Очистите неиспользуемые сети:

docker network prune

Заключение

Docker успешно установлен и настроен! Теперь вы можете использовать контейнеризацию для ваших приложений.

Для размещения ваших Docker контейнеров на надежном хостинге рекомендуем воспользоваться услугами [ARK-HOSTER.RU](https://ark-hoster.ru):

Наши специалисты помогут с настройкой Docker и оптимизацией производительности ваших контейнеров!