微软 ESB 指南 2.0 CTP‏

  • Boris Lublinsky
  • 胡键

2008 年 12 月 16 日

话题:SOA.NET语言 & 开发架构

微软在几周前发布了ESB 指南 2.0 CTP

微软 ESB 指南提供了架构方面的指导、模式、实践,以及一系列 BizTalk Server R2 和.NET 组件,旨在简化微软平台上的企业服务总线(ESB)的开发,并让微软的客户可以扩展他们自己的消息传递和集成解决方案。微软 ESB 指南包含 了一系列支持和实现松耦合消息传递环境的互操作组件,该环境简化了基于消息的企业应用开发。

根据 Dmitri Ossipov 在微软 ESB 指南中的模式 & 实践会议中的幻灯片提供的内容:

  • 松耦合的消息传递环境
  • 注册驱动的消息路由
  • 基于路线的处理(Itinerary-based processing)
  • 逻辑集中的消息传递设施(Logically-centralized messaging fabric)

它给客户带来了如下好处:

  • 复用程度更高
  • 运营成本更低
  • 动态改变业务
  • 业务、服务和异常度量指标的收集点

在他的幻灯片中,Dmitri 定义了 ESB 指南 2.0 版核心引擎架构:

Adlai Maschiach 描述了该架构的主要组件

  • Web 服务:暴露内部服务,如路线处理、异常管理、端点和地图解析、BizTalk 操作、UDDI 互操作和消息内容转换。
  • 路线服务和集中存储:包括执行转换和消息传递的代理。你可以从存储解析路线,并创建参与路线解析的自定义服务。
  • 路线入口(Itinerary on-ramps):暴露使用 SOAP 或 WCF 的服务。On-ramps 暴露路线 SOAP 报头并执行路线处理,它利用了微软 ESB 指南中用于动态解析端点和元数据的解析器和适配器提供者框架。
  • 入口(On-ramps):接收某个格式和传输范围内的外部服务,如 HTTP、JMS、WMQ、FTP、平面文件和 XML。它们是典型的 BizTalk 接收位置,它们会根据需要使用微软 ESB 指南中的管道组件和微软 ESB 指南中用来动态解析端点和元数据的解析器和适配器提供者框架。
  • 出口(Off-ramps):实现了传递消息的发送端口,使用的格式和传输如 SOAP、WCF、JMS、WMQ、FTP、 HTTP、平面文件、XML 或其他自定义格式。它们是典型的 BizTalk 发送端口,它们会根据需要使用微软 ESB 指南中的管道组件,以及微软 ESB 指南 中用来动态解析端点和元数据的解析器和适配器提供者框架。
  • 异常管理框架:包括异常 Web 服务、异常管理 API,以及用于丰富异常细节、处理以及传递异常细节给 ESB 管理门户的组件。
  • ESB 管理门户:提供注册供应、异常元数据、报警通知和分析。

这是微软针对 BizTalk Server 2009 的 ESB 指南 2.0 的第一次 CTP 发布。相比2007 年 11 月发布的版本,包含几处修改和增加

新特性和新组件

  • 新样例 该版本包含了以下几个新例子:
    • 针对企业库 4.0 的 SSO 配置提供器
    • 多 Web 服务执行样例
    • 异常处理服务样例
  • 新的 ESB Web 服务该版本包含了以下几个新的 ESB Web 服务:
    • 通用路线服务(不要求有路线报头)
  • 新的核心特性该版本包含了以下几个新的核心特性:
    • 向微软 BizTalk Server 2009(Beta 版)靠齐
    • ESB 配置工具
    • 集中存储路线
    • 路线解析器组件
    • 路线转发器管道组件
    • 路线选择器管道组件
    • 路线设计器
    • 使用企业库 4.0 配置块集中进行配置
    • 使用企业库 4.0 缓存块集中进行缓存
    • 可通过消息传递和编配调用多个服务
    • 路线 BAM 跟踪
    • 改进了 ESB 核心引擎和路线执行

现有特性的修改

  • 解析器和适配器提供者框架:该版本增强了 Dispatch 和 Transform 类,使之能通过使用文档规范类型在发布管道组件内部批量路由消息,同时还支持路线。
  • 路线缓存管道组件:该版本使用企业库 4.0 可配置的缓存管理。
  • UDDI 发布器工具:该版本只支持 UDDI3,使用发布器定义的键值来发布端点。
  • 一般的错误修改

本次发布引入的新特性将使微软在 ESB 市场扮演一个更加重要的角色。

查看英文原文

Microsoft ESB Guidance 2.0 CTP
SOA.NET语言 & 开发架构