以下是 docker-compose 文件的常用字段分类和用途解析,附带简单的范例说明。
- 基础配置
-
version指定 docker-compose 文件的版本,例如 3.9 是常见的版本。范例:用于定义文件规范的版本。
-
services定义多个服务,每个服务表示一个容器。范例:包括服务名称、镜像信息和容器配置。
- 服务相关字段
-
image指定容器运行所需的镜像。范例:如 nginx:1.21.6 表示使用 Nginx 指定版本。
-
build用于构建镜像,可以指定构建上下文和 Dockerfile 文件路径。范例:适合需要自定义镜像的场景。
-
container_name定义容器名称,便于管理和调试。范例:如 my_nginx。
-
ports映射主机和容器之间的端口。范例:将主机 8080 映射到容器的 80。
-
volumes挂载数据卷,用于数据持久化或主机与容器间文件共享。范例:挂载主机目录到容器目录。
-
environment定义环境变量,支持数组或键值对格式。范例:设置 NODE_ENV=production。
-
env_file从外部文件加载环境变量。范例:如使用 .env 文件。
-
depends_on设置服务启动顺序。范例:如 web 服务依赖 db 和 redis。
- 网络与资源管理
-
networks定义网络,用于服务间通信。范例:可设置 bridge 网络驱动。
-
restart定义容器的重启策略。范例:如 always 表示容器总是自动重启。
-
resources设置容器的 CPU 和内存资源限制。范例:限制 CPU 使用为 0.5 个核心。
- 运行与初始化配置
-
command替代容器的默认启动命令。范例:如运行 npm start。
-
entrypoint覆盖镜像的入口点。范例:如使用自定义脚本 /usr/bin/entrypoint.sh。
-
working_dir设置容器的工作目录。范例:如 /app。
-
tty启用伪终端模式。范例:适合需要交互式调试的场景。
-
stdin_open启用容器的交互模式。范例:如 true。
-
healthcheck定义容器健康检查。范例:通过 curl 检查 HTTP 服务状态。
-
init使用 init 系统处理僵尸进程。范例:如设置为 true。
- 高级功能
-
scale定义服务实例的数量。范例:设置服务副本数为 3。
-
secrets使用 Docker Secrets 管理敏感数据。范例:如加载文件中的数据库密码。
-
deploy部署配置,适用于 Docker Swarm。范例:定义服务副本数和更新策略。
- 全局配置
-
volumes定义全局数据卷,供多个服务使用。范例:如 db_data。
-
networks定义全局网络,支持自定义网络驱动。范例:如 app_network 使用 bridge。
-
configs管理配置文件,类似于 secrets。范例:挂载应用程序配置到容器。
模板: