mysql service broker 是mysql接入CF的代理服务实现,它是一个ROR(Ruby On Rails)工程。
目录结构
app - web应用的前端代码
\- asserts - 静态资源
\- controllers - MVC中的C,控制器代码
\- models - MVC中的M,业务数据集
\- queries - 查询
\- views - MVC中的V,视图,即html的模板文件(erb)
bin - 安装,启动服务,任务管理等脚本
config - 配置文件
db - 数据库schema脚本,rails的方式
lib - 业务代码
log - 日志目录
spec - 测试
tmp - 运行时的临时目录
核心代码解读
URL映射
在config/routes.rb中定义了系统的URL路径映射
这里resource定义了响应URL请求的Controller,
namespace,映射app/controllers下的目录,如:namespace :v2映射到了app/controllers/v2
only指定了支持的URL,update,destroy定义了支持的方法
get则是直接定义了URL映射到哪个controller的哪个方法
resource :preview, only: [:show] # 映射到app/controllers/preview_controller.rb的PreviewController,只支持GET方法 namespace :v2 do # 映射到app/controllers/v2目录 resource :catalog, only: [:show] # 映射到CatalogController,但只是暴露show方法,即只支持GET方法 resources :service_instances, only: [:update, :destroy] do # 映射到URL:/serviceinstance,支持PUT和DELETE方法,分别对应update和destroy resources :service_bindings, only: [:update, :destroy] #映射到了下级URL:/serviceinstance/service_bindings/支持PUT和DELETE方法,分别对应update和destroy end end namespace :manage do get 'auth/cloudfoundry/callback' => 'auth#create' # 直接映射 get 'auth/failure' => 'auth#failure' resources :instances, only: [:show] end
由上面的代码可知,系统提供了以下几个REST API:
GET /preivew,由PreviewController#show处理
GET /v2/catalog,由CatalogsController#show处理
PUT /v2/service_instances,由ServiceInstancesController#update处理
DELETE /v2/service_instances,由ServiceInstancesController#destroy处理
PUT /v2/serviceinstance/service_bindings/,由ServiceBindingsController#update处理
DELETE /v2/serviceinstance/service_bindings/,由ServiceBindingsController#destroy处理
GET /manage/auth/cloudfoundry/callback,由AuthController#create处理
GET /manage/auth/failure,由AuthController#failure处理
GET /manage/instances,由InstancesController#show处理
其中/v2/目录的API(即红色的API)是service broker 必须提供的接口,也是我们重点关注的接口
/manage/目录中的接口是对实例管理(目前只有查看)的接口,并提供了OAuth认证的支持。
接口实现
获取服务目录信息
GET /v2/catalog
从CatalogsController#show方法可以知道,仅仅是将config/settings里的配置好的service以JSON的方式输出,因此服务目录信息在这里是静态的。
创建服务实例
PUT /v2/service_instances/:id
该接口是需要参数的,具体参考Service Broker API
对应ServiceInstancesController#update方法,改方法里,先检查了参数,之后调用业务类ServiceInstanceManager的create方法,去创建了服务实例
再追溯到ServiceInstanceManager,最核心的是调用了Database#create创建了数据库,接下来ServiceInstance#create创建了记录关联改数据库和实例id,并记录了规格plan
注意:ServiceInstance是ActiveRecord::Base的子类,即继承了操作数据的方法,类似DAO层
时序如下:
从代码解读可以知道:创建mysql服务实例的实质是为用户创建一个数据库
删除服务实例
和创建相反的流程,这里不赘述
绑定服务实例
PUT /v2/serviceinstance/:inst_id/service_bindings/:id
该接口是需要参数的,具体参考Service Broker API
对应ServiceBindingsController#update方法:先从参数id获取服务实例,并创建一个ServiceBinding实例,调用ServiceBinding#save方法,该方法为之前创建的服务实例(数据库)创建了一个用户,并授予所有权限。
从代码解读可以知道:为之前创建的服务实例(数据库),创建用户,并授权
解绑服务实例
和绑定相反的流程,这里不赘述
认证授权
MySQL service broker 提供的服务提供了简单的认证机制,可以保证基本的安全要求。
所有接口的API都继承自BaseController,这里定义了每个API调用都会经过认证授权
before_filter :authenticate protected def authenticate authenticate_or_request_with_http_basic do |username, password| username == Settings.auth_username && password == Settings.auth_password end
数据视图
这里只需要一个表保存:服务实例和数据库的映射关系,及规格信息
schema_migrations是用来升级数据库的。
一些说明
接入CF管理
service broker 可以通过向nats注册,让CF知道自身的生命周期状态。
config/initializers/register_route.rb就是注册mysql service broker 到CF。
相关推荐
基于C51单片机Proteu仿真实例及软件源码+文档说明 之-电子琴.zip
均包含代码,文章,部分项目包含ppt
基于java的智乐健身后台管理系统设计与实现.docx
基于java的鲜花销售管理系统设计与实现.docx
内容概要:本文回顾了近年来关于数字孪生(Digital Twin)的概念和技术的发展历程,并详尽介绍了这种技术在未来车间中的潜在应用场景和需克服的难关。数字孪生是一种用于集成物理和虚拟系统的技术手段,它能够在产品设计、智能生产和预防性维护等多个领域发挥作用。 适合人群:研究人员和工程师们希望更好地理解数字孪生的基本理论与具体应用实践。 使用场景及目标:涵盖了从产品的设计、制造过程到服役阶段故障预测的全过程,并探讨了基于DT的具体实施路径。 其他说明:强调了信息物理系统的交互融合是DT成功部署的基础,而建立高准确度的多维虚拟模型、孪生数据驱动和实现动态实时交互将是推进这一前沿概念向前发展的关键。
管理员能够查看、添加、修改和删除景点分类信息,景点分类管理 用户在系统前台可查看系统信息,包括首页、景点信息、酒店信息以及客房信息等 用户要登录界面可输入用户名、密码,点击登录按钮进行登录系统 项目关键技术 开发工具:IDEA 、Eclipse 编程语言: Java 数据库: MySQL5.7+ 后端技术:ssm 前端技术:Vue 关键技术:springboot、SSM、vue、MYSQL、MAVEN 数据库工具:Navicat、SQLyog
关键字:UTM/企业防火墙/NGFW 功能:vpn,sdwan,无线控制器,ldap,双因子认证,nat/透明,终端控制,av防病毒,ips入侵检测,应用控制,web过滤, FortiGate UTM/NGFW产品 ①端口:8口、16口、24口、48口 ②层数:二层(接入层交换机、傻瓜式交换机)、三层(核心交换机、汇聚交换机) ③是否网管 网管: 非网管(傻瓜式交换机,即插即用) WEB网管(S1720GW系列) 全网管(S1720GFR系列,S2700以上的型号都为全网管) ④速率:百兆、千兆、万兆等 1.带机量(支持用户数) 2.端口数 3.吞吐量,并发连接数 4.功能 功能差异须知 NG-xxxx产品特有功能 TG-xxxx&NG-xxxx共有功能 TG-xxxx产品特有功能 FW:网络接入、安全防护、高可用性、身份认证、系统服务、系统管理 ●应用层DDOS攻击防护 负载均衡:多链路负载均衡与备份、多链路智能选路技术、多算法的服务器负载均衡 ●异常行为分析:内置统计只能算法,智能学习
简化设计,轻松管理 一键设计:快速创建和管理SQLite3数据库,简化数据库设计流程。 高效查询:强大的查询功能,帮助您轻松处理复杂的SQL语句。 功能全面,灵活便捷 可视化界面:直观的图形界面,让您无需编写繁琐的SQL代码,即可完成数据库设计。 数据同步:支持实时数据同步,确保您的数据库始终保持最新状态。 高度兼容,广泛适用 跨平台支持:适用于Windows、Mac和Linux等多种操作系统,满足不同开发环境的需求。 多语言集成:与C、C++等主流编程语言无缝对接,提高开发效率。 安全可靠,稳定运行 数据备份:内置数据备份与恢复功能,保障数据安全。 性能优化:优化数据库结构,提升查询速度和存储效率。
小程序-滴滴作业.zip 小程序-滴滴作业.zip 小程序-滴滴作业.zip
地线贴标_复制.ezd
Chrome主题-开阔绿地草地主题
基于java校园兼职平台设计与实现.docx
基于java的旅游管理系统设计与实现.docx
基于java的技术大健康综合咨询问诊平台的设计与实现.docx
均包含代码,文章,部分项目包含ppt
项目工程资源经过严格测试可直接运行成功且功能正常的情况才上传,可轻松复刻,拿到资料包后可轻松复现出一样的项目,本人系统开发经验充足(全领域),有任何使用问题欢迎随时与我联系,我会及时为您解惑,提供帮助。 【资源内容】:包含完整源码+工程文件+说明(如有)等。答辩评审平均分达到96分,放心下载使用!可轻松复现,设计报告也可借鉴此项目,该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的。 【提供帮助】:有任何使用问题欢迎随时与我联系,我会及时解答解惑,提供帮助 【附带帮助】:若还需要相关开发工具、学习资料等,我会提供帮助,提供资料,鼓励学习进步 【项目价值】:可用在相关项目设计中,皆可应用在项目、毕业设计、课程设计、期末/期中/大作业、工程实训、大创等学科竞赛比赛、初期项目立项、学习/练手等方面,可借鉴此优质项目实现复刻,设计报告也可借鉴此项目,也可基于此项目来扩展开发出更多功能 下载后请首先打开README文件(如有),项目工程可直接复现复刻,如果基础还行,也可在此程序基础上进行修改,以实现其它功能。供开源学习/技术交流/学习参考,勿用于商业用途。质量优质,放心下载使用。
基于java的共享客栈管理系统设计与实现.docx
基于java的车库智能管理平台设计与实现.docx
基于java的学生宿舍管理设计与实现.docx
【C++】项目设计资源 【C++】新手入门教程 包含例子和相关说明