Docker Compose --- 管理多容器应用

用于定义和运行多容器 Docker 应用程序。通过 Compose,用户可以使用 YAML 文件来配置应用程序的服务、网络和卷等资源

简化多容器的管理和部署过程

以下compose.yaml示例展示如何部署两个服务WordPress 和 MySQL的环境

复制代码
version: '3.8'  # 指定 Docker Compose 文件的版本

services:  # 定义服务
  mysql:  # MySQL 服务配置
    container_name: mysql_db  # 容器的名称
    image: mysql:8.0  # 使用的 Docker 镜像及其版本
    ports:  # 映射端口
      - "3306:3306"  # 将主机的 3306 端口映射到容器的 3306 端口
    environment:  # 设置环境变量
      MYSQL_ROOT_PASSWORD: 123456  # MySQL 根用户的密码
      MYSQL_DATABASE: wordpress  # 创建的默认数据库名称
    volumes:  # 数据卷配置
      - mysql-data:/var/lib/mysql  # 将 MySQL 数据存储在名为 mysql-data 的卷中
      - ./myconf:/etc/mysql/conf.d  # 将本地配置文件目录挂载到容器中
    restart: always  # 容器崩溃时自动重启
    networks:  # 指定网络
      - blog_network  # 使用名为 blog_network 的网络

  wordpress:  # WordPress 服务配置
    image: wordpress  # 使用的 Docker 镜像(WordPress)
    ports:  # 映射端口
      - "8080:80"  # 将主机的 8080 端口映射到容器的 80(HTTP)端口
    environment:  # 设置环境变量
      WORDPRESS_DB_HOST: mysql_db  # MySQL 数据库主机名(与 MySQL 服务名称相同)
      WORDPRESS_DB_USER: root  # 用于连接数据库的用户名
      WORDPRESS_DB_PASSWORD: 123456  # 用于连接数据库的用户密码
      WORDPRESS_DB_NAME: wordpress  # WordPress 使用的数据库名称
    volumes:  # 数据卷配置
      - wordpress_data:/var/www/html  # 将 WordPress 数据存储在名为 wordpress_data 的卷中
    restart: always  # 容器崩溃时自动重启
    networks:  # 指定网络
      - blog_network  # 使用名为 blog_network 的网络
    depends_on:  # 定义依赖关系
      - mysql  # 确保 MySQL 服务在 WordPress 启动之前运行

volumes:  # 定义数据卷
  mysql-data:  # MySQL 数据存储卷
  wordpress_data:  # WordPress 数据存储卷

networks:  # 定义网络
  blog_network:  # 自定义网络,用于连接服务之间的通信

参数描述:

  • version:指定 Docker Compose 文件使用的版本,确保兼容性。
  • services:定义应用中的各个服务。
  • container_name:自定义容器名称,便于管理和识别。
  • image:指定要使用的 Docker 镜像及其版本。
  • ports:映射主机和容器之间的端口,使外部可以访问服务。
  • environment:设置环境变量,供容器内应用使用。
  • volumes:定义数据卷,用于持久化数据存储和配置文件。
  • restart:设置容器重启策略,以提高应用稳定性。
  • networks:定义服务之间的网络,使它们能够相互通信。
  • depends_on:指定服务启动顺序,确保依赖服务先启动。

命令

准备好 docker-compose.yaml 文件后,就可以通过以下命令轻松启动、停止和管理应用:

启动应用

默认情况会去启动compose.yaml

复制代码
docker  compose  up

如果要指定yaml名称和启动多个可以用 -f

复制代码
docker compose -d -f compose.yaml -f sqlcom.yaml up

停止应用

默认都是compose.yaml

复制代码
docker compose  stop

停止并清除所有服务

复制代码
docker compose down

重启服务

复制代码
docker compose restart
  • -d:在后台运行容器,不阻塞终端。
  • -f <filename>:指定要使用的 Docker Compose 文件,可以多个文件一起使用,以便覆盖或扩展配置。
  • up:启动和创建服务,必要时更新已有容器。
  • stop:停止正在运行的服务,但不删除容器,可以随时重启。
  • down:停止并删除服务及其相关资源,适合清理环境。
  • restart:重启当前运行的服务,快速应用更改。

附录和参考资料

相关推荐
weixin_5231853214 小时前
Collections.unmodifiableMap详解:真的不可修改吗?
java·linux·前端
点燃大海14 小时前
SpringAI构建智能体
java·spring boot·spring·springai智能体
xier_ran14 小时前
【infra之路】02_RadixAttention与KV_Cache管理
java·spring boot·spring
黑马师兄14 小时前
RAG混合检索深度解析:让AI真正找到你要的内容
java·人工智能·ai·agent·rag·ai-native
码客日记14 小时前
Spring Boot 配置文件敏感信息加密(Jasypt 企业级完整方案)
java·spring boot·git
天天进步201514 小时前
Tunnelto 源码解析 #9:控制服务器设计:Warp、WebSocket、Ping/Pong 与连接保活
运维·服务器·websocket
My is 李豆14 小时前
CentOS 7 安装 Docker 完整教程(含 docker-compose 插件)
docker·eureka·centos
凡人叶枫15 小时前
Effective C++ 条款04:确定对象被使用前已先被初始化
java·linux·开发语言·c++·嵌入式开发
杨运交15 小时前
[030][Web模块]Spring Boot 验证与 OpenAPI 集成实战:从校验规则到文档生成
前端·spring boot·python
云栖梦泽15 小时前
玩转RK3506SDK
linux·嵌入式硬件