Docker Compose介绍及部署
一、Docker Compose介绍:
1、Compose简介
- Docker Compose 项目是Docker官方的开源项目,负责实现对Docker容器集群的快速编排。Docker. Compose 项目由Python 编写,调用Docker 服务提供的API来对容器进行管理。因此,只要所操作的平台支持Docker API,就可以在其上利用Compose 来进行编排管理。
- Docker Compose 是一个用于定义和运行多容器Docker应用程序的工具。它允许用户使用YAML 文件来定义应用程序的配置,包括容器的数量、容器之间的依赖关系、环境变量、端口映射以及其他设置。然后,用户可以使用docker-compose 命令来启动和管理这些容器。使用Docker Compose 可以方便地管理多个容器,例如,可以同时启动一个Web 服务器容器和一个数据库容器,并在它们之间建立网络连接。
- Docker Compose还支持自定义网络,使得容器可以在不同的网络中进行通信。
- Docker Compose 文件通常包含一个或多个服务,每个服务都由一个或多个容器组成。服务定义了容器应该执行的任务,以及容器之间的依赖关系。例如,一个Web服务器服务可以包含一个或多个Web服务器容器,而这些容器又依赖于–个数据库容器。
- Docker-Compose 将所管理的容器分为三层,分别是项目(project) ,服务(service) 以及容器(container) 。Docker-Compose 运行目录下的所有文件组成一个项目,若无特殊指定项目名即为当前目录名。一个项目当中可包含多个服务,每个服务都包含一个名称、镜像、端口映射、环境变量、挂载点等信息。
- Docker-Compose的项目配置文件默认为docker-compose. yml,可通过环境变量COMPOSE_ FTLE 或-f参数自定义配置文件,其定义了多个有依赖关系的服务及每个服务运行的容器。
- Compose允许用户通过一个 单独的docker-compose.yml 模板文件(YAML 格式)来定义一组相关联的应用容器为一一个项目(project )。
总结:docker compose 实现单机容器集群编排管理(使用一个模板文件定义多个应用容器的启动参数和依赖关系,并使用docker compose来根据这个模板文件的配置来启动容器)。
2. YAML 文件格式及编写注意事项
- YAML 是一种标记语言,它可以很直观的展示数据序列化格式,可读性高。类似于 json 数据描述语言,语法比 json 简单的很多。YAML 数据结构通过缩进来表示,连续的项目通过减号来表示,键值对用冒号分隔,数组用中括号 [ ] 括起来, hash 用花括号 { } 括起来。
使用 YAML 时需要注意下面事项:
- 不支持制表符 tab 键缩进,需要使用空格缩进
- 通常开头缩进2个空格
- 大小写敏感
- 通过缩进表示层级关系
- 字符后缩进1个空格,如冒号
:
、逗号,
、横杠-
- 缩进的空格数目不重要,只要相同层级左对齐,通常开头缩进2个空格
- 用
#
号注释 - 如果包含特殊字符用单引号
‘’
引起来 - 布尔值必须用引号
“”
括起来( true 和 false )
3. YAML数据结构
结构类型 | 说明 |
---|---|
对象 | 键值对的集合 |
数组 | 一组按次序排列的值,又称序列 |
纯量 | 单个的,不可再分的值 |
# 纯量
hello
# 数组
- Cat
- Dog
- Goldfish
# 对象
animal: pets
二、Docker Compose部署
1、 Docker Compose 环境安装
Docker Compose 是 Docker 的独立产品,因此需要安装 Docker 之后在单独安装 Docker Compose
#下载
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
#查看版本
docker-compose --version
2.、Docker Compose配置常用字段
字段 | 描述 |
---|---|
build | 指定 Dockerfile 文件名,要指定Dockerfile文件需要在build标签的子级标签中使用dockerfile标签指定 |
dockerfile | 指定当前目录中的dockerfile文件 |
context | 是 dockerfile 的路径 |
image | 指定镜像 |
command | 执行命令,覆盖默认命令 |
container name | 指定容器名称,由于容器名称是唯一的,如果指定自定义名称,则无法 scale指定容器数量 |
deploy | 指定部署和运行服务相关配置,只能在 Swarm 模式使用 |
environment | 添加环境变量 |
networks | 加入网络,引用顶级networks下条目 |
network_mode | 设置容器的网络模式,如 host,bridge,… |
ports | 暴露容器端口,与 -p 相同,但端口不能低于 60 |
volumes | 挂载一个宿主机目录或命令卷到容器,命名卷要在顶级 volumes 定义卷名称 |
volumes_from | 从另一个服务或容器挂载卷,可选参数 :ro 和 :rw,仅版本 ‘2’ 支持 |
hostname | 容器主机名 |
sysctls | 在容器内设置内核参数 |
links | 连接到另外一个容器,- 服务名称[:服务别名] |
privileged | 用来给容器root权限,注意是不安全的,true |
restart | 设置重启策略:no,always,no-failure,unless-stopped no:默认策略,在容器退出时不重启容器。 on-failure:在容器非正常退出时(退出状态非0),才会重启容器。 on-failure:3:在容器非正常退出时重启容器,最多重启3次。 always:在容器退出时总是重启容器。 unless-stopped:在容器退出时总是重启容器,但是不考虑在 Docker 守护进程启动时就已经停止了的容器。 |
- depends_on标签用于解决容器的依赖、启动先后的问题。
php:
depends_on:
- apache
- mysql
3、Docker Compose 常用命令
字段 | 描述 |
---|---|
build | 重新构建服务 |
ps | 列出容器 |
up | 创建和启动容器 |
exec | 在容器里面执行命令 |
scale | 指定一个服务容器启动数量 |
top | 显示容器进程 |
logs | 查看容器输出 |
down | 删除容器、网络、数据卷和镜像 |
stop/start/restart | 停止/启动/重启服务 |
4、Docker Compose 文件结构
yum install -y tree
tree /opt/compose_nginx
/opt/compose_nginx/
├── docker-compose.yml #创建模板脚本
├── nginx
│?? ├── Dockerfile #创建容器脚本
│?? ├── nginx-1.12.0.tar.gz #复制源码包
│?? └── run.sh #启动服务脚本
└── wwwroot
└── index.html #站点网页
编写配置文件docker-compose.yml并创建容器
vim /opt/compose_apache/docker-compose.yml
version: '3'
services:
apache:
image: httpd:latest
container_name: httpd-xc
ports:
- 9912:80
volumes:
- ./html:/usr/local/apache2/htdocs
networks:
lamp:
ipv4_address: 172.20.0.10
networks:
lamp:
driver: bridge
ipam:
config:
- subnet: 172.20.0.0/16
选项 | 描述 |
---|---|
-f, --file FILE | 使用特定的 compose 模板文件,默认为 docker-compose.yml |
-p, --project-name NAME | 指定项目名称,默认使用目录名称 |
-d | 在后台运行 |
cd /opt/compose_apache/
docker-compose -f docker-compose.yml up -d ##必须在docker-compose.yml所在目录执行此操作
docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
0901be856a8c httpd:latest "httpd-foreground" 19 seconds ago Up 18 seconds 0.0.0.0:9912->80/tcp, :::9912->80/tcp httpd-xc
echo "have fun" > ./html/index.html
cat ./html/index.html
用访问http://192.168.92.13:9912/index.html
docker-compose down #自动关闭并删除容器