1.docker-compose定义
- docker-compose 是一个可以实现在单机上对容器集群编排管理的工具。
- 使用python开发的,能运行docker的平台也都能用docker-compose编排管理容器。
2.docker-compose的三大概念
- 项目project
- 服务service
- 容器container
3.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 [-f docker-compose.yml] up -d 根据模板文件创建并后台启动所有容器
down 根据模板文件删除所有容器
ps 根据模板文件查看所有容器状态
start|stop|restart 根据模板文件启动|停止|重启所有容器
4. yaml格式文件
#一级字段
key1: value1 #一个key只有一个值,值的类型为 纯量
key2:
- value1 #一个key有多个值的纵向格式,值的类型为 列表
- value2
key3: ["value1", "value2"] #一个key有多个值的横向格式,值的类型为 数组
key4:
#二级字段
subkey1: value1 #用 空格缩进 表示字段的层级关系,同一层字段要靠左对齐
subkey2:value2
subkey3: #key的值也是键值对,值的类型为 对象
#三级字段
sskey1: value1
sskey2: value2
5.json格式文件
#一级字段
{
"key1": ["value1"],
"key2": ["value2", "value3"],
"key3": {
#二级字段
"subkey1": ["value1"],
"subkey2": ["value2"],
"subkey3": {
#三级字段
"sskey1": ["value1"],
"sskey2": ["value2"]
}
}
}
6.docker-compose架构LNMP服务
version: "3"
services:
web:
build:
context: ./nginx/
dockerfile: Dockerfile
container_name: nginx
ports:
- 80:80
volumes:
- ./nginx/html:/usr/local/nginx/html
networks:
mynetwork:
ipv4_address: 172.18.0.10
db:
image: mysql:lnmp
container_name: mysql
privileged: true
volumes:
- db-data:/usr/local/mysql
networks:
mynetwork:
ipv4_address: 172.18.0.20
php:
image: php:lnmp
container_name: php
ports:
- 9000:9000
volumes:
- db-data:/usr/local/mysql
- ./nginx/html:/usr/local/nginx/html
networks:
mynetwork:
ipv4_address: 172.18.0.30
depends_on:
- web
- db
networks:
mynetwork:
driver: bridge
ipam:
config:
- subnet: 172.18.0.0/16
volumes:
db-data: