`
jackyhongvip
  • 浏览: 158143 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

深度剖析CloudFoundry的架构设计(1)

    博客分类:
  • PaaS
 
阅读更多

 

VMware在今年4月份突然发布了业内第一个开源的PaaS——CloudFoundry。发布至今的这几个月里,笔者一直关注它的演进,并从它的架构设计中获益良多,觉得有必要写出来与大家分享一下。

本文会分为两个部份:第一部份主要介绍CloudFoundry的架构设计,从它所包含的模块介绍起,到各部份的消息流向,各模块如何协调合作;第二部份会在第一部份的基础上,以如何在你的数据中心里面用CloudFoundry部署一个私有PaaS为目标,把第一部分介绍到的架构知识使用起来。

第一部份讲的很多内容,会引用Pat在10月12日的VMwareCloud Forum上面关于CloudFoundry架构的演讲。Pat是CloudFoundry Core的负责人,他的那次演讲很值得一听。如果你当时在场,并且理解他所说的内容,本部份可以选择直接跳过。我除了会把说的内容讲具体点外,不太可能可以讲得比他好。

一、架构及模块

从总体地看,CloudFoundry的架构如下:

深度剖析CloudFoundry的架构设计

这个架构图以及下文所用到的各模块架构图均来自Pat的PPT。从上图能够看到CloudFoundry主要有以下几大组件组成:

1、 Router:顾名思义,Router组件在CloudFoundry中是对所有进来的Request进行路由。进入Router的request主要有两类:首先是来自VMCClient或者STS的,由CloudFoundry使用者发出的,管理型指令。

例如:列出你所有apps的vmcapps,提交一个apps等等。这类request会被路由到AppLife Management组件,又叫CloudController组件去;第二类是外界对你所部署的apps访问的request。这部份requests会被路由到Appexecution,又或者叫做DEAs的组件去。所有进入CloudFoundry系统的requests都会经过Router组件,看到这里可能会有朋友会担心Router成为单点,从而成为整个云的瓶颈。

但是CloudFoundry作为云系统,其设计的核心就是去单点依赖,组件平行扩充,且可替代的以保证扩展性,这是CloudFoundry,甚至所有云计算系统的设计原则,后文会讨论CloudFoundry如何做到这点,目前只要知道,系统可以部署多个Routers共同处理进来的requests,但是Router上层的LoadBalance不在CloudFoundry的实现范围,CloudFoundry只保证所有的request是无状态的,这样就使上层均衡附载选择面非常非常大了,例如可以通过DNS做,也可以部署硬件的LoadBalancer,或者简单点,弄台ngnix作负载均衡器,都是可行的。

Router组件,目前版本是对nginx的一个简单封装。熟悉ngnix的朋友应该知道,它可以一个套接字文件(.sock文件)作为输入输出。所有安装CloudFoundry的Router组件服务器都会安装一个nginx,其ngnix.conf文件有以下配置:

深度剖析CloudFoundry的架构设计

从整体的来看,Router组件的结构如下:

深度剖析CloudFoundry的架构设计

外界httprequest进入CloudFoundry服务器,nginx会首先接到request,nginx通过sock与router.rb进行交互,于是真正处理请求的是Router组件。router.rb里面根据传入的url,用户名密码等,进行逻辑判断,到CloudController组件或者DEA组件取数据并且返通过与niginx连接的.sock文件返回。

router.rb是对nginx进行了逻辑封装。熟悉CloudFoundry的朋友肯定知道,CloudFoundry给每一个app分配了一个url访问,如果直接使用VMware所托管的CloudFoundry.com的话,那你的app的url可能就是xxx.cloudfoundry.com,无论通过命令给你的app扩展了多少个instances,都是从这个url访问的,这里面的url转换路由就是由router.rb实现的。

 

原文:http://datacenter.watchstor.com/infra-134681.htm

 

分享到:
评论

相关推荐

    深度剖析CloudFoundry的架构设计

    本文会分为两个部份:第一部份主要介绍CloudFoundry的架构设计,从它所包含的模块介绍起,到各部份的消息流向,各模块如何协调合作;第二部份会在第一部份的基础上,以如何在你的数据中心里面用CloudFoundry部署一个...

    CloudFoundry V2架构分析

    Cloud Foundry是VMware于推出的业界第一个开源PaaS云平台,它支持多种框架、语言、运行时环境、云平台及应用服务,使开发人员能够在几秒钟内进行应用程序的部署和扩展,无需担心任何基础架构的问题。同时,它本身是...

    喻勇 2012-08-12 Cloud Foundry的弹性设计

    根据给定的信息,本文将深入探讨“Cloud Foundry的弹性设计”,主要围绕以下几个方面进行解析:Cloud Foundry产品概述、架构剖析以及其中的关键模块(如NATS、Router和Warden Container)。 ### Cloud Foundry产品...

    Spring 与 Cloud Foundry:在云中珠联璧合

    其次,Cloud Foundry的微服务架构与Spring Boot的理念不谋而合。Spring Boot支持创建独立的、生产级别的微服务应用,而Cloud Foundry则提供了运行这些微服务的完美环境。两者结合,可以构建出高度可扩展和模块化的...

    Cloud Foundry架构及应用介绍.pptx

    Cloud Foundry是一个开源的平台即服务(PaaS)框架,专为加速应用程序的开发、部署和管理而设计。它提供了一种高度自动化和标准化的方法,使开发者能够专注于编写代码,而不必关心底层基础设施的运维。在本文中,...

    Cloud Foundry: The Definitive Guide

    这本书不仅适合对Cloud Foundry感兴趣的开发者,也适合那些希望了解如何在企业环境中部署和管理Cloud Foundry平台的系统管理员和架构师。通过阅读这本书,读者可以系统地了解Cloud Foundry的所有方面,并掌握如何在...

    Cloud Foundry合作伙伴战略和案例分享

    鲁为民可能详细阐述了MoPaaS如何利用Cloud Foundry的开放架构,为国内企业提供了一种快速构建和管理云应用的服务。他可能还讨论了MoPaaS在实现企业数字化转型过程中的具体实践和成功经验,包括服务的可扩展性、安全...

    Cloud Foundry核心组件架构

    描述Cloud Foundry核心组件的功能,及各组件之间的联系

    基于CloudFoundry的PaaS云平台的设计与实现

    综上所述,基于CloudFoundry的PaaS云平台的设计与实现,不仅需要深入理解和分析CloudFoundry的技术架构和组件,还需要在实际构建过程中,根据自身的需求进行定制开发。CloudFoundry通过其开放性和对多种语言框架的...

    Cloud Foundry:云时代的Linux/LAMP.pdf

    Cloud Foundry的目标是成为“云时代的Linux/LAMP”,寓意着它将成为云计算领域的基础架构标准,就像Linux在服务器领域和LAMP(Linux、Apache、MySQL、PHP)在Web开发中的地位一样。随着全球越来越多的开发者、工具...

    Cloudfoundry

    Cloudfoundry

    CloudFoundry的架构优化

    在本文中,我们将深入探讨京东架构师“强娃”针对CloudFoundry中的NATS单节点问题进行的架构优化,以提升整体系统的高可用性和可靠性。 NATS是CloudFoundry中的一个关键组件,它作为消息传递系统,负责连接和协调CF...

    Cloud Foundry 中的新增功能-中英文

    Cloud Foundry是一个开源的平台即服务(PaaS)系统,由Pivotal Software维护,用于构建、部署和管理云应用程序。这个技术的核心在于提供了一种高效、可扩展的方式来托管和运行各种应用程序,无论它们是基于微服务...

    CloudFoundry开源云计算平台简介.rar

    CloudFoundry开源云计算平台简介rar,提供“CloudFoundry开源云计算平台简介”免费资料下载,主要包括Cloud Foundry的概述、Cloud Foundry的架构、使用Cloud Foundry部署应用等内容,可供学习使用。

    cloudfoundry-runtime-0.8.4_Java8_cloud_

    【标题】"cloudfoundry-runtime-0.8.4_Java8_cloud_" 指的是一个针对 Cloud Foundry 运行时环境的特定版本,这个版本是为 Java 8 语言定制的。Cloud Foundry 是一个开源的平台即服务(PaaS)系统,允许开发者构建、...

    Cloud Foundry - The Definitive Guide

    Get started with Cloud Foundry, the leading Platform as a Service (PaaS) that’s dramatically changing how developers, operations practitioners, and especially DevOps teams deploy applications and ...

Global site tag (gtag.js) - Google Analytics