Docker Orchestration... What It Means and Why You Need It (Docker 编配 ...它是什么意思,为什么你会需要它?)

2024-01-19 18:48

本文主要是介绍Docker Orchestration... What It Means and Why You Need It (Docker 编配 ...它是什么意思,为什么你会需要它?),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Docker Orchestration… What It Means and Why You Need It

原文作者:Cloudify Community
原文地址:https://dzone.com/articles/docker-orchestration-what-it
译者微博:@从流域到海域
译者博客:blog.csdn.net/solo95
本文同样刊载于腾讯云+:https://cloud.tencent.com/developer/article/1019149

Docker 编配 …它是什么意思,为什么你会需要它

本文由Yaron Parasol编写

Docker容器是为了帮助快速,可靠地部署应用程序组件或层(tier)而被发明的,其实现方法是创建一个容器,该容器包含可自行部署的应用程序部分以及成功运行它们所需要的中间件和应用程序业务逻辑。例如,Tomcat容器中的Spring应用程序。按照设计,Docker被故意设计为应用程序中独立出来的独立的部分,通常是层中的一层或甚至层中的一个节点。

然而,一个应用程序通常是在其体系中是多层架构的,这意味着存在层与层之间的依赖关系,依赖的本质可以是从网络连接和远程API调用到应用程序层之间的消息交换之间的任何东西。因此,应用程序是一组具有特定配置的不同容器。这就是为什么你需要一种方法来把你的应用程序粘贴在一起。

虽然Docker有一个使用Docker bridge的基本解决方案,但是这个解决方案并不总是首选,尤其是在跨不同主机部署容器时,您需要关注真正的网络设置。

如何使用TOSCA + Cloudify编配Docker。让我们来一探究竟。点这里

那么,orchestrator扮演什么角色呢?
(orchestrator,音乐中指乐器的调配者,这个建议不翻译,或者参考番剧《中二病也要谈恋爱》,翻译成圣调理人(๑•̀ㅂ•́)و✧)

orchestrator将会处理两件事:

  1. 容器创建的时机 - 因为容器需要依赖和顺序创建
  2. 为了允许容器相互通信而进行的对容器的配置 - 为此,orchestrator需要在容器之间传递运行时的某些属性。

作为一个方面的说明:在Docker中,你需要一个特殊的调整,因为你通常不会碰到容器内的配置文件,为了容器保持完好无损,对于这种情况需要一个有趣的解决方法。

一种方法是使用基于YAML的编配方案(orchestration plan)编排应用程序的部署和部署后的自动化过程,这是Cloudify采用的方法。基于TOSCA(云应用程序的拓扑和编配标准),这个编配方案描述了组件及其生命周期,以及组件之间的关系,特别是涉及到复杂的拓扑时。这包括什么与什么相连接,什么host了什么,以及其他这样的考虑。TOSCA能够描述基础架构,以及中间件层和应用层。Cloudify基本上采用这个TOSCA编配方案(在Cloudify中称为blueprint),并使用遍历组件的图(graph)或这个方案的组件并向代理发布命令这样的工作流来实现这个方案。然后创建应用程序组件并将它们粘合在一起。

代理使用被称为插件的扩展(程序),它们是Cloudify配置和各种基础架构即服务(IaaS)以及自动化工具的API之间的适配器。

在我们的例子中,我们创建了一个与Docker API接口的插件。

Docker Cloudify插件介绍

该Cloudify-Docker插件简单直接,它在机器上安装Docker API 终端/服务器,然后使用Docker-Py把容器

的创建,配置和删除结合起来。TOSCA生命周期事件是:

  • Create(创建) - 安装应用程序组件
  • Configure(配置) - 组件的配置
  • Start - 启动/运行组件
  • 还有stop(停止)和(delete)删除 - 关闭和删除

我们从Create开始使用 - 创建一个容器,我们没有在一开始时就去实现配置,并开始运行应用程序。但后来我们意识到,对于具有依赖性的容器,我们需要有运行时的环境属性,比如为了创建容器,我们需要导入相应容器的IP。当我们创建一个app服务器容器时,我们需要端口和数据库容器的IP。因此我们把容器的创建推到了configure eventceng层面上,并且使用了一个基于TOSCA relationship的预配置钩子来在运行时获取相关容器的信息。

将运行时信息公开到具有依赖关系的容器的方法是将它们设置为环境变量。

查看源代码

打印

有疑问?

01. interfaces:

02. cloudify.interfaces.lifecycle:

03. configure:

04. implementation: docker.docker_plugin.tasks.configure

05. inputs:

06. container_config:

07. command: mongod--rest--httpinterface --smallfiles

08. image: dockerfile/mongodb

09. start:

10. implementation: docker.docker_plugin.tasks.run

11. inputs:

12. container_start:

13. port_bindings:

14. 27017: 27017

15. 28017: 28017

Nodecellar 示例

我想通过使用我们的Nodecellar app作为例子来解释这是如何工作的。Nodecellar app由两台主机组成,在这种情况下,Cloudify不创建,只是SSH进入,然后安装代理。一方面,我们有带MongoD进程的MongoD容器。另一方面,我们有带NodeJS和Nodecellar应用程序的Nodecellar容器。Nodecellar容器需要连接到MongoD容器,以在应用程序启动时运行app queris。

