Docker Compose容器编排
目录
一、Docker Compose简介
Compose项目是Docker官方的开源项目,负责实现对Docker容器集群的快速编排。它是一个定义和运行多容器的docker应用工具。使用compose,你能通过YMAL文件配置你自己的服务,然后通过一个命令,你能使用配置文件创建和运行所有的服务。
Compose是一个定位“定义和运行多个Docker容器应用的工具”,其前身是Fig,目前使用的Compose仍然兼容Fig格式的模板文件。
Compose的代码主要使用Python编写,其开源地址为:https://github.com/docker/compose。
注意:Fig时代支持的配置文件名为fig.yml以及fig.yaml;为了兼容遗留的Fig化配置,目前Compose支持的配置文件类型非常丰富,主要有以下几种:fig.yaml、docker-compose.yml、docker-compose.yaml以及用户指定的配置文件路径。(可通过环境变量COMPOSE_FILE或-f参数自定义配置文件)
1.1 在Compose中有两个重要的概念
- 服务(service):一个应用的容器,实际上可以包括若干运行相同镜像的容器实例。
- 项目(project):由一组关联的应用容器组成的一个完成业务单元,在docker-compose.yml中定义。
以上可以理解为:
- 服务(service)就是在它下面可以定义应用需要的一些服务,代表配置文件中的每一项服务。每个服务都有自己的名字、使用的镜像、挂载的数据卷、所属的网络、依赖哪些其他服务等等,即以容器为粒度,用户需要Compose所完成的任务。
- 项目(project)代表用户需要完成的一个项目,即是Compose的一个配置文件可以解析为一个项目,即Compose通过分析指定配置文件,得出配置文件所需完成的所有容器管理与部署操作。
Compose的默认管理对象时项目,通过子命令对项目中的一组容器进行便捷地生命周期管理。
1.2 docker,dockerfile与docker-compose区别
docker和操作系统无关的一个沙箱容器,宿主机安装的什么操作系统和其本身无关,在它基础上可以制作各种系统类型的基础服务
Dockerfile是把我们手工安装docer镜像的过程变成一个配置文件的方式运行,这样每次不用一步步手敲命令去安装了,而只是需要一个配置文件运行既可生成一个镜像
docker-compos提供了服务和项目的概念,这样一个服务可以配置多个项目,这个服务是多个项目的集合体,启动和关闭都相对一个一个项目的启动要方便很多
1.3 Docker Compose 配置常用字段
字段 | 描述 |
---|---|
build dockerfile context | 指定Dockerfile文件名构建镜像上下文路径 |
image | 指定镜像 |
command | 执行命令,覆盖默认莫名 |
container name | 指定容器名称,由于容器名称是唯一的,如果指定自定义名称,则无法scale |
deploy | 指定部署和运行服务相关配置,只能在Swarm模式使用 |
environment | 添加环境变量 |
networks | 加入网络 |
ports | 暴露容器端口,与-p相同,但端口不能地域60 |
volumes | 挂载宿主机路径或命令卷 |
restart | 重启策略,默认no,always,no-failure,unless-stoped |
hostname | 容器主机名 |
1.4 Docker Compose 常用命令
字段 | 描述 |
---|---|
build | 重新构建服务 |
ps | 列出容器 |
up | 创建和启动容器 |
exec | 在容器里面执行命令 |
scale | 指定一个服务容器启动数量 |
top | 显示容器进程 |
logs | 查看容器输出 |
down | 删除容器、网络、数据卷和镜像 |
stop/start/restart | 停止/启动/重启服务 |
1.5 Compose 命令
- 基本的使用格式
docker-compose [options][COMMAND] [ARGS...]
- docker-compse选项
- –verbose 输出更多调试信息
- –version 打印版本并退出
- -f,–file FILE 使用特定的 compose 模板文件,默认为docker-compose.yml
- -p,–project-name NAME 指定项目名称,默认使用目录名称
1.6 文件格式
- YAML是一种标记语言很直观的数据序列化格式
- 文件格式及编写注意事项
- 不支持制表符tab键缩进,需要使用空格缩进
- 通常开头缩进2个空格
- 字符后缩进1个空格,如冒号、逗号、横杆
- 用#号注释
- 如果包含特殊字符用单引号引起来
- 布尔值必须用引号括起来
二、使用Docker-Compose创建容器
# Compose安装
[[email protected] ~]# mv docker-compose /usr/local/bin/
[[email protected] ~]# chmod +x /usr/local/bin/docker-compose
[[email protected] compose_nginx]# tree
.
├── docker-compose.yml # 创建模板脚本
├── nginx
│ ├── Dockerfile # 创建容器脚本
│ ├── nginx-1.12.2.tar.gz # 复制源码包
│ └── run.sh # 启动服务脚本
└── wwwroot
└── index.html # 站点
# 创建网页
[[email protected] compose_nginx]# mkdir wwwroot
[[email protected] compose_nginx]# vi wwwroot/index.html
<center>Docker Compose!</center>
# 编写Compose文件
[[email protected] compose_nginx]# vi docker-compose.yml
version: '3'
services:
nginx: # 服务名称
hostname: nginx
build:
context: ./nginx # Dockerfile目录(相对路径)
dockerfile: Dockerfile
ports:
- 2020:80 # 映射端口
- 2021:443
networks:
- qwe # 指定网络名称
volumes:
- ./wwwroot:/usr/local/nginx/html # 数据卷映射
networks:
qwe:
# 目录如下
[[email protected] compose_nginx]# tree
.
├── docker-compose.yml # 创建模板脚本
├── nginx
│ ├── Dockerfile # 创建容器脚本
│ ├── nginx-1.12.2.tar.gz # 复制源码包
│ └── run.sh # 启动服务脚本
└── wwwroot
└── index.html # 站点
[[email protected] compose_nginx]# docker-compose -f docker-compose.yml up -d # 指定ocker-compose.yml文件来启动
[[email protected] compose_nginx]# docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
375c1f912a89 compose_nginx_nginx "/run.sh" 25 minutes ago Up 25 minutes 0.0.0.0:2020->80/tcp, 0.0.0.0:2021->443/tcp compose_nginx_nginx_1
其中,Nginx的Dockerfile文件和run.sh文件详见Dockerfile镜像制作(sshd,systemd,nginx,tomcat)
结果如下:
上一篇: 在哪运作PHP代码
推荐阅读
-
Docker容器使用jenkins部署web项目(总结)
-
详解通过docker和docker-compose实现eureka高可用
-
.NET 微服务 1. Docker 容器简介和选择
-
在Google Container Engine上申请创建Docker容器
-
Docker Compose部署项目到容器-基于Tomcat和mysql的商城项目(附源码和sql下载)
-
利用docker-compose搭建AspNetCore开发环境
-
使用IPython来操作Docker容器的入门指引
-
在Docker容器中部署静态网页的方法教程
-
Docker容器化部署Python应用
-
详解docker容器硬盘动态扩容