通过Java编程处理XML 为SOA减少内存占用

ZDNet软件频道 时间:2009-02-04 作者: | IT专家网 我要评论()
本文关键词:内存占用 SOA xml JAVA
Java 技术为 SOA 设计和实现提供了经过优化的解决方案。通过使用简单的基于 XML 文件的服务配置,您可以轻松地在网络中移动客户机数据。
 很多大型软件供应商还在开发各自的 SOA 产品。因此,SOA 领域目前综合了各种技术,包括 JAVA Business Integration (JBI)、Intelligent Event Processing 和 Business Process Execution Language (BPEL) 服务器。因此,在将各种技术融入到一个解决方案之前,想要从 SOA 中受益的用户组织很可能需要进行大量投资。通过对 SOA 布置如此高的复杂性,行业提前为实现供应商定位铺好了道路,即使 SOA 其中的一项承诺是实现基于标准、面向组件、独立于供应商的计算。在开始代价高昂的迁移过程前,用户组织能够获得一些实用的 SOA 使用体验吗?

  为回答这个问题,本文通过简单的 xml 和一些 JAVA 代码演示了几个重要的 SOA 原理。本文并不打算介绍 SOA 领域中的所有内容;相反,我们只介绍其中的一些关键部分。例如,您可以考虑使用 RSS 发布 xml 服务定义。但是,在本文的例子中,传输机制使用的是 JAVA 工具。

      JAVA 技术和 xml

  JAVA 技术和 xml 几乎成为了同义词。实际上,我通过 IBM 工具对整篇文章应用了 xml 格式。尽管 xml 取得了显而易见的巨大成功,仍需注意 xml 是一种相当笨拙的技术,例如 标签会增加大量带宽并在通过网络传输数据时处理系统开销。然而,忽略这种特性,xml 确实提供了一些强大的处理工具。这些工具(本文将探讨其中的两种)基本上解决了数据表示和解析问题(后者长久以来一直难以解决)。现在,通过使用 xml 工具,各种技术级别的程序员都可以实现专业的标准化解析。

  JAVA 技术为 xml 数据处理提供了一些真正强大的工具(请参见侧栏 JAVA 技术和 xml)。如果将 清单 1 中的内容看作是给定数据集的基于 xml 的呈现,那么您还可以使用其他方式进行呈现。构成 清单 1 基本内容的原始数据一般保存在数据库中。因此,您如何将这些数据打包成 xml?

  这种聚焦式方法的优点就是用户组织中的 JAVA 开发人员可以使用其中的理念构建自己的简单的试验性 SOA。这种试验模式有助于组织实现 SOA 的商业效益。后者包含对业务服务建模,例如计算服务、用户自助服务、更好的自动化服务和更具响应性的服务。您可以将上述的迁移作为一个独立试验实现,与现有业务流程并行运作。

  用户组织不需要进行大型投资就可实现一个试验性质的 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 所示的 Web 访问细节。某种程度上讲,这种尝试可以减少支持电话的花销和发生频度。有趣的是,这种基于 Web 的服务可以使用户觉得为他们提供服务的是较为先进的提供商。这实现了双赢的局面,因为客户可以更好地访问他们的服务数据,而提供商可以销售无需他们插手的服务包。授权的用户可以修改如 清单 1 所示的一些服务参数 — 例如,配置的带宽。随之修改的是用户每月的订购费用。

  因此,清单 1 中的代码形成了基于 xml 的服务模型的基础。通过简单地与在线表单进行交互,用户可以修改可写的服务元素(例如带宽)。通过在线表单进行的修改将被记录,然后反映到可由用户配置文件修改的后端服务中。这是一种实现自助服务的标准方法。

  然而,您将要了解的是另一种更加松散耦合的自助服务 — 使用这种服务,用户可以通过在网络中传输 清单 1 中的 xml 内容修改数据。在这种场景中,所传输的 xml 内容可通过一个 JAVA 客户机进行修改,后者可运行在台式机、笔记本电脑、甚至某种资源受限的设备上(例如手机),然后将数据发回给网络服务提供商。这种机制超越了基本的 HTML 页面模型并采纳了 SOA 思想。

  将服务定义 xml 文档传输给使用 JAVA 技术的客户机

  清单 2 中的内容摘取自本文附带的 JAVA 文件 encodexml.JAVA.(相关文件可从 下载 部分获得)。encodexml.JAVA 类对 xmlEncoder 类的对象进行了实例化。如您所见,这个对象随后在当前目录中创建了名为 xmldata.xml 的文件。下一步是将 xml 数据值插入到文件中,这可以通过调用一连串的 writeObject() 方法实现(清单 2 对此进行了说明)。显然,在生产环境中,清单 2 中硬编码的文本字符串将来自数据库这样的持久性存储。无论何种情况,可以看到 xml 数据文件的创建非常简单。

  清单 2. 使用 xml 格式编码数据

  

xmlEncoder e = new xmlEncoder(
new BufferedOutputStream(
new FileOutputStream("xmldata.xml")));
e.writeObject("Josephine Bloggs");
e.writeObject("Internet");
e.writeObject("1mbps");
e.writeObject("Gbyte");
e.writeObject("295");
e.close();

  执行 清单 2 中的程序后,程序的执行目录中将出现一个名为 xmldata.xml 的文件。清单 3 解释了新创建文件包含的内容。

  清单 3. 生成的 xml 数据

  

<?xml version="1.0" encoding="UTF-8"?>
<JAVA version="1.5.0_06" class="JAVA.beans.xmlDecoder">
<string>Josephine Bloggs</string>
<string>Internet</string>
<string>1mbps</string>
<string>Gbyte</string>
<string>295</string>
</JAVA>

  您可以通过网络将 清单 3 中的文件传输给等待状态中的客户机 — 使用 JAVA 技术即可创建。清单 4 展示了一个简单的例子。

 

内存占用

SOA

xml

JAVA


百度大联盟认证黄金会员Copyright© 1997- CNET Networks 版权所有。 ZDNet 是CNET Networks公司注册服务商标。
中华人民共和国电信与信息服务业务经营许可证编号:京ICP证010391号 京ICP备09041801号-159
京公网安备:1101082134