QCon 演讲火热征集中,快来分享技术实践与洞见! 了解详情
写点什么

VMware 在 DockerCon EU 宣布开源“Photon Controller”基础设施控制器

  • 2015-12-02
  • 本文字数:1757 字

    阅读完需:约 6 分钟

在 2015 年 DockerCon EU 中,VMware 通过企业的 Github 账号开源了他们的 Photon Controller 产品。Photon Controller 是 VMware 中 Photon platform 的一个组件。它为了优化“容器与云”工作负载,作为一个基础结构堆栈被设计出来。这个虚拟化平台通过许多框架,例如 Kubernetes Docker Swarm Mesos ,提供了 API 优先的用户体验、可扩展的控制平面和原生容器支持。

VMware blog 声明,Photon platform 是一个新型基础结构堆栈,为了优化“原生云应用”,它基于 VMware ESXi 管理程序,但是“它更倾向于在规模和速度上超过 vSphere 提供的丰富的管理功能”。此平台由 Photon Machine,一个轻量级的、基于 ESX 的、有内置 Photon OS 的“microvisor”,和 Photon Controller,一个分布式的、API 驱动的、多租户的、包括 Project Lightwave 容器安全性项目的控制平面组成,并且为“极高的规模与改动”而设计。

Photon platform 在八月份的 VMworld 中被发布,并承诺了“将 Photon Controller 开源,让开发者、客户和伙伴直接参与进来”。Photon Controller 网站声明这个项目交付了:

  • 一个 API 优先的模型:一种用户体验,利用 RESTful API、SDK 和 CLI 工具的,专注于基础结构消费与操作的自动化;
  • 一个快速、可扩展的控制平面:一种新的用于优化规模和速度的基础结构控制平面,允许每分钟创建 1000 个新的 VM 隔离的工作负载,并且支持总数 100000 个的同时发生的工作负载;
  • 原生容器支持:Photon Controller 为了“用来运行为原生云(分布式的)app 而设计的工作负载的大型环境”而建立,开发团队可以用各种各样的容器编排框架,例如 Kubernetes、Docker Swarm、Pivotal CF/Lattice 和 Mesos 来部署基于容器的应用。

Photon Controller 架构由若干低耦合的部件或是由“分布式协作”管理的服务组成。端点在 Apache Zookeeper 注册,服务可能作为“横向扩展”(主动 / 主动)操作,使用备用服务器(主动 / 被动),或有明显分区的工作(例如计划程序)。Photon Controller 的技术架构如下图:

图 1. Photon Controller 的技术架构

Photon Controller 的外部 API 以 REST (基于 HTTP 的 JSON)接口提供,用基于 Java 的 Dropwizard 框架实现。这些外部 REST API 是为了被水平扩展的、共享一个持久数据库(“CloudStore”)的 API 服务器显示而设计的。其中的持久数据库充当了一个容器状态、簇、VM、磁盘、网络和物理宿主的单一事实来源。面对 API 服务器,负载平衡器(例如 haproxy )将典型地被取代。

Photon Controller 的大多数管理平面是用 java 实现的,其中有一些服务是在 VMware 的 Xenon 框架上实现的。这个框架是一个“分散的系统开发框架”,现在只能作为技术预览得到。ESX 代理用 Python 实现,Photon Controller CLI,作为完备产品的集成测试,用 Ruby 实现。

每个由 Photon Controller 控制的物理宿主都有一个代理在其之上运行,提供用 Apache Thrift 实现的 RPC 接口,被其他所有部件用于与宿主交流。有很多特殊的部件用于监督其他部件的运行状况和开支管理。例如,“Chairman”负责计划程序的运行状况和树状拓扑结构。

VMware 网站声明 Photon Controller 还实现了一种新奇的分布式计划程序:

它是计划程序服务节点的层次结构,其中树中的每个节点只能访问它的直接子节点。其中由父节点决定的负载 / 使用上的重要统计(stats)在计划程序中不断涌现,父节点沿计划程序树向下发送请求来解决配置需求。这样的话计划程序就避免了单一权值 / 配置数据库上的重负载。

