【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

相关推荐
加上音乐2 小时前
windows—wsl2—docker配置代理以push/pull
windows·docker·容器
青靴7 小时前
用 Docker Compose 管理留言板多容器应用
运维·docker·容器
Radan小哥7 小时前
Docker学习笔记---day002
笔记·学习·docker
roman_日积跬步-终至千里12 小时前
【Docker多节点部署】基于“配置即身份“理念的 Docker 多节点 StarRocks 高可用集群自动化部署方案
java·docker·微服务
piepis12 小时前
Doris Docker 完整部署指南
数据仓库·docker·doris·容器部署
sg_knight16 小时前
Docker 实战:如何限制容器的内存使用大小
java·spring boot·spring·spring cloud·docker·容器·eureka
电棍23316 小时前
在docker a100云服务器运行vulkan->sapien->robotwin的经验(报错segmentation fault)
运维·docker·容器
MichaelCoCoQ21 小时前
Zabbix监控K8S的PV卷
容器·kubernetes·负载均衡·zabbix·运维开发
似水流年 光阴已逝21 小时前
k8s中的StatefulSet 控制器
云原生·容器·kubernetes