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:重启当前运行的服务,快速应用更改。

附录和参考资料

相关推荐
qq_2290580115 分钟前
docker中检测进程的内存使用量
java·docker·容器
佑白雪乐25 分钟前
<Linux基础第10集>复习前面内容
linux·运维·服务器
java_logo27 分钟前
使用 Docker 部署 Clawdbot(官方推荐方式)
docker·容器·clawdbot·clawdbot部署·clawdbot部署手册·clawdbot部署文档·docker clawdbot
春日见28 分钟前
自动驾驶规划控制决策知识点扫盲
linux·运维·服务器·人工智能·机器学习·自动驾驶
我真的是大笨蛋28 分钟前
InnoDB行级锁解析
java·数据库·sql·mysql·性能优化·数据库开发
钦拆大仁31 分钟前
Java设计模式-单例模式
java·单例模式·设计模式
暮云星影33 分钟前
四、linux系统 应用开发:UI开发环境配置概述 (三)
linux·ui·arm
小手cool1 小时前
在保持数组中对应元素(包括负数和正数)各自组内顺序不变的情况下,交换数组中对应的负数和正数元素
java
笨手笨脚の1 小时前
深入理解 Java 虚拟机-04 垃圾收集器
java·jvm·垃圾收集器·垃圾回收
skywalker_111 小时前
Java中异常
java·开发语言·异常