【Cloud Foundry】Cloud Foundry学习(四)——Service
在阅读的过程中有不论什么问题,欢迎一起交流
QQ:1494713801
Services:Cloud Foundry的Service模块从源码控制上看就知道是一个独立的、可Plugin的模块,以方便第三方把自己的服务整合入 CloudFoundry生态系统。在Github上看到service是与CloudFoundry Core项目vcap独立的一个repository,为vcap-service。Service模块当中设计原则是方便第三方服务提供商提供服务。
在 这方面CloudFoundry做得非常成功。从Github上看。已经有下面服务提供:a)MongoDB;
b) mysql; c) neo4j; d) PostgreSql; e) RabbitMQ; f) Redis; g)vBlob。
基类都是放在base目录中。
第三方假设须要自己开发CloudFoundry的服务,须要继承改写它里面的两个基础类:Node和Gateway;而里面一些操作, 如:Provision。能够在base的provisioner.rb基础上增加自己的逻辑,相同的还有Service_Error和 Service_Message等。关于怎样写自己的Service,ELC的博客会推出对应文章具体论述,并不在本文的讨论范围里面,从架构了解上来 说,仅仅要知道服务间的关系,知道个服务与base间透过继承关系来横向扩充。而CloudFoundry与apps调用Service是通过base来完
成这一简单的架构方法就可以。
cf提供的服务按模块分能够分为:service gateway和 service node。类层次结构上分为两层:vcap-service-base提供了base的getway(vcap-service-base\lib \gateway.rb启动gateway。启动了一个thinserver,vcap-services-base\lib\base \asynchronous_service_gateway.rb,提供服务的处理方法)和node。详细的服务则需重载或实现gateway和 node的一些方法。
Service Gateway
service gateway提供REST接口。
从cloud controller过来的请求会先到service gateway做初步的处理,接着查找相应的服务节点。将请求通过发消息的方式托付给详细服务的节点处理。
Service Node
Service Node负责详细的处理gateway的消息。管理service如创建(provision)删除(provision)绑定(bind)解绑(unbind)。恢复服务(restore)等,并将详细请求发送到服务实例。
重要的概念
Service Instance
服务实例。详细的执行的服务进程,如执行着的mysqld。
执行在Service Node中,由Service Node管理。为DEA中的app提供服务。
Credentials
凭据,服务的配置和认证信息。创建服务的时候,service node会创建credentials。绑定app时则增加到app的环境变量中,app拿到改信息则能够訪问详细的服务。
关键工作流程
provision service

注意,vmc/STS到cloud controller的通信,到gateway的通信都是HTTP REST请求,gateway和node之间是NAT的消息。
bind service
绑定服务到应用:查找服务实例,查找credentials并返回给cloud controller。创建的服务。应用还不知道。须要通过绑定将服务的credentials信息设置到应用的环境变量,应用才干訪问到。
绑定mysql服务的流程例如以下:

