1、概念
1.1 Docker Compose是什么
Docker Compose的前身是Fig,它是一个定义及运行多个Docker容器的工具
通过 Compose,不需要使用shell脚本来启动容器,而使用 YAML 文件来配置应用程序需要的所有服务
然后使用一个命令,根据 YAML 的文件配置创建并启动所有服务
Docker Compose非常适合组合使用多个容器进行开发的场景
1.2 YAML
YAML(YAML Ain’t a Markup Language)是一个可读性高,用来表达数据序列化的格式
文件格式及编写注意事项
不支持制表符tab键缩进,需要使用空格缩进
通常开头缩进2个空格
字符后缩进1个空格,如冒号、逗号、横杆
用#号注释
如果包含特殊字符用单引号引起来
布尔值必须用引号括起来
1.3 yml 文件配置指令参考
version:指定此yml文件基于的compase的版本
services:指定创建容器的服务选项
服务名:例如nginx等
hostname:容器主机名
build :指定构建镜像上下文路径
context:上下文路径
dockerfile:指定构建镜像的 Dockerfile 文件名
ports:暴露容器端口,与-p相同,但端口不能低于60;例如:- 1234:80
networks:加入顶级networks下配置的网络
deploy:指定部署和运行服务相关配置,只能在Swarm模式使用
volumes:挂载宿主机路径或命令卷
image:指定容器运行的镜像
command:执行命令,覆盖默认命令
container_name:指定容器名称,由于容器名称是唯一的,如果指定自定义名称,则无法scale(扩展)
environment:添加环境变量
restart:重启策略,定义是否重启容器;no(默认,不重启), always(总是重启),no-failure(退出状态非0时重启),unless-stoped(容器退出时,忽略守护进程启动前停止的容器)
networks:配置网络,指定网卡设备等
1.4 Compose命令说明
基本的使用格式
docker-compose [options] [COMMAND][ARGS...]
相关选项
--verbose:输出更多调试信息
--version:打印版本并退出
-f,--file FILE:使用特定的compose模板文件,默认为docker-compose.yml
-p, --project-name NAME:指定项目名称,默认使用目录名称
Docker Compose常用命令
| 字段 | 描述 |
|---|---|
| build | 重新构建服务 |
| ps | 列出容器 |
| up | 创建和启动容器 |
| exec | 在容器里面执行命令 |
| scale | 指定一个服务容器启动数量 |
| top | 显示正在运行的容器进程 |
| logs | 查看服务容器的输出 |
| down | 删除容器、网络、数据卷和镜像 |
| stop/start/restart | 停止/启动/重启服务 |
2.compose的安装和使用
2.1 安装compose
yum install docker-ce -y

curl -L https://github.com/docker/compose/releases/download/1.21.1/docker-compose-uname -s-uname -m -o /usr/local/bin/docker-compose
chmod +x /usr/local/bin/docker-compose
mkdir /root/compose_nginx


2.2 使用compose编排创建容器
yum -y install tree
tree ./


Docker Compose配置常用字段
字段 描述
build 指定 Dockerfile 文件名,要指定Dockerfile文件需要在build标签的子级标签中使用dockerfile标签指定
dockerfile 构建镜像上下文路径
context 可以是 dockerfile 的路径,或者是指向 git 仓库的 url 地址
image 指定镜像
command 执行命令,覆盖默认命令
container name 指定容器名称,由于容器名称是唯一的,如果指定自定义名称,则无法 scale
deploy 指定部署和运行服务相关配置,只能在 Swarm 模式使用
environment 添加环境变量
networks 加入网络
ports 暴露容器端口,与 -p 相同,但端口不能低于 60
volumes 挂载宿主机路径或命令卷
hostname 容器主机名
restart 重启策略,默认 no,always,no-failure,unless-stoped(详细解释见下)
no,默认策略,在容器退出时不重启容器。
on-failure,在容器非正常退出时(退出状态非0),才会重启容器。
on-failure:3,在容器非正常退出时重启容器,最多重启3次。
always,在容器退出时总是重启容器。
unless-stopped,在容器退出时总是重启容器,但是不考虑在 Docker 守护进程启动时就已经停止了的容器。
Docker Compose 常用命令
字段 描述
build 重新构建服务
ps 列出容器
up 创建和启动容器
exec 在容器里面执行命令
scale 指定一个服务容器启动数量
top 显示容器进程
logs 查看容器输出
down 删除容器、网络、数据卷和镜像
stop/start/restart 停止/启动/重启服务
compose部署lnmp
1.mkdir -p /opt/compose-lnmp/nginx
2.cd /opt/compose-lnmp/nginx
3.把nginx-1.12.0.tar.gz和wordpress-4.9.4-zh_CN.tar.gz和nginx的配置文件nginx.conf移进来(配置文件都已经修改好)
mysql前期操做
1.mkdir -p /opt/compose-lnmp/mysql
2.cd /opt/compose-lnmp/mysql
3.把boost_1_59_0.tar.gz和mysql-5.7.17.tar.gz和mysql配置文件my.cnf移动到本目录(配置文件都已经修改好)
php前期操做
1.mkdir -p /opt/compose-lnmp/php
2.cd /opt/compose-lnmp/php
3.把php-7.1.10.tar.bz2、php-fpm.conf、php.ini、www.conf移动到本目录(配置文件都已经修改好)

编写dockerfile
在3个服务的工作目录下编写dockerfile,与之前的构建lnmp一致,这边就不叙述了
构建lnmp的compose文件
cd /opt/compose-lnmp #compose的工作目录
vim docker-compose.yml #构建compose的yml文件
version: '2' #版本2能使用volumes_from
services:
nginx:
hostname: nginx
build:
context: ./nginx
dockerfile: Dockerfile
container_name: nginx
ports:
- 1111:80
- 2222:443
volumes: - ./nginx/html/:/usr/local/nginx/html
networks:
lnmp:
ipv4_address: 172.20.0.10
mysql:
hostname: mysql
build:
context: ./mysql
dockerfile: Dockerfile
container_name: mysql
networks:
lnmp:
ipv4_address: 172.20.0.20
ports: - 3306:3306
php:
hostname: php
build:
context: ./php
dockerfile: Dockerfile
container_name: php
networks:
lnmp:
ipv4_address: 172.20.0.30
ports: - 9000:9000
volumes_from: - nginx
- mysql
networks:
lnmp:
driver: bridge
ipam:
config: - subnet: 172.20.0.0/16
启动compose搭建的lnmp
cd /opt/compose-lnmp/
docker-compose -f docker-compose.yml up -d

-f, --file FILE :使用特定的 compose 模板文件,默认为 docker-compose.yml
-p, --project-name NAME :指定项目名称,默认使用目录名称
-d :在后台运行
跟之前一样进入数据库容器给与权限
docker exec -it mysql /bin/bash
mysql #进入数据库
create database wordpress;
grant all privileges on wordpress.* to 'wordpress'@'%' identified by '122000';
grant all privileges on . to 'root'@'%' identified by '122000';
flush privileges;

浙公网安备 33010602011771号