Cloud Foundry与阿里云结合技术的原理与实现

简介: 在2017年北京云栖大会的“开发者服务专场”上,阿里云高级技术专家高磊带来了《Cloud Foundry on Cloud——开源PaaS集成技术实现》的精彩分享。分享中,他重点介绍了Cloud Foundry技术与阿里云结合系统后的应用原理与安装程序。

以下内容根据演讲PPT及现场分享整理:

 

072fa1b2307683034887b2a2e0d60d74820fe15c

PaaS给开发者带来什么?开发者不再需要关注机器、存储、网络等的开通、管理和监控等细节事物;可以迅速实现应用原型;可以快捷地将服务组装成为应用;可以快速地部署代码的新版本;依靠多启动几个实例,快速地实现应用的弹性伸缩;不再需要实现日志与度量的监控系统。

ddd6e4f396754cfebb3997ae242aa673ccb560b6

Cloud Foundry最早是由VMware推出的业界第一个开源PaaS云平台,具有开发框架的选择性、应用服务的选择性、部署云环境的选择性等优点。

9164093536dc9b0130afde4a7aafe05434eecff5

Cloud Foundry已经得到了一大批知名厂商的鼎力支持

 

Cloud Foundry工作原理简介

3e6e2684e7716e14990a54bb241f431c8eff4c70

Router负责请求的分发;Router通过Diego BBS获取所有应用的运行状态,并维护动态的路由表;一般在Router前增加SLB,并绑定域名。

123e22e7fb73e7b1f961afd684809e99c966c78c

Authentication中UAA组件作为Cloud Foundry的几种用户管理中心,对平台中的用户信息进行统一管理、认证和授权。

8337adb1095c9ec41b16c7f992c5cc487320d430

APP Lifecycle中Cloud Controller负责管理APP的发布,当用户Push一个APP的时候,Cloud Controller将请求转交给Diego Cell完成应用的Stage操作;应用的状态通过Diego BBS来进行监控和消息通知。

c8fbda45c67ab53414ace54f4f465924ea81a1cb

App Storage and Execution中的Blobstore用于存储二进制文件,包括代码包、Buildpacks和Droplets;应用的运行和Stage都有Diego Cell来分配资源运行;Diego Cell管理应用的生命周期,并汇报应用的状态给BBS;Diego Cell负责将应用的Metrics和Log发送出去。

40cbef166b6871ef7578089f614bc23c57996120

Blob store中的Buildpacks负责将写好的程序,及其依赖的环境、配置、启动脚本等打包成droplet,这个过程称为stage;支持多种开发语言与框架;CF按照固定的顺序管理buildpacks;支持自定义扩展。

00c49645d60f3445f16fe98322079fae20d8b7d9

Blob store触发的工作流程图如上图。

1590d1e9917efe77bd9bd963cbac69c0360ef398


Service Broker中的CF通过Service Broker方式支持APP的数据库或者三方SaaS的访问需求;CF通过Service Broker构建第三方服务于CF组件之间的连接;采用的Open Service Broker API规范同时被Kubernates、Open Shift等项目支持。

8a53f1adf54bc2ec9e3ff82d4337e2a05fd590ed

Messaging中NATS是CF的内部通信系统,是一款基于事件驱动的、轻量级的消息发布-订阅系统,CF通过NATS来解决各个组件间的通讯问题;Consul是一款分布式服务发现与配置管理系统,用于同步APP及各组件的地址等信息;BBS是随Diego发布的消息同步组件,用于管理Cell及APP状态、任务和心跳管理等。

cfcfc6a443ccfed7249f3e8c385e28275808e6f8

Loggregrator将APP的日志通过流的方式输出给开发者;Metrics Collector用于收集组件的统计和度量,可提供给运维人员作为监控使用。


Cloud Foundry的运维理念

可以总结为:弹性伸缩、运维智能、LaaS隔离、自动化部署工具BOSH四个特点。

f2f311f189da10b7eed019b91d6f646e6f282aa5

BOSH是Bosh Outter Shell的缩写。与“Outter Shell”相对,被BOSH部署和管理的系统称为“Inner Shell”。其中部署和链接图谱如上图。

4063efaeeb02799ae0c54f29dadf5c0e1ae76700


Cloud访问接口和链接程序如上图。

Stemcell就是一个支持BOSH的虚拟机镜像模板;Stemcell中包括一个BOSH Agent组件,并随机启动运行,这个进程被用于监听虚拟机上BOSH组件的运行状态并负责与BOSH Director进行通信交互,当BOSH Agent接收到BOSH Director发布的任务指令后,会根据此任务指令的要求在虚拟机上进行一系列的动作;BOSH会使用指定的Stemcell创建虚拟机,并通过Agent进行管理;包括Light-stemcell与Heavy-Stemell。

6018dc253209f5d213e316f785b6fab36a3dc096

Stemcell运行图如上图。


在阿里云上安装BOSH

获取工程网址:http://github.com/aliyun/bosh-deployment;安装BOSH CLI网址:http://bosh.io/docs/cli-v2.html#install。选一个Region;创建一个专有网络VPC;创建安全组SecurityGroup;选择一个Zone,创建一个专有网络技术交换机Vswitch;如果需要公网访问,创建ElasticIP;获取AccessKeyID/AccessKeySecret;使用bosh create-env命令安装bosh,将相关的参数填进去;使用bosh login命令完成登录;更详细的部分请参阅云栖社区文章:https://yq.aliyun.com/articles/292815


准备Cloud Foundry运行环境

