针对SOA将EJB组件公开为业务服务(1)

上一篇 / 下一篇  2008-05-12 16:46:47

当机构使用 Web 服务技术构建、部署和组织业务服务时,显然必须进行仔细、全面设计 Java 2 平台企业版 (J2EE) 应用程序。在这方面,最有效的帮助是严格应用旨在实现面向服务的体系结构 (SOA) 的体系结构模式。当公开 Enterprise JavaBean (EJB) 时,此类模式尤其有用。

人们通常把模式仅仅看作是为特殊设计问题提供指导的参考工具;而事实上,应将模式看作是体系结构要求的组成部分。它们是影响业务服务(封装了业务规则验证、计算、数据访问以及其他驱动 J2EE 应用程序的核心功能的逻辑)组织决策的起点。除其他适用于 J2EE 的模式和思考方式以外,一些学术界人士、供应商和用户还从 SOA 的角度对著名的Design Patterns一书(由 Addison-Wesley 出版社于 1994 年出版,作者是 Erich Gamma、Richard Helm、Ralph Johnson 和 John Vlissides —— 通常称之为“四人帮”或“GoF”)中的许多模式进行了再计算和研究。

本文将从体系结构的角度介绍最重要的模式及其应用,假设您熟悉以下 Web 服务基础知识:简单对象访问协议 (SOAP)、HTTP、XML、J2EE、EJB、Java 消息服务 (JMS) 等。

走进 Web 服务世界

从 J2EE 的角度而言,Web 服务基本上是 J2EE 编程模型的扩展(参见图 1),具体体现在:

  • Web 服务继承了符合 J2EE 的应用服务器的容器功能。
  • 远程过程调用 (RPC) 样式的 Web 服务通过非会话状态 EJB 公开。
  • 消息样式的 Web 服务通过 JMS(JMS 监听程序)和消息驱动的 bean 公开。
  • 非会话状态 EJB 或 JMS 被定义为 Web 服务定义语言 (WSDL) 的应用程序入口点,并被部署为 Web 服务。
  • Web 服务客户机使用 WSDL 生成服务请求程序基于 SOAP 的代码。

图 1

图 1:J2EE/Web 服务模型

首先,我们将简要概述将 EJB 应用程序公开为业务服务的过程。尽管本文使用 Oracle Application Server Containers for J2EE (OC4J) 环境,但对于任何其他符合 J2EE 的应用服务器也同样适用。

下面,我将介绍一个企业对客户 (B2C) 商务领域中的示例。(参见图 2 和图 3;图 2 描绘了角色交互,图 3 描绘了系统分解。)在该示例中,客户登录到“电子商店”网站,点击感兴趣的商品,选择某些要购买的商品,查看订单信息,提供支付信息,最后注销。为简单起见,我省略了大量详细信息—例如,所有表示(Web 层)组件、安全支持等。

图 2

图 2:“电子商店”示例—协作图表

图 3

图 3:“电子商店”示例—分解图表

如图 3 所示,该解决方案包含四种 EJB 子系统(每个子系统包含多个 bean):

  • 客户验证管理: 负责登录/注销、站点注册和客户首选项
  • 客户体验管理:负责客户可以在“电子商店”站点执行的所有功能—查看目录、购买商品、付款、查询订单状态等
  • 产品清单管理: 负责提供商品可用性和更新存货/脱销数据库以及触发实现进程
  • 财务管理: 负责帐目管理和其他财务处理,如开发票。

此处最简单的服务可能是基于非会话状态会话 bean SystemIdEJB 的 GetSystemIdService。该 bean 是称作“验证客户”的一组对象类的一部分。如果客户已经成功通过验证,则该 bean 提供稍后用于获取其他客户信息(例如,与商品目录的呈现方式相关的客户首选项)的系统用户 ID。如果客户未成功通过验证,则该 bean 发出例外。


TAG:

 

评分:0

我来说两句

显示全部

:loveliness: :handshake :victory: :funk: :time: :kiss: :call: :hug: :lol :'( :Q :L ;P :$ :P :o :@ :D :( :)

我的栏目

日历

« 2008-07-25  
  12345
6789101112
13141516171819
20212223242526
2728293031  

数据统计

  • 访问量: 12951
  • 日志数: 2718
  • 图片数: 1
  • 建立时间: 2008-03-20
  • 更新时间: 2008-06-01

RSS订阅

Open Toolbar