Docker三剑客之docker-compose

docker-compose 是 Docker 生态系统中的一个重要成员,它允许开发人员使用一个简单的配置文件来定义和运行多个 Docker 容器。通过 docker-compose,你可以定义应用程序的各个组件、容器之间的依赖关系以及网络配置,从而实现在一个命令中启动、停止和管理整个应用程序栈。

安装 docker-compose

我们之前有篇文章Docker 及 Docker Compose 安装指南介绍过docker和docker-compose 的安装,家人们可以查阅下。我们在这块在介绍下docker-compose的安转。

从github上下载docker-compose二进制文件安装

  • 下载最新版的docker-compose文件

官方文档地址:docs.docker.com/compose/ins...

下载地址

github.com/docker/comp...

  • 将文件放到 /usr/local/bin/下并重命名
bash 复制代码
cd /usr/local/bin/
mv docker-compose-linux-x86_64 docker-compose
  • 添加可执行权限
bash 复制代码
cd /usr/local/bin/
sudo chmod +x docker-compose
  • 测试安装结果

docker-compose --version

显示 Docker Compose version v2.5.0 则表示已经安装成功了

编写 docker-compose.yml 文件

docker-compose 使用一个名为 docker-compose.yml 的文件来定义应用程序的组件和配置。这个文件使用 YAML 格式,因此可读性良好,并且易于编写和维护。

以下是一个mysql8.0的示例,展示了如何定义一个 mysql数据库服务:

yaml 复制代码
#这个文件使用的 Docker Compose 版本。在这个例子中,使用的是版本3.3。
version: '3.3'
# 定义了一个名为 mysql-db 的服务。这个服务将会创建一个 MySQL 数据库容器。
services:

  mysql-db:
    # 指定容器的名称
    container_name: mysql     
    # 指定镜像和版本
    image: mysql:8.0  
    #将容器内的端口 3306 映射到宿主机的端口 3306。这允许在宿主机上通过端口 3306 访问 MySQL 服务器。
    ports:
      - "3306:3306"
    #配置容器的重启策略为 always,这意味着当容器退出时会自动重启。
    restart: always
    # 容器日志大小配置
    logging:
      driver: 'json-file'
      options:
        max-size: '5g'
    #设置容器内的环境变量 MYSQL_ROOT_PASSWORD,用于配置 MySQL 数据库的 root 用户密码为 xj2022。
    environment:
      # 配置root密码
      MYSQL_ROOT_PASSWORD: xj2022
    #设置数据卷挂载
    volumes:
      # 挂载数据目录
      - "./mysql/data:/var/lib/mysql" 
      # 挂载配置文件目录
      - "./mysql/config:/etc/mysql/conf.d"     

常用命令

此处所有命令均在docker-compose.yml 同级目录下使用

  • 启动服务

    docker-compose up

后台启动

复制代码
docker-compose up -d

使用 docker-compose up 命令可以启动你在配置文件中定义的所有服务。加上 -d 参数可以在后台运行它们。

常用参数的详细解释:

  • -d 或 --detach:以"分离模式"运行,即在后台运行容器,不会阻塞终端。

  • --build:在启动之前构建服务的镜像。如果 docker-compose.yml 中有 build 配置,使用这个选项可以强制重新构建镜像。

  • --force-recreate:在启动之前强制重新创建容器。即使容器已经存在,也会停止并重新创建它们。

  • --no-deps:不启动依赖的服务。默认情况下,docker-compose up 会启动所有依赖的服务,但使用此选项可以避免启动它们。

  • --scale SERVICE=NUM:指定要扩展的服务和容器实例数量。

  • 停止服务

    docker-compose down

使用 docker-compose down 命令可以停止并移除所有相关的容器、网络和存储卷。

  • 查看日志

    docker-compose logs -f

使用 docker-compose logs 命令可以查看指定服务的日志输出。

常用参数的详细解释:

  • -f 或 --follow:实时跟踪日志输出,类似于 tail -f 命令。当新日志输出产生时,会自动显示在终端上。
  • --tail=<数值>:仅显示指定行数的日志。例如,--tail=100 将仅显示最后的 100 行日志。
  • --timestamps:在日志输出中包含时间戳。
  • --no-color:禁止使用颜色编码显示日志。
  • -t 或 --timestamps:在日志输出中显示时间戳。
  • --since=<时间戳或持续时间>:仅显示从指定时间戳开始的日志,或从指定的持续时间内的日志。例如,--since="2023-08-01" 或 --since="2h30m"。
  • --until=<时间戳或持续时间>:仅显示直到指定时间戳为止的日志,或在指定的持续时间内的日志。例如,--until="2023-08-15" 或 --until="1h"。

总结

docker-compose 是一个强大的工具,能够简化多个 Docker 容器的定义、管理和交互。它使开发人员能够轻松地在本地环境中模拟复杂的应用程序栈,加速开发和测试流程。通过编写清晰的 docker-compose.yml 文件,并结合 docker-compose 提供的命令,你可以以更高效的方式构建和管理容器化的应用程序。无论是小型项目还是大规模系统,docker-compose 都是一个不可或缺的工具,助力你更好地驾驭 Docker 的强大能力。

相关推荐
武子康5 分钟前
大数据-252 离线数仓 - Airflow + Crontab 入门实战:定时调度、DAG 编排与常见报错排查
大数据·后端·apache hive
程序员Terry36 分钟前
RocketMQ 使用指南
后端·rocketmq
AI茶水间管理员41 分钟前
OpenClaw 的 Token 消耗怎么计算?(附实操优化方案)
后端
星浩AI42 分钟前
现在最需要被 PUA 的,其实是 AI
人工智能·后端·github
程序员老赵1 小时前
超全 Docker 镜像源配置指南|Windows/Mac/Linux一键搞定,拉镜像再也不卡顿
linux·后端·容器
JavaGuide1 小时前
MiniMax M2.7 发布!Redis 故障排查 + 跨语言重构场景实测,表现如何?
redis·后端·ai·ai编程
架构师沉默1 小时前
程序员真的要失业了吗?
java·后端·架构
于先生吖2 小时前
SpringBoot+Vue 前后端分离短剧漫剧系统开发实战
vue.js·spring boot·后端
shengjk12 小时前
我用 EXISTS 把一条 SQL 从 18 秒优化到 6 秒,同事以为我改了索引
后端