目录
我们知道使用一个Dockerfile模板文件可以定义一个单独的应用容器,如果需要定义多个容器就需要服务编排。下面介绍Docker官方产品,Docker Compose。
容器编排管理与传统的容器管理的区别
传统的容器管理
- Dockerfile文件
- 手动执行 docker build 一个个镜像的构建
- 手动执行 docker run 一个个容器的创建和启动
容器编排管理
- Dockerfile文件
- 在docker-compose.yml配置模板文件里定义容器启动参数和依赖关系
- 执行docker-compose命令指定配置模板文件,根据模板文件的配置一键完成所有镜像的构建和容器的创建启动
什么Docker-Compose?
Docker-Compose的简介
- 一个可以实现在单机上对容器集群编排管理的工具。
- 使用python开发的,能运行docker的平台也都能用docker-compose编排管理容器。
- 就是在yaml格式的docker-compose配置模板文件里定义一个或多个服务及其容器的启动参数和依赖关系,并使用docker-compose命令根据配置模板文件中的参数来启动和管理容器。
Docker-Compose的作用
- 一个Dockerfile模板文件可以定义一个单独的应用容器
- Docker Compose作为Docker官方产品可以服务编排定义多个容器
Docker-compose的三大概念
项目project
- 包含一个或多个服务service
- 默认使用项目的目录名作为project的项目名,也支持使用 -p 或 --project-name 选项指定项目名称
- 项目目录里要包含一个docker-compose配置模板文件,默认为docker-compose.yml,也支持使用 -f 或 --file 选项指定项目的配置模板文件
服务service
- 包含容器container的镜像、端口映射、数据卷、环境变量、依赖关系等启动参数
- 在配置模板文件里要包含一个或多个服务及其容器的配置,每个服务要包含容器的名称、镜像、映射端口、数据卷、网络模式、依赖关系等容器的启动参数。
容器container
- 在配置模板文件里要包含一个或多个服务及其容器的配置,每个服务要包含容器的名称、镜像、映射端口、数据卷、网络模式、依赖关系等容器的启动参数。
什么YAML文件?
YAML文件介绍
- YAML 是一种标记语言,它可以很直观的展示数据序列化格式,可读性高。
- 类似于 json 数据描述语言,语法比 json 简单的很多。YAML 数据结构通过缩进来表示,连续的项目通过减号来表示,键值对用冒号分隔,数组用中括号 [ ] 括起来, hash 用花括号 { } 括起来。
使用YAML时的注意事项
- 大小写敏感
- 通过缩进表示层级关系
- 只能使用空格缩进不能使用tab键
- 可以使用井号键进行注释
- 符号字符都有一个空格 如test:
- 单引号起来的字符,会被当作普通字符串处理。"#&" 双引号里面如果是特殊字符,就表示本意
- '$' 表示普通字符串
- "$" 表示就是$
YAML文件的基本数据结构
yaml格式文件
- 文件名以 .yaml .yml 为后缀,用 空格缩进 表示字段的层级关系
特点
- 可读性高,易于管理
#一级字段
key1: value1 #一个key只有一个值,值的类型为 纯量
key2:
- value1 #一个key有多个值的纵向格式,值的类型为 列表
- value2
key3: ["value1", "value2"] #一个key有多个值的横向格式,值的类型为 数组
key4:
#二级字段
subkey1: value1 #用 空格缩进 表示字段的层级关系,同一层字段要靠左对齐
subkey2:value2
subkey3: #key的值也是键值对,值的类型为 对象
#三级字段
sskey1: value1
sskey2: value2
json格式文件
- 文件名以 .json 为后缀,用 大括号{} 表示字段的层级关系,每层字段除了最后一个
- 字段都要用逗号 , 结尾
特点
- 易于编程语言的api接口解析
#一级字段
{
"key1": ["value1"],
"key2": ["value2", "value3"],
"key3": {
#二级字段
"subkey1": ["value1"],
"subkey2": ["value2"],
"subkey3": {
#三级字段
"sskey1": ["value1"],
"sskey2": ["value2"]
}
}
}
key1: 值相当于echo "helloworld"
hello
world
key2: | 值相当于echo -e "hello\nworld" #key: | 表示保留文本块中的换行符
hello
world
key3: |- 值相当于echo -e "hello\nworld\c"
hello
world
key4: |+ 值相当于echo -e "hello\nworld\n"
hello
world
key5: > hello 值相当于echo "hello world" #> 会将文本块中的回车替换为空格
world
key1: &a value1 #定义数据锚点,即定义复制的数据,相当于 a="value1"
key2: *a #引用锚点数据,值相当于为 echo $a , key2: "value1"
Docker-Compose配置常用字段
字段 | 描述 |
image | 使用本地镜像或从仓库拉取镜像创建容器 |
build | 使用dockerfile现场构建镜像创建容器 |
context | 指定dockerfile文件所在的目录路径 |
dockerfile | 指定dockerfile文件名 |
command | 设置容器的启动命令,会覆盖镜像中的CMD指令 |
container_name | 设置容器名 --name |
environment | 设置环境变量 -e -env |
networks | 设置容器使用的自定义网络和IP --ip |
network_mode | 设置容器的网络模式 --network |
ports | 设置容器端口映射 -p |
volumes | 设置数据卷挂载 -v |
volumes_from | 设置数据卷容器挂载,版本3不支持 --volumes-from |
hostname | 设置容器主机名 -h --hostname |
sysctls | 设置容器的内核参数 --sysctl |
links | 设置容器互联 --link |
privileged | 设置容器拥有root权限 --privileged |
restart | 设置容器重启策略 --restart |
depends_on | 设置容器的依赖关系 |
Docker-Compose常用命令
docker-compose [-f docker-compose.yml] up -d 根据模板文件创建并后台启动所有容器
down 根据模板文件删除所有容器
ps 根据模板文件查看所有容器状态
start|stop|restart 根据模板文件启动|停止|重启所有容器
标签:容器,Compose,单机,文件,Docker,docker,模板
From: https://blog.csdn.net/2401_83784772/article/details/140927086