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;

posted on 2021-10-18 15:09  小笼包不是汤包  阅读(253)  评论(0)    收藏  举报