核心代码
cloud controller
1. cloud_controller-master\cloud_controller\config\routes.rb:cloud controller URL到方法映射
2. cloud_controller-master\cloud_controller\app\controllers\services_controller.rb:针对service的controller
gateway
1. vcap-services-base-master\lib\base\asynchronous_service_gateway.rb:暴露接口的gateway
2. vcap-services-base-master\lib\base\provisioner.rb:gateway的服务方法
Service Node
1. vcap-services-base-master\lib\base\node.rb:node基类
2. cf-services-release-master\src\mysql_service\lib\mysql_service\node.rb:mysql node
【Cloud Foundry】Cloud Foundry学习(四)——Service的更多相关文章
- Spring Cloud 微服务架构学习笔记与示例
本文示例基于Spring Boot 1.5.x实现,如对Spring Boot不熟悉,可以先学习我的这一篇:<Spring Boot 1.5.x 基础学习示例>.关于微服务基本概念不了解的 ...
- (转)SpringMVC学习(四)——Spring、MyBatis和SpringMVC的整合
http://blog.csdn.net/yerenyuan_pku/article/details/72231763 之前我整合了Spring和MyBatis这两个框架,不会的可以看我的文章MyBa ...
- Spring Boot 项目学习 (四) Spring Boot整合Swagger2自动生成API文档
0 引言 在做服务端开发的时候,难免会涉及到API 接口文档的编写,可以经历过手写API 文档的过程,就会发现,一个自动生成API文档可以提高多少的效率. 以下列举几个手写API 文档的痛点: 文档需 ...
- TweenMax动画库学习(四)
目录 TweenMax动画库学习(一) TweenMax动画库学习(二) TweenMax动画库学习(三) Tw ...
- SVG 学习<四> 基础API
目录 SVG 学习<一>基础图形及线段 SVG 学习<二>进阶 SVG世界,视野,视窗 stroke属性 svg分组 SVG 学习<三>渐变 SVG 学习<四 ...
- Android JNI学习(四)——JNI的常用方法的中文API
本系列文章如下: Android JNI(一)——NDK与JNI基础 Android JNI学习(二)——实战JNI之“hello world” Android JNI学习(三)——Java与Nati ...
- SCARA——OpenGL入门学习四(颜色)
OpenGL入门学习[四] 本次学习的是颜色的选择.终于要走出黑白的世界了~~ OpenGL支持两种颜色模式:一种是RGBA,一种是颜色索引模式. 无论哪种颜色模式,计算机都必须为每一个像素保存一些数 ...
- ZigBee学习四 无线+UART通信
ZigBee学习四 无线+UART通信 1) 协调器编程 修改coordinator.c文件 byte GenericApp_TransID; // This is the unique messag ...
- Expression Blend学习四控件
原文:Expression Blend学习四控件 Expression Blend制作自定义按钮 1.从Blend工具箱中添加一个Button,按住shift,将尺寸调整为125*125; 2.右键点 ...
- day 83 Vue学习四之过滤器、钩子函数、路由、全家桶等
Vue学习四之过滤器.钩子函数.路由.全家桶等 本节目录 一 vue过滤器 二 生命周期的钩子函数 三 vue的全家桶 四 xxx 五 xxx 六 xxx 七 xxx 八 xxx 一 Vue的过滤 ...
随机推荐
- 《暗黑世界V1.3》数据库表说明文档
<暗黑世界V1.3>数据库表说明文档 (下载地址:http://www.9miao.com/forum.php?mod=viewthread&tid=38821&highl ...
- Apache OFBiz 添加样式
1.打开themes文件夹,拷贝一份样式作为自己的样式更改初始样式,我这里拷贝的是flatgrey文件夹,重新命名为qlstyle 2.在文件/ofbiz/framework/common/c ...
- Wireshark-配合tcpdump对Android(安卓)手机抓包
环境:Windows, 安装真机(可以获取Root权限), adb, Wireshark, tcpdump 原理: 使用 tcpdump 进行抓包, 然后用 Wireshark 进行分析 1.获取手机 ...
- 解决chrome和firefox flash不透明的方法
透明flash在IE内核的浏览器下正常.在chrome和火狐下不透明了. 解决方法: <object height="377" width="712" c ...
- 弹出键盘windowsoftinputmode属性设置值
windowSoftInputMode属性设置值 2012-08-30 16:49 1592人阅读 评论(0) 收藏 举报 androidattributes活动 (1).AndroidManifes ...
- 如何给app客户端进行埋点?
1.什么是数据埋点? 当一款app开发完成后,一定需要查看数据,来分析用户访问量,点击量,转化率等等指标.想要查看数据,就得先做好数据埋点 注:html和app数据埋点的方式不同 2.常用app数据分 ...
- Scrapy使用问题整理(转载)
转载自:http://blog.csdn.net/heu07111121/article/details/50832999 最近尝试使用Scrapy进行数据抓取,并尝试在windows7 64位系 ...
- 什么是SQL注入式攻击?
什么是SQL注入式攻击? 所谓SQL注入式攻击,就是攻击者把SQL命令插入到Web表单的输入域或页面请求的查询字符串,欺骗服务器执行恶意的SQL命令.在某些表单中,用户输入的内容直接用来构造(或者影响 ...
- JUC组件扩展(二)-JAVA并行框架Fork/Join(一):简介和代码示例
一.背景 虽然目前处理器核心数已经发展到很大数目,但是按任务并发处理并不能完全充分的利用处理器资源,因为一般的应用程序没有那么多的并发处理任务.基于这种现状,考虑把一个任务拆分成多个单元,每个单元分别 ...
- clone和lambda的一个小问题和解决
起因是这样,某管理器类有两个集合,A集合是模板集合,B集合是从模板中实例出的集合. 但是B集合的一些东西,总会调用A集合中的,导致出错. 一开始考虑clone使用不当,但检查后没发现什么问题,后来发现 ...