Spring2.0与BEA WebLogic Server的集成
一年多以前,我们讲述过 Spring 1.2.x与WebLogic Server 9.2的集成。其后,我们又验证了Spring和BEA WebLogic Server的更新的版本,一直到WebLogic Server 9.2和Spring 2.0的组合。这些版本表现出在功能性、可用性和性能上的重大飞跃,因此我们决定对文章进行更新以反映这一变化。
BEA WebLogic Server 9.2是Sun Microsystems的Java EE 1.4平台的领先实现。然而,WebLogic Server的核心价值主张则体现在Java EE规范没有覆盖的领域——增强的管理、易用性、高可用性、可伸缩性、可靠性和性能。实际上,WebLogic Server的价值不依赖于任何特定的编程模型,所以它与新也自然适用于新出现的非Java EE的Java编程模型。近年来出现的最令人激动的事物莫过于基于反向控制(IoC)的模型,Spring Framework就是它的事实上的实现。本文介绍了Spring 2.0 Framework、WebLogic Server以及这两者的集成的新特性。我们会看到,整体大于部分之和。
Spring简介
本节,我们来简要地概述Spring Framework的特性,包括2.0版以来的一些新特性。
Spring是基于Rod Johnson在 Expert One-on-One J2EE Design and Development(Wrox, 2002)公布的代码的一个分层的Java/Java EE应用程序框架。Spring的存在是因为我们相信Java EE应该更容易使用,并且有可能创造更简单的Java EE开发方法而不会牺牲平台性能。
Spring支持灵活的Java EE开发,允许使用Plain Old Java Objects(一般称为 POJO)开发Java EE应用程序。
改进的Spring开发体验
Spring在其核心部分提供了一个易于配置、XML驱动的反向控制(IoC)容器。IoC基于所谓的“好莱坞原则”:“不要打电话过来,请等通知。”在这种模式中,通过容器而不是直接编程将Java对象间的关系注入应用程序中。有两种注入方式—构造函数注入和setter注入,具体取决于容器是通过其构造函数还是mutator方法将信息注入已创建的Java对象。
在Spring中,注入的属性——或到其他bean的引用——是通过一个XML文件进行配置的,这使得配置轻而易举。它耦合了另外一个AOP框架,允许非侵入性增加诸如事务处理和安全等属性,这意味着开发人员可以专注于创建业务解决方案,而不必忙于复杂的Java EE开发或配置。由于容器是非侵入性的,所以您不必担心业务代码会被特定于供应商(此处也包括Spring)的工件所污染。
Spring应用程序组件
如上所述,Spring提供了一个轻量级的容器,用于提供集中式、自动化的配置并连接应用程序对象。它是非侵入性的,能够以一致的和透明的方式通过IoC把一组松耦合的组件(POJO)组装成复杂的系统。因为该容器允许首先独立地开发和测试各软件组件,然后在任意环境中(Java SE或Java EE)中进行扩展部署,所以它具有灵活性和高利用率,并提高了应用程序的可测试性和可伸缩性.此外,Spring提供了许多其他对开发人员友好的特性,下面我们一一列举:
一个用于事务管理的通用抽象层:支持可插入的事务管理器,使事务划分更轻松,同时无需处理底层的问题。该层中还包括JTA策略和一个JDBC DataSource。相比普通的JTA或EJB CMT,Spring的事务支持不依赖于Java EE环境。考虑到是一个十分灵活的非侵入性解决方案,事务语义通过AOP应用于 POJO,通过XML或Java SE 5注释进行配置。
一个JDBC抽象层:提供了一个有意义的异常层次结构(不再从SQLException抽取供应商代码),简化了错误处理,极大地减少了代码编写量。无需为了再次使用JDBC编写另外的finally代码块。面向JDBC的异常遵循Spring的一般DAO异常层次结构。
与业界领先的对象——关系映射解决方案的集成:在资源拥有者、DAO实现支持和事务策略方面。对大量IoC便利特性的一流支持,解决了许多典型的O-R映射集成问题。所有这些都遵循Spring的一般事务和DAO异常层次。而且,Spring 2.0提供了与Java Persistence API (JPA)的完全集成。
AOP功能性:完全集成到Spring配置管理中。您可以对Spring所管理的任何对象启用AOP,增加了声明性事务管理等方面。借助于Spring,您能够拥有没有EJB的声明性事务管理——甚至也可以没有JTA。
一个灵活的MVC Web应用程序框架:构建在核心的Sping功能之上。它是通过策略接口高度可配置的,并且适用多种视图技术,如JSP、Velocity、Tiles、iText和POI。注意,Spring中间层能容易地与基于任何其他Web MVC框架(如Struts、WebWork或Tapestry)的Web层组合。
一个用户可扩展的配置层:允许用户在vanilla Spring配置中加入自己定制的XML标签。整个Spring 2.0核心库已经广泛地使用这一功能,提供增强的语法和通用Spring特性的可用性。
异步编程抽象:包括与JMS提供者的框架中立的事务集成的消息驱动POJO(MDP);与异步调度机制的集成,如commonj、Java SE并行程序和Quartz;本地事件支持。
所有的Spring功能都可以在任何Java EE服务器上使用,大部分功能可以在非托管环境中使用。Spring的一个重心是支持可重用业务和不依赖于特定的Java EE 服务的数据访问对象。这些对象可以不费事地跨J2EE环境(Web或EJB)、独立应用程序和测试环境进行重用。
Spring的分层架构提供了大量灵活性。它的功能都构建在较低的层次上。例如,您可以在不使用MVC框架或没有AOP支持的情况下使用JavaBean配置管理。但是,如果您要使用Web MVC框架或AOP支持,您会发现它们构建在配置框架之上,所以您可以马上用上有关它的知识。
BEA WebLogic Server 9.2简介
本节,我们来简要概述BEA WebLogic Server的特性,重点强调其提供的底层基础架构,而不是编程模型。
WebLogic Server是可伸缩的企业级Java EE应用服务器。WebLogic Server基础架构支持各类分布式应用程序的部署,是构建各种应用程序的理想基础。
Sun Microsystem公司的 Java EE 1.4 规范 在WebLogic Server上的实现提供了标准的一组API,用以创建能够访问多种服务(如数据库、消息传递服务和外部企业系统连接)的分布式Java应用程序。终端用户客户程序使用Web浏览器客户端或Java客户端访问这些应用程序。由于Java EE是如此有名,这里我们就不进一步讨论了。参见关于 编程模型 的 WebLogic Server文档,可以获得更多信息。
除了实现Java EE之外,WebLogic Server还使企业能够在一个健壮的、安全的、高可用的、可伸缩的环境中部署任务关键型应用程序。这些特性允许企业配置WebLogic Server实例集群以分布负载,并在发生硬件或其他故障时提供额外的容量。新的诊断工具允许系统管理员监控和调优已部署的应用程序和 WebLogic Server环境本身的性能。可以对WebLogic Server进行配置来自动监控和调整应用程序吞吐量,无需人工干预。广泛的安全特性保护了服务的访问,保证了企业数据安全,并阻止了恶意攻击。
WebLogic Server的增强后的服务质量
就像许多其他的BEA产品,WebLogic Server如同冰山,浮在水面上的只是很少的一部分而已。具体来说,WebLogic Server提供了许多特性和工具来支持高可用的和可伸缩的应用程序部署:
WebLogic Server clusters 通过将工作负载分布到多个WebLogic Server实例之间,为用户的应用程序提供可伸缩性和可靠性。基于要处理的工作量,传入的请求能够被发送给集群中的一个WebLogic Server实例。万一出现硬件或其他故障,会话状态对其他集群节点可用,这些节点能够恢复故障节点的工作。另外,可以实现集群,使服务驻留在这样的单台机器上:如果出现故障,该机器可以选择把服务迁移到集群中的另一个节点上。
除了在一个集群内跨服务器复制HTTP会话状态之外,WebLogic Server也能够 跨多个集群复制HTTP会话状态,从而在多个地理区域、多个网格和Internet服务提供商中扩展可用性和容错能力。
Work Manager 基于用户定义的规则对工作划分优先级,并监控实际的运行时性能统计信息。然后利用这些信息优化应用程序的性能。Work Manager可以全局地应用于一个WebLogic Server域或者一个特定的应用程序组件。
过载保护 使WebLogic Server能够检测和避免过载情况,并从中得以恢复正常。
网络频道 基于流量类型把网络流量分散到各个频道中去,有利于网络资源的有效使用。
WebLogic Server持久性存储 是一个性能卓越的内置存储器解决方案,用于需要持久性存储的WebLogic Server子系统和服务。例如,它可以保存持久性的JMS消息,或者暂时保存使用存储-转发特性发送的消息。持久性存储支持到基于文件的存储器或到支持JDBC的数据库的持久性。
存储-转发服务 使WebLogic Server在跨 WebLogic Server实例分布的应用程序之间可靠地传递消息。如果由于网络或系统故障造成消息接受方无效,那么一个本地服务器实例将保存消息,并且当接受方有效时进行转发。
企业级就绪部署工具 使应用程序从开发阶段到生产环境的部署和迁移变得容易。
生产环境重新部署 使企业在不中断旧版程序的工作进程的情况下部署其新的版本。
现在,让我们来看一看这两个系统之间的协作。
在Java EE和Spring环境中开发应用程序
为了比较和对照Java EE和Spring开发方法的不同,我们采用用Spring 2.0 Framework重新编写了MedRec示例程序,充分利用Spring 2.0的许多创新特性。下一节,我们将给出MedRec一般架构的简短概述,然后依次看一下它的Java EE形式和Spring形式。
Medical Records应用程序
Avitek Medical Records(或MedRec)是一个WebLogic Server示例程序工具包,简明地示范了Java EE平台的各个方面。设计MedRec的目的是作为各层次水平Java EE开发人员的一个教学工具。它显示了每个Java EE组件的使用方法,阐明了适于组件交互和客户端开发的设计模式。MedRec也表明了在WebLogic Server上开发和部署应用程序的最佳实践。
MedRec背后的真实世界概念是一个框架,其中患者、医生、管理人员使用各种不同的客户端管理患者数据。对于患者,MedRec提供了基于Web的应用程序,供他们察看自己的医疗记录和维护档案文件。对于管理人员,MedRec提供了基于Web的应用程序,用于管理注册登记、医疗记录上传和所有应用程序监控。MedRec还提供与独立的医疗机构接合的资源。为了演示这个通信系统,MedRec包括一个医生应用程序,用于向MedRec系统请求和提交数据。
MedRec Java EE版本架构概述
Java EE和WebLogic Server版的MedRec的设计和实现采用传统的三层架构模型,分为相互独立的客户端、服务器和数据存储三个部分:
表示层:它负责所有的用户交互;有时也称为客户端层。
服务层:它是封装了应用程序业务逻辑的中间层。它处理来自异构客户端的请求,同时与各种后端系统进行交互,包括数据存储器。该层有时也称为服务器层。
企业信息系统(EIS)层:它表示那些提供和/或存储遗留的程序和数据库的数据的系统。有时也称为数据存储。
我们为MedRec的患者和管理部门程序开发了Web应用程序(webapp),公开对于各自用户的服务。webapp符合模型-视图-控制器(Model-View-Controller)模式,Java Server Page呈现视图给用户,模型封装要呈现给用户和从用户处捕捉而来的数据,而控制器机制则管理除与服务层的交互之外的组件交互。MedRec采用Jakarta Struts来实现该模式。
服务层提供服务给发出请求的客户端,并管理与后端应用程序和资源的交互。MedRec的服务层采用Session Facade模式来封装业务逻辑和业务数据。Session Facade通过提供一个到分布式服务的接口,简化了应用程序的复杂性。在MedRec中,Session Facade的首要责任是提供数据吞吐量。在MedRec的J2EE和WebLogic Server版本中,Session Facade被开发为无状态的会话Enterprise JavaBean,而数据则是由实体Enterprise JavaBean来管理的。
为了与外部实体接合,MedRec通过Web服务公开应用程序功能,从而允许不同系统之间使用一系列开放标准动态交互。通过Web 服务公开服务使得MedRec能够为独立的各方提供数据,或接收来自各方的数据,这样就实现了集中式医疗记录管理的主要目标。