Docker容器之compose容器集群的快速编排
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)。
- Docker-Compose运行目录下的所有文件(docker-compose.yml,extends文件或环境变量文件等)组成一个工程,若无特殊指定工程名即为当前目录名。
- 一个工程当中可包含多个服务,每个服务中定义了容器运行的镜像、参数、依赖。
- 一个服务当中可包括多个容器实例,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文件格式
- YAML 是一种标记语言,它可以很直观的展示数据序列化格式,可读性高。
- 类似于 json数据描述语言,语法比 json简单的很多。
- YAML 数据结构通过缩进来表示,连续的项目通过减号来表示,键值对用冒号分隔,数组用中括号 [ ] 括起来, hash 用花括号 { }括起来。
(2)YAML格式的注意事项
- 不支持制表符 tab 键缩进,只能使用空格缩进
- 通常开头缩进2个空格
- 字符后缩进1个空格,如冒号 : 、逗号 , 、横杠 -
- 用 # 号注释
- 如果包含特殊字符用单引号 ‘’ 引起来作为普通字符;如果用双引号“”表示特殊字符本身的意思
- 布尔值必须用引号 “” 括起来
- 区分大小写
(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
六、总结
- Docker-Compose的工程配置文件默认为docker-compose.yml
- 使用一个Dockerfile模板文件,可以让用户很方便的定义一个单独的应用容器。
- Compose允许用户通过一个单独的docker-compose.yml模板文件(YAML 格式)来定义一组相关联的应用容器为一个项目(project)。
docker-compose分三层:project,service,container
project:代表多个service组成的项目,默认是用工作目录的名称作为project的工程名称
service:一个 service 可以包含一个或多个容器,在里面可以定义网络模式端口镜像数据卷等参数
container:可以直接由一个已存在的镜像运行实现,也可以通过dockerfile构建镜像实现
Docker容器之compose容器集群的快速编排相关推荐
- Docker容器集群--compsoe
文章目录 一.Docker-compose 简介 二.compose安装 三.YAML 文件格式及编写注意事项 3.1 YAML 文件格式 3.2 YAML格式的注意事项 3.3 YAML数据结构 四 ...
- Docker容器之Docker Swarm集群详解(上)
目录 Swarm介绍 Swarm的几个关键概念 Swarm的调度策略 Swarm Cluster模式的特点 Swarm集群部署 准备工作 创建Swarm并添加节点 在Swarm中部署服务 Swarm介 ...
- 【docker详解14】-Docker Swarm容器集群编排
目录 一.Docker Swarm介绍 二.集群环境搭建 2.1.实验环境 2.2.安装基础运行环境 2.3.建立swarm集群 2.4.swarm集群管理 (1).重新生成集群token (2).节 ...
- Karmada 千级容器集群:工商银行业务容灾管理设计利器
文章目录 前言 一.工行业务背景 1.1.工行云计算架构组成 1.2.工行云平台技术栈 1.3.工行金融云成效 1.3.1.入云规模同业最大 1.3.2.业务如云场景广 1.4.容灾及高可用保障 1. ...
- Docker应用:Kubernetes(容器集群)
Docker应用:Kubernetes(容器集群) 原文:Docker应用:Kubernetes(容器集群) 阅读目录: Docker应用:Hello World Docker应用:Docker-co ...
- docker镜像创建redis5.0.3容器集群
拉取redis5.0.3镜像 # docker pull daocloud.io/library/redis:5.0.3 [root@localhost ~]# docker pull daoclou ...
- Kubernetes(k8s)集群部署(k8s企业级Docker容器集群管理)系列目录
0.目录 整体架构目录:ASP.NET Core分布式项目实战-目录 k8s架构目录:Kubernetes(k8s)集群部署(k8s企业级Docker容器集群管理)系列目录 一.感谢 在此感谢.net ...
- Docker学习总结(19)——Google开源的容器集群管理系统Kubernetes介绍
Kubernetes是Google开源的容器集群管理系统.它构建Ddocker技术之上,为容器化的应用提供资源调度.部署运行.服务发现.扩容缩容等整一套功能,本质上可看作是基于容器技术的mini-Pa ...
- Docker容器集群服务Swarm
Docker容器集群服务Swarm 一.Swarm简介 二.Swarm基本概念 1.Swarm集群 2.节点 3.服务 4.任务 5.服务的外部访问 三.使用Swarm 1.创建集群 2.Slave1 ...
最新文章
- Activex test contact failed to create control 未指定的错误 控件无法加载的原因
- 2017-2018中国机器人创新Top100榜单深度分析
- 树莓派3 64linux,树莓派3 model b安装64位debian+qt5.9
- 如何让listview或者gridview设置到底刷新新数据
- python中shutil模块_Python中shutil模块的学习笔记教程
- koa2:通过Ajax方式上传文件,使用FormData进行Ajax请求
- java线程中的死锁_Java多线程中的死锁 - Break易站
- Atitit 音频技术实践 艾提拉著 目录 1. 常用的通用技术	2 1.1. Nlp 云识别 api 爬虫技术	2 1.2. Html解析	2 1.3. ffmpege	2 1.4. jfug
- RC延时电路计算方法
- 掌握c语言的运行环境,c语言考试大纲
- 蓝牙双模音频模块 BT401蓝牙BLE应用笔记
- matlab logspace 虚数,《MATLAB智能算法超级学习手册》一一1.2 矩阵的表示
- python中index函数_python的index函数用法 详解python中的index函数用法
- 程序员双手飞快敲键盘的时候是在敲代码吗?
- 使用ECS和OSS搭建个人网盘
- S5700的Eth-Trunk端口汇聚及Trunk删除
- 2017微信公开课·张小龙演讲全文(下)
- 盲打打字php,讯飞输入法盲打键盘闪亮登场 是时候展示你真正的技术了
- 微信小程序蓝牙writeBLECharacteristicValue 1004错误问题
- 简化行政地图边界 简化地图边界的方法 GeoPandas
热门文章
- AIGC席卷,抖快、阅文、知乎大战网文圈
- android 多个蓝牙连接电脑,Android BLE蓝牙多设备连接
- python图片保存jpg、show变成bmp_Python 实现判断图片格式并转换,将转换的图像存到生成的文件夹中...
- Vampire:吸血鬼
- 离散数学——数学结构
- Windows直接拖拽文件复制到虚拟机Ubuntu
- php篮球比赛,篮球数据API接口-【篮球比赛动画直播变化数据】API调用示例代码...
- 什么是“天道左旋、地道右旋”?
- Kettle数据从txt到数据库表,表到文件
- 练习-Java类和对象之对象组合之求圆锥体表面积