【Docker】Compose

Docker Compose 是 Docker 官方提供的容器编排工具 ,用于通过一个配置文件(docker-compose.yml)定义和管理多个关联的 Docker 容器,实现多容器应用一键启动、停止、构建和管理

(dockerfile是构建镜像,docker-compose.yml管理多个容器的运行

流程

  1. 编写配置文件 :创建 docker-compose.yml,定义所有服务(容器)的配置。
  2. 启动应用 :执行 docker-compose up 一键启动所有容器。
  3. 管理应用 :通过 docker-compose stop(停止)、docker-compose down(停止并删除)等命令管理。

docker-compose.yml 配置文件

配置文件是 Compose 的核心,采用 YAML 格式,示例:

复制代码
services:               # 1. 服务定义(核心,每个服务对应一个容器)
  service1:                 # 服务名(自定义,如 frontend/backend)
    image: xxx              # 镜像来源(或 build 构建)
    ports: []               # 端口映射
    volumes: []             # 数据挂载
    depends_on: []          # 依赖的其他服务
    environment: {}         # 环境变量
    networks: []            # 所属网络
networks: {}            # 2. 自定义网络(可选)
volumes: {}             # 3. 自定义数据卷(可选)

一、启动容器(基于 docker-compose.yml

前台启动 (默认,输出实时日志,按 Ctrl+C 停止)

复制代码
docker compose up
  • 首次启动会自动构建镜像(若配置 build)、创建网络 / 卷、启动所有服务。
  • 再次执行会重启已停止的容器,保留数据。

后台启动(推荐,启动后释放终端)

复制代码
docker compose up -d

-d 表示 detach(分离模式),容器在后台运行。

二、关闭容器

停止容器(保留容器和数据)

复制代码
docker compose down
  • 停止并删除所有服务的容器(但保留镜像、数据卷、网络)。
  • 下次启动(up)可复用数据。

停止容器并清理资源

复制代码
# 停止并删除容器、网络,同时删除未被其他服务引用的数据卷
docker compose down -v
​
# 停止并删除容器、网络、数据卷,同时删除构建的镜像
docker compose down -v --rmi all
  • -v:删除关联的数据卷(谨慎使用,会丢失持久化数据)。

  • --rmi all:删除通过 build 构建的镜像(不影响拉取的镜像如 nginxmongo)。

三、其他常用命令

  • 重启容器(不重新构建,适合配置未变更时)

    复制代码
    docker compose restart
  • 查看运行状态

    复制代码
    docker compose ps
  • 查看日志(后台启动时查看输出)

    查看所有服务日志

    docker compose logs

    查看指定服务日志(如 frontend),并实时跟踪

    docker compose logs -f frontend

相关推荐
王同学 学出来8 小时前
vue+nodejs项目在服务器实现docker部署
服务器·前端·vue.js·docker·node.js
last demo9 小时前
docker容器
运维·docker·容器
海鸥819 小时前
k8s 国内无法下载docker images的分析
docker
养乐多q.♡9 小时前
docker镜像的nginx配置证书SSL,单独配置单个localtion使用证书,其他nginx配置不影响
nginx·docker·ssl
Y.O.U..9 小时前
Kurbenetes-Service(1)
容器·kubernetes
last demo11 小时前
docker镜像
运维·docker·容器
ICT董老师11 小时前
kubernetes中operator与helm有什么区别?部署mysql集群是选择operator部署还是helm chart部署?
linux·运维·mysql·云原生·容器·kubernetes
L16247612 小时前
Prometheus 监控 K8s 集群全指南(适配 K8s 特性 + 实操部署)
docker·容器·kubernetes
王旭晨12 小时前
【高并发架构】从 0 到亿,从单机部署到 K8s 编排:高并发架构的 8 级演进之路
容器·架构·kubernetes
阿方索12 小时前
Kubernetes 1.28 高可用集群安装指南(Docker 运行时)
docker·容器·kubernetes