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 

 

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

目录
相关文章
|
1月前
|
Cloud Native Java 对象存储
面向未来的架构设计:Spring Cloud和Netflix OSS在云原生环境下的发展趋势
面向未来的架构设计:Spring Cloud和Netflix OSS在云原生环境下的发展趋势
46 1
|
Kubernetes Java 应用服务中间件
Spring Cloud Alibaba - 01漫谈传统架构和微服务架构
Spring Cloud Alibaba - 01漫谈传统架构和微服务架构
126 0
|
Go 网络架构
Cloud Foundry 2. 核心概念
Cloud Foundry 2. 核心概念
Cloud Foundry 2. 核心概念
|
Java 数据库 微服务
10.3k?这才是企业级的 Spring Cloud Alibaba 微服务开发平台,真心牛 x! 下
10.3k?这才是企业级的 Spring Cloud Alibaba 微服务开发平台,真心牛 x! 下
|
消息中间件 监控 NoSQL
10.3k?这才是企业级的 Spring Cloud Alibaba 微服务开发平台,真心牛 x! 上
10.3k?这才是企业级的 Spring Cloud Alibaba 微服务开发平台,真心牛 x! 上
|
Java 微服务 Spring
从0到1 手把手搭建spring cloud alibaba 微服务大型应用框架(一) (mini-cloud) 整体架构图
从0到1 手把手搭建spring cloud alibaba 微服务大型应用框架(一) (mini-cloud) 整体架构图
从0到1 手把手搭建spring cloud alibaba 微服务大型应用框架(一) (mini-cloud) 整体架构图
|
消息中间件 Kubernetes Java
Spring Cloud Alibaba 生态发展和近期规划 | 学习笔记
快速学习 Spring Cloud Alibaba 生态发展和近期规划
Spring Cloud Alibaba 生态发展和近期规划 | 学习笔记
|
Shell API Go
Cloud Foundry 1. 快速入门
Cloud Foundry 1. 快速入门
Cloud Foundry 1. 快速入门
|
消息中间件 Kubernetes Java
Spring Cloud Alibaba 生态发展和近期规划
Spring Cloud Alibaba 的诞生得益于过往数十年处理淘系电商高并发大流量业务所积累的技术经验,阿里巴巴内部沉淀了一套包括限流降级、分布式配置、注册中心、分布式消息、分布式事务等完整的微服务解决方案,比如 Sentinel、RocketMQ 等。 2015 年 6 月, Spring Cloud 第一个正式版本发布后,得益于 SpringBoot 奠定的用户群体基础,再加上 Spring Cloud 本身较为完善的解决方案能力和简单易上手的特点,迅速成为微服务技术圈热点。
Spring Cloud Alibaba 生态发展和近期规划