原文链接: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