66104bece6208936c0d36a8931fc96ca500e99d2

首先确定域名;创建一个SLB;选择可用区;创建交换机、SNAT、DNAT、选好实例规格。

Update cloud-config.yml中需要注意参数:azs、vm_types、disk_types、network、vm_extensions、compilation。

 

安装Cloud Foundry

工程登录网址:https://github.com/cloudfoundry/cf-deploymengt bosh upload-stemcell;修改cf-deployment.yml,做必要的增加或裁剪;安装CF:$bosh –e my-bosh –d cf deploy cf-deployment.yml\--vars-store cf-vars.yml\-v system_domain=cloudfoundry.cc;登录CF:$cf login –a http://api.cloudfoundry.cc --skip-ssl-validation –u admin –p `bosh int./cf-creds.yml –path/cf_admin_password`。

55e31466beac8e002ca670d1a8c857f3b3f40a80

国区ECS在线安装时,可能会遇到Release下载问题,请先本地下载后upload-release再安装。Buildpacks默认都是在线Buildpack,需要安装完成后替换为离线Buildpacks。为此,我们制作了常用buildpacks的缓存,提供了下载,地址见云栖社区文章。

 

关联文章:云栖社区:开源PaaS工具Cloud Foundry落地阿里云 https://yq.aliyun.com/articles/292815 

 

本文由云栖社区志愿者小组王晓慧整理,丁匀泰审校。编辑:郭雪梅。

目录
相关文章
|
2月前
|
关系型数据库 分布式数据库 数据库
阿里云PolarDB登顶2024中国数据库流行榜:技术实力与开发者影响力
近日,阿里云旗下的自研云原生数据库PolarDB在2024年中国数据库流行度排行榜中夺冠,并刷新了榜单总分纪录,这一成就引起了技术圈的广泛关注。这一成就源于PolarDB在数据库技术上的突破与创新,以及对开发者和用户的实际需求的深入了解体会。那么本文就来分享一下关于数据库流行度排行榜的影响力以及对数据库选型的影响,讨论PolarDB登顶的关键因素,以及PolarDB“三层分离”新版本对开发者使用数据库的影响。
74 3
阿里云PolarDB登顶2024中国数据库流行榜:技术实力与开发者影响力
|
2月前
|
大数据 数据中心 云计算
连续4年 阿里云液冷技术论文入选DesignCon 2024和ECTC 2024
连续4年 阿里云液冷技术论文入选DesignCon 2024和ECTC 2024
|
2月前
|
人工智能 运维 Cloud Native
阿里云祝顺民:云网络领域关键技术创新
2023年10月31日,云栖大会,阿里云技术主论坛带来了一场关于阿里云主力产品与技术创新的深度解读,阿里云网络产品线负责人祝顺民带来《云智创新,网络随行》的主题发言,针对阿里云飞天洛神云网络(下文简称洛神网络)领域产品服务创新以及背后的技术积累进行了深度解读,不少背后的创新技术系首次重磅披露。
219 2
|
2月前
|
人工智能 监控 Cloud Native
阿里云参编业内首个代码大模型标准丨云原生 2024 年 1 月产品技术动态
阿里云参编业内首个代码大模型标准丨云原生 2024 年 1 月产品技术动态
|
2月前
|
消息中间件 Cloud Native 应用服务中间件
阿里云云原生工程师认证(Alibaba Cloud Certified Associate,ACA)考试大纲
介绍阿里云云原生工程师认证(Alibaba Cloud Certified Associate,ACA)所需具备的知识及学习方法等。
350 1
|
6天前
|
监控 Serverless API
阿里云函数计算的工作原理与事件驱动模型密切相关
【4月更文挑战第17天】阿里云函数计算的工作原理与事件驱动模型密切相关
59 4
|
1月前
|
弹性计算 网络协议 关系型数据库
网络技术基础阿里云实验——企业级云上网络构建实践
实验地址:<https://developer.aliyun.com/adc/scenario/65e54c7876324bbe9e1fb18665719179> 本文档指导在阿里云上构建跨地域的网络环境,涉及杭州和北京两个地域。任务包括创建VPC、交换机、ECS实例,配置VPC对等连接,以及设置安全组和网络ACL规则以实现特定服务间的互访。例如,允许北京的研发服务器ECS-DEV访问杭州的文件服务器ECS-FS的SSH服务,ECS-FS访问ECS-WEB01的SSH服务,ECS-WEB01访问ECS-DB01的MySQL服务,并确保ECS-WEB03对外提供HTTP服务。
|
1月前
|
供应链 安全 专有云
阿里云通过信通院面向一云多芯的专有云技术能力评测
近日,阿里云飞天企业版通过中国信息通信研究院2023年度《面向一云多芯的专有云技术能力要求》,在异构兼容能力、专有云基础能力、迁移适配能力三个方面,再一次验证了阿里云专有云一云多芯领先的技术能力。
|
1月前
|
弹性计算 缓存 数据库
2核4G服务器优惠价格,阿里云降价了,释放技术红利
2核4G服务器优惠价格,阿里云降价了,释放技术红利,2核4G配置1个月多少钱?2核4G服务器30元3个月、轻量应用服务器2核4G4M带宽165元一年、企业用户2核4G5M带宽199元一年
|
1月前
|
弹性计算 NoSQL 关系型数据库
还得是阿里云,在2024如此艰难的一年,百款产品直降,技术更优,规模更大,节省更多
还得是阿里云,在2024如此艰难的一年,百款产品直降,技术更优,规模更大,节省更多

热门文章

最新文章