253 lines
5.9 KiB
Markdown
253 lines
5.9 KiB
Markdown
|
# Шпаргалка по Dockerfile и docker-compose
|
|||
|
|
|||
|
Эта шпаргалка содержит основные команды и примеры использования Dockerfile и docker-compose. Полезно для быстрой настройки и работы с Docker.
|
|||
|
|
|||
|
---
|
|||
|
|
|||
|
## Dockerfile
|
|||
|
|
|||
|
### Основные инструкции Dockerfile:
|
|||
|
|
|||
|
1. **FROM**
|
|||
|
Указывает базовый образ:
|
|||
|
```dockerfile
|
|||
|
FROM <base_image>
|
|||
|
```
|
|||
|
Пример:
|
|||
|
```dockerfile
|
|||
|
FROM python:3.10-slim
|
|||
|
```
|
|||
|
|
|||
|
2. **WORKDIR**
|
|||
|
Устанавливает рабочую директорию в контейнере:
|
|||
|
```dockerfile
|
|||
|
WORKDIR /app
|
|||
|
```
|
|||
|
|
|||
|
3. **COPY**
|
|||
|
Копирует файлы из локальной системы в образ:
|
|||
|
```dockerfile
|
|||
|
COPY <source> <destination>
|
|||
|
```
|
|||
|
Пример:
|
|||
|
```dockerfile
|
|||
|
COPY . /app
|
|||
|
```
|
|||
|
|
|||
|
4. **RUN**
|
|||
|
Выполняет команды внутри образа при сборке:
|
|||
|
```dockerfile
|
|||
|
RUN <command>
|
|||
|
```
|
|||
|
Пример:
|
|||
|
```dockerfile
|
|||
|
RUN apt-get update && apt-get install -y build-essential
|
|||
|
```
|
|||
|
|
|||
|
5. **CMD**
|
|||
|
Определяет команду, выполняемую при запуске контейнера:
|
|||
|
```dockerfile
|
|||
|
CMD ["executable", "arg1", "arg2"]
|
|||
|
```
|
|||
|
Пример:
|
|||
|
```dockerfile
|
|||
|
CMD ["python", "app.py"]
|
|||
|
```
|
|||
|
|
|||
|
6. **ENTRYPOINT**
|
|||
|
Устанавливает основную команду для контейнера:
|
|||
|
```dockerfile
|
|||
|
ENTRYPOINT ["executable", "arg1"]
|
|||
|
```
|
|||
|
|
|||
|
7. **EXPOSE**
|
|||
|
Указывает порт, используемый контейнером:
|
|||
|
```dockerfile
|
|||
|
EXPOSE <port>
|
|||
|
```
|
|||
|
|
|||
|
8. **ENV**
|
|||
|
Устанавливает переменные окружения:
|
|||
|
```dockerfile
|
|||
|
ENV <key>=<value>
|
|||
|
```
|
|||
|
|
|||
|
9. **VOLUME**
|
|||
|
Определяет точки монтирования для данных:
|
|||
|
```dockerfile
|
|||
|
VOLUME ["/data"]
|
|||
|
```
|
|||
|
|
|||
|
10. **LABEL**
|
|||
|
Добавляет метаданные к образу:
|
|||
|
```dockerfile
|
|||
|
LABEL maintainer="your_email@example.com"
|
|||
|
```
|
|||
|
|
|||
|
### Пример Dockerfile:
|
|||
|
```dockerfile
|
|||
|
FROM python:3.10-slim
|
|||
|
WORKDIR /app
|
|||
|
COPY requirements.txt .
|
|||
|
RUN pip install -r requirements.txt
|
|||
|
COPY . .
|
|||
|
EXPOSE 8000
|
|||
|
CMD ["uvicorn", "main:app", "--host", "0.0.0.0", "--port", "8000"]
|
|||
|
```
|
|||
|
|
|||
|
---
|
|||
|
|
|||
|
## docker-compose.yml
|
|||
|
|
|||
|
### Основные элементы docker-compose:
|
|||
|
|
|||
|
1. **version**
|
|||
|
Указывает версию файла Compose:
|
|||
|
```yaml
|
|||
|
version: "3.8"
|
|||
|
```
|
|||
|
|
|||
|
2. **services**
|
|||
|
Определяет сервисы и их параметры:
|
|||
|
```yaml
|
|||
|
services:
|
|||
|
app:
|
|||
|
image: <image_name>
|
|||
|
```
|
|||
|
|
|||
|
3. **build**
|
|||
|
Указывает путь к Dockerfile для сборки образа:
|
|||
|
```yaml
|
|||
|
build:
|
|||
|
context: .
|
|||
|
```
|
|||
|
|
|||
|
4. **ports**
|
|||
|
Пробрасывает порты контейнера на хост:
|
|||
|
```yaml
|
|||
|
ports:
|
|||
|
- "8000:8000"
|
|||
|
```
|
|||
|
|
|||
|
5. **volumes**
|
|||
|
Монтирует директории или создаёт тома:
|
|||
|
```yaml
|
|||
|
volumes:
|
|||
|
- ./app:/app
|
|||
|
```
|
|||
|
|
|||
|
6. **environment**
|
|||
|
Передаёт переменные окружения:
|
|||
|
```yaml
|
|||
|
environment:
|
|||
|
- KEY=value
|
|||
|
```
|
|||
|
|
|||
|
7. **depends_on**
|
|||
|
Указывает зависимости между сервисами:
|
|||
|
```yaml
|
|||
|
depends_on:
|
|||
|
- db
|
|||
|
```
|
|||
|
|
|||
|
8. **networks**
|
|||
|
Настраивает сети:
|
|||
|
```yaml
|
|||
|
networks:
|
|||
|
- my_network
|
|||
|
```
|
|||
|
|
|||
|
### Пример docker-compose.yml:
|
|||
|
```yaml
|
|||
|
version: "3.8"
|
|||
|
services:
|
|||
|
app:
|
|||
|
build:
|
|||
|
context: .
|
|||
|
ports:
|
|||
|
- "8000:8000"
|
|||
|
volumes:
|
|||
|
- ./app:/app
|
|||
|
environment:
|
|||
|
- DATABASE_URL=postgres://postgres:password@db:5432/postgres
|
|||
|
depends_on:
|
|||
|
- db
|
|||
|
db:
|
|||
|
image: postgres:15
|
|||
|
environment:
|
|||
|
POSTGRES_USER: postgres
|
|||
|
POSTGRES_PASSWORD: password
|
|||
|
POSTGRES_DB: postgres
|
|||
|
volumes:
|
|||
|
- db_data:/var/lib/postgresql/data
|
|||
|
volumes:
|
|||
|
db_data:
|
|||
|
```
|
|||
|
|
|||
|
---
|
|||
|
|
|||
|
## Полезные команды Docker
|
|||
|
|
|||
|
### Работа с образами:
|
|||
|
1. Сборка образа:
|
|||
|
```bash
|
|||
|
docker build -t <image_name> .
|
|||
|
```
|
|||
|
2. Просмотр образов:
|
|||
|
```bash
|
|||
|
docker images
|
|||
|
```
|
|||
|
3. Удаление образа:
|
|||
|
```bash
|
|||
|
docker rmi <image_id>
|
|||
|
```
|
|||
|
|
|||
|
### Работа с контейнерами:
|
|||
|
1. Запуск контейнера:
|
|||
|
```bash
|
|||
|
docker run --name <container_name> -p 8000:8000 <image_name>
|
|||
|
```
|
|||
|
2. Просмотр запущенных контейнеров:
|
|||
|
```bash
|
|||
|
docker ps
|
|||
|
```
|
|||
|
3. Остановка контейнера:
|
|||
|
```bash
|
|||
|
docker stop <container_id>
|
|||
|
```
|
|||
|
4. Удаление контейнера:
|
|||
|
```bash
|
|||
|
docker rm <container_id>
|
|||
|
```
|
|||
|
|
|||
|
### Работа с docker-compose:
|
|||
|
1. Запуск всех сервисов:
|
|||
|
```bash
|
|||
|
docker-compose up
|
|||
|
```
|
|||
|
2. Остановка всех сервисов:
|
|||
|
```bash
|
|||
|
docker-compose down
|
|||
|
```
|
|||
|
3. Пересборка образов и перезапуск:
|
|||
|
```bash
|
|||
|
docker-compose up --build
|
|||
|
```
|
|||
|
4. Перезапуск контейнеров без пересборки:
|
|||
|
```bash
|
|||
|
docker-compose up --force-recreate
|
|||
|
```
|
|||
|
5. Просмотр логов:
|
|||
|
```bash
|
|||
|
docker-compose logs
|
|||
|
```
|
|||
|
|
|||
|
---
|
|||
|
|
|||
|
## Полезные советы:
|
|||
|
1. Используйте `.env` для хранения конфиденциальных данных.
|
|||
|
2. Всегда сохраняйте данные сервисов через тома (`volumes`).
|
|||
|
3. Для разработки монтируйте код в контейнер с помощью `volumes`, чтобы изменения были видны сразу.
|
|||
|
4. Оптимизируйте Dockerfile, удаляя ненужные слои и файлы после установки зависимостей.
|
|||
|
|