为回答这个问题,本文通过简单的 xml 和一些 JAVA 代码演示了几个重要的 SOA 原理。本文并不打算介绍 SOA 领域中的所有内容;相反,我们只介绍其中的一些关键部分。例如,您可以考虑使用 RSS 发布 xml 服务定义。但是,在本文的例子中,传输
JAVA 技术和 xml 几乎成为了同义词。实际上,我通过 IBM 工具对整篇文章应用了 xml 格式。尽管 xml 取得了显而易见的巨大成功,仍需注意 xml 是一种相当笨拙的技术,例如
JAVA 技术为 xml 数据处理提供了一些真正强大的工具(请参见侧栏 JAVA 技术和 xml)。如果将 清单 1 中的内容看作是给定数据集的基于 xml 的呈现,那么您还可以使用其他方式进行呈现。构成 清单 1 基本内容的原始数据一般保存在数据库中。因此,您如何将这些数据打包成 xml?
这种聚焦式方法的优点就是用户组织中的 JAVA
用户组织不需要进行大型投资就可实现一个试验性质的 SOA。通过这种方式,陈述特定于组织的 SOA 需求时可以脱离任何供应商实现。实际上,某些较小的用户组织可以继续使用他们的试验性 SOA 模式,只在后期迁移到软件供应商提供的大型商用解决方案。
自助服务趋势
对于大多数服务提供商来说,自助服务正在发展为一种趋势 — 特别是那些资金紧张的 ISP。因此,如果您需要更多带宽(进行下载或玩在线游戏),您可以登录到提供商的 Web 站点并通过 Web 页面自动升级与提供商的连接。让我们看一个具体的例子:清单 1 展示了一个简单的基于 xml 的用户服务配置文件。
清单 1. 一个简单的基于 xml 的服务描述
<ServiceInstance> <Customer>Josephine Bloggs</Customer> <Package>Internet</Package> <Bandwidth>1mbps</Bandwidth> <DownloadLimit>1Gbyte</DownloadLimit> <Uptime>95</Uptime> </ServiceInstance> |
代码解释了这个用户 xml 服务模型。该模型包括:
无疑,服务定义可以比此处的例子复杂很多。其他内容可能包括客户地址、账单明细、往返延迟、加密和服务信用
因此,清单 1 中的代码形成了基于 xml 的服务模型的基础。通过简单地与在线表单进行交互,用户可以修改可写的服务元素(例如带宽)。通过在线表单进行的修改将被记录,然后反映到可由用户配置文件修改的后端服务中。这是一种实现自助服务的标准方法。
然而,您将要了解的是另一种更加松散耦合的自助服务 — 使用这种服务,用户可以通过在网络中传输 清单 1 中的 xml 内容修改数据。在这种场景中,所传输的 xml 内容可通过一个 JAVA 客户机进行修改,后者可运行在台式机、笔记本电脑、甚至某种资源受限的设备上(例如手机),然后将数据发回给网络服务提供商。这种机制超越了基本的 HTML 页面模型并采纳了 SOA 思想。