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。
相关推荐
"解决 Service Broker 未启动的问题" Service Broker 是 SQL Server 中的一个组件,用于实现异步消息传递。它允许数据库管理员创建可靠的、可扩展的消息应用程序。但是,有时可能会遇到 Service Broker 未启动的...
SQL Server 2008中的Service Broker是一种内置的异步消息处理系统,它允许数据库间进行可靠的、事务性的通信。Service Broker提供了一种方法,使得应用程序可以在不影响数据库正常操作的情况下发送和接收消息,确保...
《Pro SQL Server 2008 Service Broker》是针对SQL Server 2008数据库系统中Service Broker特性的深入解析教程。Service Broker是SQL Server的一个重要组件,它为数据库间的异步通信提供了强大的支持,使得分布式...
### Pro SQL Server 2008 Service Broker:深入解析与应用 #### 一、SQL Server 2008 Service Broker简介 SQL Server 2008 Service Broker 是一种基于消息的平台,它允许应用程序在数据库之间异步地传递消息。这种...
用于 Cloud Foundry 的 Node.js 版本的 MySQL Service Broker 概述 这是适用于 Cloud Foundry 的 MySQL Service Broker 的 Node.js 版本,它可以作为 Node.js 应用程序部署到 Cloud Foundry 或 node.js 框架工作的...
另一个重要功能是 SQL Server Service Broker,它为数据库应用程序增加了可靠、可扩展、分布式异步功能。 为什么要编写异步排队操作? 在开发 SQL Server 2005 时,我们与成功开发过大型可扩展数据库应用程序的...
下面是一份关于 SQL Server Service Broker 基础知识介绍的PPT 文档,可以下载。 演讲者:EntLib.com MSN & Email:entlib@hotmail.com 如有任何技术问题或者培训需求,欢迎和我们联系或者留言。
**SQL Server 2005 Service Broker 深度解析** Service Broker 是 SQL Server 2005 引入的一项重要特性,它为数据库间的消息传递提供了可靠且高性能的解决方案。这一特性允许开发者构建分布式、异步处理的应用程序...
SQL Server 2005 Service Broker 是一项强大的功能,它为数据库应用程序引入了可靠、可扩展的异步消息处理机制。Service Broker 解决了在数据库中实现高效排队操作的复杂性和挑战,使得开发人员能够更专注于业务逻辑...
文档提供了示例Service Broker,框架和库的列表,这些列表对于希望实现平台或Service Broker的开发人员可能有用。 文档是一种快速的方法,可以跟踪当前和未决功能添加的状态,它们如何与发行版保持一致以及当前支持...
《SQL Server 2005 Service Broker》是Klaus Aschenbrenner撰写的一本专业书籍,由Gerald Hinson作序,后者是Service Broker的创始成员、架构师及开发经理。本书旨在深入讲解如何利用SQL Server 2005 Service Broker...
SQL Server 2005, Service Broker Sample ================================== The example illustrates communication between two different database instances on the same Server 1. Run the script ...
sqlserver 2005 ServiceBroker Sample
- 示例代码:包含创建服务、启动对话、发送和接收消息的示例脚本,帮助开发者快速理解和应用Service Broker。 学习并掌握SQL Server 2005 Service Broker,对于开发高效、可扩展的数据库解决方案至关重要,尤其是在...
基于Service Broker与WCF的数据实时刷新技术是指在Windows平台下,利用Service Broker和Windows Communication Foundation(WCF)技术,实现后台数据库发生更改后能够即时地刷新前台界面的一种技术方案。这种技术...
在提供的文件"aws-servicebroker-main"中,我们可能找到AWS Service Broker的源代码、配置文件、部署脚本等关键组成部分。通过研究这些文件,开发者可以深入了解AWS Service Broker的工作原理,定制化服务,或者为...
ServiceBroker.Net 用于SQL Server Service Broker的NServiceBus ITransport实现 关于 SQL Server Service Broker是SQL Server提供的集中式消息队列子系统。 它使用逻辑服务来接受消息并将其存储在队列中。 该逻辑...
Service Broker 是 Microsoft SQL Server 2005/2008/2012 中的新技术,它可帮助数据库开发人员生成安全、可靠且可伸缩的应用程序。本文档由 EntLib.com team 编写。
在这个名为 "Ansible-ansible-service-broker.zip" 的压缩包中,我们关注的是 "ansible-service-broker",这可能是一个专门用于服务编排的Ansible模块或项目。 服务经纪(Service Broker)通常涉及到将服务目录化,...