最终,orchestrator不应该仅仅局限于软件部署,Docker背后的全部思想是为了保持灵活性,所以我们也希望在自动扩展、自动修复和CD的情况下使用Docker。在下一篇文章中,我们将精确地展示如何将Cloudify与Docker一起用于后期部署场景。

这篇关于Docker Orchestration... What It Means and Why You Need It (Docker 编配 ...它是什么意思,为什么你会需要它?)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/623337

相关文章

关于数据埋点,你需要了解这些基本知识

产品汪每天都在和数据打交道,你知道数据来自哪里吗? 移动app端内的用户行为数据大多来自埋点,了解一些埋点知识,能和数据分析师、技术侃大山,参与到前期的数据采集,更重要是让最终的埋点数据能为我所用,否则可怜巴巴等上几个月是常有的事。   埋点类型 根据埋点方式,可以区分为: 手动埋点半自动埋点全自动埋点 秉承“任何事物都有两面性”的道理:自动程度高的,能解决通用统计,便于统一化管理,但个性化定

如何用Docker运行Django项目

本章教程,介绍如何用Docker创建一个Django,并运行能够访问。 一、拉取镜像 这里我们使用python3.11版本的docker镜像 docker pull python:3.11 二、运行容器 这里我们将容器内部的8080端口,映射到宿主机的80端口上。 docker run -itd --name python311 -p

业务中14个需要进行A/B测试的时刻[信息图]

在本指南中,我们将全面了解有关 A/B测试 的所有内容。 我们将介绍不同类型的A/B测试,如何有效地规划和启动测试,如何评估测试是否成功,您应该关注哪些指标,多年来我们发现的常见错误等等。 什么是A/B测试? A/B测试(有时称为“分割测试”)是一种实验类型,其中您创建两种或多种内容变体——如登录页面、电子邮件或广告——并将它们显示给不同的受众群体,以查看哪一种效果最好。 本质上,A/B测

Maven创建项目中的groupId, artifactId, 和 version的意思

文章目录 groupIdartifactIdversionname groupId 定义:groupId 是 Maven 项目坐标的第一个部分,它通常表示项目的组织或公司的域名反转写法。例如,如果你为公司 example.com 开发软件,groupId 可能是 com.example。作用:groupId 被用来组织和分组相关的 Maven artifacts,这样可以避免

禅道Docker安装包发布

禅道Docker安装包发布 大家好, 禅道Docker安装包发布。 一、下载地址 禅道开源版:   /dl/zentao/docker/docker_zentao.zip  备用下载地址:https://download.csdn.net/download/u013490585/16271485 数据库用户名: root,默认密码: 123456。运行时,可以设置 MYSQL_ROOT_P

828华为云征文|华为云Flexus X实例docker部署rancher并构建k8s集群

828华为云征文|华为云Flexus X实例docker部署rancher并构建k8s集群 华为云最近正在举办828 B2B企业节,Flexus X实例的促销力度非常大,特别适合那些对算力性能有高要求的小伙伴。如果你有自建MySQL、Redis、Nginx等服务的需求,一定不要错过这个机会。赶紧去看看吧! 什么是华为云Flexus X实例 华为云Flexus X实例云服务是新一代开箱即用、体

docker-compose安装和简单使用

本文介绍docker-compose的安装和使用 新版docker已经默认安装了docker-compose 可以使用docker-compose -v 查看docker-compose版本 如果没有的话可以使用以下命令直接安装 sudo curl -L https://github.com/docker/compose/releases/download/1.16.1/docker-c

01 Docker概念和部署

目录 1.1 Docker 概述 1.1.1 Docker 的优势 1.1.2 镜像 1.1.3 容器 1.1.4 仓库 1.2 安装 Docker 1.2.1 配置和安装依赖环境 1.3镜像操作 1.3.1 搜索镜像 1.3.2 获取镜像 1.3.3 查看镜像 1.3.4 给镜像重命名 1.3.5 存储,载入镜像和删除镜像 1.4 Doecker容器操作 1.4

Vue2电商项目(二) Home模块的开发;(还需要补充js节流和防抖的回顾链接)

文章目录 一、Home模块拆分1. 三级联动组件TypeNav2. 其余组件 二、发送请求的准备工作1. axios的二次封装2. 统一管理接口API----跨域3. nprogress进度条 三、 vuex模块开发四、TypeNav三级联动组件开发1. 动态展示三级联动数据2. 三级联动 动态背景(1)、方式一:CSS样式(2)、方式二:JS 3. 控制二三级数据隐藏与显示--绑定styl

使用WebP解决网站加载速度问题,这些细节你需要了解

说到网页的图片格式,大家最常想到的可能是JPEG、PNG,毕竟这些老牌格式陪伴我们这么多年。然而,近几年,有一个格式悄悄崭露头角,那就是WebP。很多人可能听说过,但到底它好在哪?你的网站或者项目是不是也应该用WebP呢?别着急,今天咱们就来好好聊聊WebP这个图片格式的前世今生,以及它值不值得你花时间去用。 为什么会有WebP? 你有没有遇到过这样的情况?网页加载特别慢,尤其是那