有关 Photon Platform 和 Photon Controller 的更多信息可以在项目网站上找到,开源的代码可以在 VMware 的 Github 库中查看。开发者们可以使用项目的“ Devbox ”下载并运行一个小型的、单机的、测试用 Photon Controller 部署。有关项目的问题可以在 Photon Controller Google Group 中提问,也可以通过在 Stack Overflow 使用“photon-controller”标签提问。

查看英文原文: VMware Open Source ‘Photon Controller’ Infrastructure Control Plane at DockerCon EU


感谢张龙对本文的审校。

给InfoQ 中文站投稿或者参与内容翻译工作,请邮件至 editors@cn.infoq.com 。也欢迎大家通过新浪微博( @InfoQ @丁晓昀),微信(微信号: InfoQChina )关注我们,并与我们的编辑和其他读者朋友交流(欢迎加入 InfoQ 读者交流群(已满),InfoQ 读者交流群(#2))。

2015-12-02 18:001371
用户头像

发布了 218 篇内容, 共 69.4 次阅读, 收获喜欢 76 次。

关注

评论

发布
暂无评论
发现更多内容

F5G+X:给5G一个伙伴,给千行百业一个拥抱

脑极体

刘华:事实证明,假敏捷都比瀑布优秀

刘华Kenneth

DevOps 敏捷 软件开发

新生必备清单:不想成为虚度青春的“小透明”,手机应该怎样选?

脑极体

架构师训练营第九周作业

张明森

JVM参数手册

Rayjun

JVM GC

架构师训练营第九周学习总结

张明森

dubbo-go 中使用 sentinel

apache/dubbo-go

dubbo sentinel Go 语言

格一格你的情欲念

王进行

搭乘政策红利“快车” 欧科云链助力区块链人才培养

CECBC

金融行业区块链技术应用有了“安全符”

CECBC

敏捷教练和Scrum Master - 敏捷转型中的两个重要角色的对比

Bob Jiang

Scrum 敏捷教练 ScrumMaster

【面试必问】Spring中的事务管理详解

只喝纯牛奶

Scrum Master是否需要懂技术

Bob Jiang

敏捷 敏捷开发 敏捷教练 ScrumMaster

无意中参加了infoQ的一期活动,获得了所有奖项,哈哈哈。。。

诸葛小猿

InfoQ 奖品

RRedis系列(八):缓存到底该如何做到高可用?

z小赵

redis 分布式系统 高并发系统设计

微碳系:我心中的宇宙

Geek_116789

30岁的二三事

大唐小生

总结 个人感悟

来了来了!Docker安装及运行原理

程序员的时光

Java Docker 微服务

什么是算法的大O表示法

码农神说

算法 时间复杂度 Java算法 大O

今天你内卷了吗?

池建强

个人成长 内卷化

“PlusToken”跨国网络传销案告破,涉案400亿元!

CECBC

JVM详解之:类的加载链接和初始化

程序那些事

Java JVM GC 加载

谈谈敏捷中的那些模式

Bob Jiang

敏捷 敏捷开发 敏捷教练

最牛逼的Java框架,没有之一

我是苞谷

Dockerfile你值得拥有

北漂码农有话说

Docker

LeetCode题解:70. 爬楼梯,递归+哈希表,JavaScript,详细注释

Lee Chen

大前端 LeetCode

nginx配置文件

张明森

这16道Redis最常见面试问题,你能回答上来几个?

火羊哥

Java

别在网上乱找代码了,找了一段代码突然爆了!!!

导导

Java

小伙伴想写个 IDEA 插件么?这些 API 了解一下!

程序员小航

IDEA idea插件 教程 API IntelliJ IDEA

JVM系列:通过一个例子分析JIT的汇编代码

简爱W

VMware在DockerCon EU宣布开源“Photon Controller”基础设施控制器_DevOps & 平台工程_Daniel Bryant_InfoQ精选文章