Docker Compose

时间:2024-12-18 09:41:45

 原文链接:Docker Compose - Liu Zijian's Blog | 刘子健的博客

本文最后更新于 2024年12月14日

未完待续

Docker Compose是什么

Docker Compose是Docker官方的开源项目,负责实现对Docker容器的快速编排,Docker建议每个容器只运行一项服务,因为容器运行的开销很小,但是同时部署多个应用需要每个容器都单独编写Dockerfile会显得非常复杂,因而Docker官方提供了多容器部署的编排工具Docker Compose

Docker Compose允许用户通过一个单独的配置文件来定义一组相关联的应用容器为一个项目,Docker Compose可以管理多个Docker容器组成的一个应用,只需要定义好一个yaml格式的配置文件docker-compose.xml,写好多个容器之间的调用关系,然后只要一个命令就可以实现一键部署和一键启动和关闭这些容器。

Docker Compose文件格式版本有多种,这里以最为主流的3.x为例

Docker Compose安装

先去下载docker-compose的可执行文件,Docker Compose发布在GitHub上面(https://github.com/docker/compose/releases/),我下载的版本是linux64位的v2.30.3,下载地址:

  • docker-compose-linux-x86_64

安装很简单,只要将下载下来的可执行文件赋予执行权限,并链接即可,先将下载下来的文件docker-compose-linux-x86_64放到/opt目录下,然后作为可执行文件,并建立软链接

chmod +x ./docker-compose-linux-x86_64

BASH

ln -s /opt/docker-compose-linux-x86_64 /usr/local/bin/docker-compose

BASH

之后,就可以在任意目录执行docker-compose的命令了

Docker Compose文件

一个DockerCompose文件就是一个工程,工程由服务组成,服务就是一个个的应用实例,由一组关联的容器组成一个完整的业务单元就是工程

  • version docker-compose文件版本,大多用3
  • name 名称
  • services 服务,下面可以定义多个部署的应用
  • services.$app-name.image 使用的镜像,镜像:TAG
  • services.$app-name.container_name 容器名
  • services.$app-name.environment 环境变量,- NAME=VALUE
  • services.$app-name.restart 自启动always
  • services.$app-name.command 自定义命令行参数,[""]
  • services.$app-name.ports 端口映射,宿主机端口:容器内端口
  • services.$app-name.volumes 数据卷挂载,宿主机路径:容器内路径
  • services.$app-name.depends_on 依赖哪个服务,在哪些服务启动后再启动
  • services.$app-name.networks 使用的自定义网络
  • networks 自定义网络,供services下的应用使用
  • networks.$network-name.driver 自定义网络的类型,不设置的话默认是bridge
  • networks.$network-name.ipam.config IP地址管理,用于管理网络的IP地址分配,不设置则Docker自动分配
  • networks.$network-name.ipam.config.subnet 自定义网络的网段,192.168.1.0/24
  • networks.$network-name.ipam.config.gateway 自定义网络的网关,192.168.1.1
version: '3'

name: my-demo

services:
    app_1:
       image: demo:1.0
       container_name: demo
       environment: # 环境变量
         - NAME=VALUE

       restart: 
       command: [""]
       ports:
         - "80:80"
       volumes:
         - /data:/var/lib/data
       networks:
         - my-network

    app_2:
       image: 
       depends_on:
         - app_1
       volumes: 
         - /data:/var/data

networks:
  my-network:
    driver: bridge
    ipam:
      config:
        - subnet: 192.168.1.0/24
          gateway: 192.168.1.1

YAML

Docker Compose常用命令

docker-compose.yml文件路径下执行以下命令,如果docker-compose.yml文件的路径不是./或文件名不是默认的docker-compose.yml,你可以使用-f参数来指定文件路径和文件名。这样,DockerCompose会使用你指定的文件来运行命令。

  • docker-compose -h

    帮助

    docker-compose -h

    BASH

  • docker-compose up

    上线所有的服务

    docker-compose up 

    BASH

  • docker-compose up -d

    上线所有的服务并后台运行

    docker-compose up -d 

    BASH

  • docker-compose down

    下线并删除容器、网络、数据卷和镜像

    docker-compose down 

    BASH

  • docker-compose exec

    进入容器实例内部

    docker-compose exec 服务ID /bin/bash

    BASH

  • docker-compose ps

    展示当前docker-compose文件编排过的运行的所有容器

    docker-compose ps 

    BASH

  • docker-compose top

    展示当前docker-compose文件编排过的容器进程

    docker-compose top 

    BASH

  • docker-compose logs

    查看容器输出的日志

    docker-compose logs  服务ID 

    BASH

  • docker-compose config

    检查配置是否有语法错误

    docker-compose config  

    BASH

  • docker-compose -q

    检查配置,有问题的才输出

    docker-compose -q  

    BASH

  • docker-compose restart

    重启服务

    docker-compose restart  

    BASH

  • docker-compose start

    启动服务

    docker-compose start 

    BASH

  • docker-compose stop

    停止服务

    docker-compose stop 

    BASH

  • docker-compose scale

    扩容,将服务名为app的应用扩容3份

    docker-compose scale app×3