Docker容器之compose容器集群的快速编排

  • 前言
  • 一、Docker-compose简介
  • 二、YAML文件格式及编写注意事项
    • (1)YAML文件格式
    • (2)YAML格式的注意事项
    • (3)YAML数据结构
  • 三、Docker Compose配置常用字段
  • 四、Docker-compose常用命令
  • 五、compose部署
  • 六、总结

前言

Dockerfile可以让用户管理一个单独的应用容器;而Compose则允许用户在一个模板(YAML格式)中定义一组相关联的应用容器(被称为一个project,即项目),例如一个Web服务容器再加上后端的数据库服务容器等。

一、Docker-compose简介

Docker-Compose项目是基于Python开发的Docker官方开源项目,负责实现对Docker容器集群的快速编排。

Docker-Compose将所管理的容器分为三层,分别是 工程(project),服务(service)以及容器(container)。

  1. Docker-Compose运行目录下的所有文件(docker-compose.yml,extends文件或环境变量文件等)组成一个工程,若无特殊指定工程名即为当前目录名。
  2. 一个工程当中可包含多个服务,每个服务中定义了容器运行的镜像、参数、依赖。
  3. 一个服务当中可包括多个容器实例,Docker-Compose并没有解决负载均衡的问题,因此需要借助其它工具实现服务发现及负载均衡,比如Consul。

Docker-Compose的工程配置文件默认为docker-compose.yml,可通过环境变量COMPOSE_FILE或-f参数自定义配置文件,其定义了多个有依赖关系的服务及每个服务运行的容器。

使用一个Dockerfile模板文件,可以让用户很方便的定义一个单独的应用容器。在工作中,经常会碰到需要多个容器相互配合来完成某项任务的情况。例如要实现一个Web项目,除了Web服务容器本身,往往还需要再加上后端的数据库服务容器,甚至还包括负载均衡容器等。

Compose允许用户通过一个单独的docker-compose.yml模板文件(YAML 格式)来定义一组相关联的应用容器为一个项目(project)。

Docker-Compose项目由Python编写,调用Docker服务提供的API来对容器进行管理。因此,只要所操作的平台支持Docker API, 就可以在其上利用Compose来进行编排管理。

二、YAML文件格式及编写注意事项

(1)YAML文件格式

  1. YAML 是一种标记语言,它可以很直观的展示数据序列化格式,可读性高。
  2. 类似于 json数据描述语言,语法比 json简单的很多。
  3. YAML 数据结构通过缩进来表示,连续的项目通过减号来表示,键值对用冒号分隔,数组用中括号 [ ] 括起来, hash 用花括号 { }括起来。

(2)YAML格式的注意事项

  1. 不支持制表符 tab 键缩进,只能使用空格缩进
  2. 通常开头缩进2个空格
  3. 字符后缩进1个空格,如冒号 : 、逗号 , 、横杠 -
  4. 用 # 号注释
  5. 如果包含特殊字符用单引号 ‘’ 引起来作为普通字符;如果用双引号“”表示特殊字符本身的意思
  6. 布尔值必须用引号 “” 括起来
  7. 区分大小写

(3)YAML数据结构

对象: 键值对的字典
animal: pets数组: 一组按次序排列的列表
- cat
- dog
- goldfish布尔值
debug: "true"
debug: "false"#Yaml示例
languages:  #序列的映射- Java- Golang- Python
websites:   #映射的映射Baidu: www.baidu.comWangyi: www.163.comSouhu: www.souhu.com#或者
languages: ["Java","Golong","Python"]
websites: Baidu: www.baidu.comWangyi: www.163.comSouhu: www.souhu.com#Json格式
{languages: ['Java','Golong','Python',],websites: [Baidu: 'www.baidu.com',Wangyi: 'www.163.com',Souhu: 'www.souhu.com',]
}

三、Docker Compose配置常用字段

字段 描述
build 指定Dockerfile文件名(要指定的Dockerfile文件需要在build标签的子级标签中用dockerfile标签指定)
dockerfile 构建镜像上下文路径
context 可以是dockerfile路径,或者是执行git 仓库的url地址
image 指定镜像(已存在)
command 执行命令,会覆盖容器启动后默认执行的命令(会覆盖Dockerfile的CMD指令)
container_name 指定容器名称,由于容器名称是唯一的,如果指定自定义名称,则无法scale指定容器数量
deploy 指定部署和运行服务相关配置,只能在Swarm模式使用
environment 添加环境变量
networks 加入网络,引用顶级networks下条目
network-mode 设置容器的网络模式
ports 暴露容器端口,与-p 相同,但是端口不能低于60
volumes 挂载一个宿主机目录或命令卷到容器,命名卷要在顶级volumes 定义卷名称
volumes_from 从另一个服务或容器挂载卷,可选参数 :ro 和 :rw,(仅版本‘2’支持)
hostname hostname
hostname 在容器内设置内核参数
links 连接到另一个容器,- 服务名称[ : ]
privileged 用来给容器root权限,注意是不安全的,true
restart 重启策略,定义是否重启容器;1.no,默认策略,在容器退出时不重启容器。2.on-failure,在容器非正常退出时(退出状态非0),才会重启容器。3.on-failure:3,在容器非正常退出时重启容器,最多重启3次。4.always,在容器退出时总是重启容器。5.unless-stopped,在容器退出时总是重启容器,但是不考虑在Docker守护进程启动时就已经停止了的容器。
depends_on 此标签用于解决容器的依赖,启动先后问题。如启动应用容器,需要先启动数据库容器php:depends_on:- apache- mysql

