欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

Docker Compose容器编排

程序员文章站 2022-05-14 20:40:58
...

一、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)

结果如下:
Docker Compose容器编排