【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

相关推荐
小章UPUP1 小时前
Kubernetes (K8s) 与 Podman 的比较
容器·kubernetes·podman
忆~遂愿1 小时前
CANN metadef 核心解析:计算图原型定义、算子元数据抽象与异构系统互操作机制
docker·容器
说实话起个名字真难啊2 小时前
用docker来安装openclaw
docker·ai·容器
恬静的小魔龙2 小时前
【群晖Nas】群晖Nas中实现SVN Server功能、Docker/ContainerManager等
docker·svn·容器
Zfox_3 小时前
CANN Catlass 算子模板库深度解析:高性能 GEMM 融合计算、Cube Unit Tiling 机制与编程范式实践
docker·云原生·容器·eureka
春日见4 小时前
如何创建一个PR
运维·开发语言·windows·git·docker·容器
DARLING Zero two♡4 小时前
告别 Docker 命令行!Portainer+cpolar 让容器管理从局域网走向公网
运维·docker·容器
liu****5 小时前
2.深入浅出理解虚拟化与容器化(含Docker实操全解析)
运维·c++·docker·容器·虚拟化技术
logocode_li6 小时前
OCI/CRI 双标准下:从 dockerd 到 containerd 的 K8s 运行时迭代史
docker·云原生·容器·k8s
_运维那些事儿17 小时前
VM环境的CI/CD
linux·运维·网络·阿里云·ci/cd·docker·云计算