四、Docker-compose常用命令

字段 描述
build 重新构建服务
ps 列出容器
up 创建和启动容器
exec 在容器里面执行命令
scale 指定一个服务容器启动数量
top 显示正在运行的容器进程
logs 查看服务容器的输出
down 删除容器、网络、数据卷和镜像
stop/start/restart 停止/启动/重启服务

五、compose部署

Docker-Compose 是 Docker 的独立产品,因此需要安装 Docker 之后在单独安装 Docker Compose。

//环境部署所有主机安装docker环境(内容为docker基础)
yum install docker-ce -y
//下载compose(上传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
cp -p docker-compose /usr/local/bin/
chmod +x /usr/local/bin/docker-composemkdir /root/compose_nginxyum install -y treevim /root/compose_nginx/docker-compose.ymlversion: '3'
services:nginx:hostname: nginxbuild:context: ./nginxdockerfile: Dockerfileports:- 1216:80- 1217:443networks:- cluster     volumes:- ./wwwroot:/usr/local/nginx/htmlnetworks:cluster:


[root@docker compose_nginx]# vim /root/compose_nginx/docker-compose.yml
[root@docker compose_nginx]# ls
docker-compose.yml
[root@docker compose_nginx]# mkdir nginx
[root@docker compose_nginx]# mkdir wwwroot
[root@docker compose_nginx]# ls
docker-compose.yml  nginx  wwwroot
[root@docker compose_nginx]# echo "liyong xuexijiugenwanyiyang" > wwwroot/index.html
[root@docker compose_nginx]# cat wwwroot/index.html
liyong xuexijiugenwanyiyang
[root@docker compose_nginx]# cd nginx
[root@docker nginx]# ls
[root@docker nginx]# rz -E
rz waiting to receive.
[root@docker nginx]# ls
nginx-1.20.2.tar.gz

[root@docker nginx]# vim Dockerfile FROM centos:7 as build
ADD nginx-1.20.2.tar.gz /mnt
WORKDIR /mnt/nginx-1.120.2
RUN yum install -y gcc pcre pcre-devel devel zlib-devel make &> /dev/null && \yum clean all && \sed -i 's/CFLAGS="$CFLAGS -g"/#CFLAGS="$CFLAGS -g"/g' auto/cc/gcc && \./configure --prefix=/usr/local/nginx &> /dev/null && \make &>/dev/null && \make install &>/dev/null && \rm -rf /mnt/nginx-1.20.2FROM centos:7
EXPOSE 80
VOLUME ["/usr/local/nginx/html"]
COPY --from=build /usr/local/nginx /usr/local/nginx
CMD ["/usr/local/nginx/sbin/nginx","daemon off;"]

[root@docker compose_nginx]# tree ./
./
├── docker-compose.yml        //创建模板脚本
├── nginx├── Dockerfile        //创建容器脚本├── nginx-1.20.2.tar.gz    //复制源码包
└── wwwroot└── index.html        //站点

docker-compose -f docker-compose.yml up -d
docker network ls


六、总结

  1. Docker-Compose的工程配置文件默认为docker-compose.yml
  2. 使用一个Dockerfile模板文件,可以让用户很方便的定义一个单独的应用容器。
  3. Compose允许用户通过一个单独的docker-compose.yml模板文件(YAML 格式)来定义一组相关联的应用容器为一个项目(project)。

docker-compose分三层:project,service,container

project:代表多个service组成的项目,默认是用工作目录的名称作为project的工程名称
service:一个 service 可以包含一个或多个容器,在里面可以定义网络模式端口镜像数据卷等参数
container:可以直接由一个已存在的镜像运行实现,也可以通过dockerfile构建镜像实现

Docker容器之compose容器集群的快速编排相关推荐

  1. Docker容器集群--compsoe

    文章目录 一.Docker-compose 简介 二.compose安装 三.YAML 文件格式及编写注意事项 3.1 YAML 文件格式 3.2 YAML格式的注意事项 3.3 YAML数据结构 四 ...

  2. Docker容器之Docker Swarm集群详解(上)

    目录 Swarm介绍 Swarm的几个关键概念 Swarm的调度策略 Swarm Cluster模式的特点 Swarm集群部署 准备工作 创建Swarm并添加节点 在Swarm中部署服务 Swarm介 ...

  3. 【docker详解14】-Docker Swarm容器集群编排

    目录 一.Docker Swarm介绍 二.集群环境搭建 2.1.实验环境 2.2.安装基础运行环境 2.3.建立swarm集群 2.4.swarm集群管理 (1).重新生成集群token (2).节 ...

  4. Karmada 千级容器集群:工商银行业务容灾管理设计利器

    文章目录 前言 一.工行业务背景 1.1.工行云计算架构组成 1.2.工行云平台技术栈 1.3.工行金融云成效 1.3.1.入云规模同业最大 1.3.2.业务如云场景广 1.4.容灾及高可用保障 1. ...

  5. Docker应用:Kubernetes(容器集群)

    Docker应用:Kubernetes(容器集群) 原文:Docker应用:Kubernetes(容器集群) 阅读目录: Docker应用:Hello World Docker应用:Docker-co ...

  6. docker镜像创建redis5.0.3容器集群

    拉取redis5.0.3镜像 # docker pull daocloud.io/library/redis:5.0.3 [root@localhost ~]# docker pull daoclou ...

  7. Kubernetes(k8s)集群部署(k8s企业级Docker容器集群管理)系列目录

    0.目录 整体架构目录:ASP.NET Core分布式项目实战-目录 k8s架构目录:Kubernetes(k8s)集群部署(k8s企业级Docker容器集群管理)系列目录 一.感谢 在此感谢.net ...

  8. Docker学习总结(19)——Google开源的容器集群管理系统Kubernetes介绍

    Kubernetes是Google开源的容器集群管理系统.它构建Ddocker技术之上,为容器化的应用提供资源调度.部署运行.服务发现.扩容缩容等整一套功能,本质上可看作是基于容器技术的mini-Pa ...

  9. Docker容器集群服务Swarm

    Docker容器集群服务Swarm 一.Swarm简介 二.Swarm基本概念 1.Swarm集群 2.节点 3.服务 4.任务 5.服务的外部访问 三.使用Swarm 1.创建集群 2.Slave1 ...

最新文章

  1. Activex test contact failed to create control 未指定的错误 控件无法加载的原因
  2. 2017-2018中国机器人创新Top100榜单深度分析
  3. 树莓派3 64linux,树莓派3 model b安装64位debian+qt5.9
  4. 如何让listview或者gridview设置到底刷新新数据
  5. python中shutil模块_Python中shutil模块的学习笔记教程
  6. koa2:通过Ajax方式上传文件,使用FormData进行Ajax请求
  7. java线程中的死锁_Java多线程中的死锁 - Break易站
  8. Atitit 音频技术实践 艾提拉著 目录 1. 常用的通用技术 2 1.1. Nlp 云识别 api 爬虫技术 2 1.2. Html解析 2 1.3. ffmpege 2 1.4. jfug
  9. RC延时电路计算方法
  10. 掌握c语言的运行环境,c语言考试大纲
  11. 蓝牙双模音频模块 BT401蓝牙BLE应用笔记
  12. matlab logspace 虚数,《MATLAB智能算法超级学习手册》一一1.2 矩阵的表示
  13. python中index函数_python的index函数用法 详解python中的index函数用法
  14. 程序员双手飞快敲键盘的时候是在敲代码吗?
  15. 使用ECS和OSS搭建个人网盘
  16. S5700的Eth-Trunk端口汇聚及Trunk删除
  17. 2017微信公开课·张小龙演讲全文(下)
  18. 盲打打字php,讯飞输入法盲打键盘闪亮登场 是时候展示你真正的技术了
  19. 微信小程序蓝牙writeBLECharacteristicValue 1004错误问题
  20. 简化行政地图边界 简化地图边界的方法 GeoPandas

热门文章

  1. AIGC席卷,抖快、阅文、知乎大战网文圈
  2. android 多个蓝牙连接电脑,Android BLE蓝牙多设备连接
  3. python图片保存jpg、show变成bmp_Python 实现判断图片格式并转换,将转换的图像存到生成的文件夹中...
  4. Vampire:吸血鬼
  5. 离散数学——数学结构
  6. Windows直接拖拽文件复制到虚拟机Ubuntu
  7. php篮球比赛,篮球数据API接口-【篮球比赛动画直播变化数据】API调用示例代码...
  8. 什么是“天道左旋、地道右旋”?
  9. Kettle数据从txt到数据库表,表到文件
  10. 练习-Java类和对象之对象组合之求圆锥体表面积