技术开发 频道

Spring和Hibernate与WebSphere Application Server一起使用

IT168 技术文档】

    Spring Framework(通常称为 Spring)是一种开源项目,目的是为了使 J2EE™ 环境更具可访问性。Spring 为简单 Java™ 对象提供框架,使这些对象可以通过包装类和 XML 配置使用 J2EE 容器。Spring 的目标是为这些项目提供显著的好处,提高这些项目的开发效率和运行时性能,同时改进测试覆盖率和应用程序质量。

    Hibernate 是开放源代码持久性和查询框架,提供 POJO(传统 Java 对象)到关系数据库表的与对象相关的映射,以及数据查询和检索功能。

    尽管许多组织感兴趣的是了解使用这些框架能够获得什么好处,但 IBM 希望让使用这些框架的客户知道,他们可以通过 WebSphere Application Server 以强健和可靠的方式做到这一点。本文介绍这些框架如何能够与 WebSphere Application Server 一起使用,并介绍针对各种用例的非常好的实践,以帮助您尽快地使用 Spring 或 Hibernate。

    使用 Spring

    通常将 Spring 描述为轻量级容器环境,但是将其描述为用于简化开发的框架可能更适当。Spring Framework 由 Interface21 根据 Rod Johnson 发表的关于依赖项注入设计模型开发。Spring 可以在独立应用程序或应用服务器中使用。其主要概念是使用依赖项注入和面向方面的编程来简化和平稳地进行从开发到测试再到生产的转换。

    涉及 Spring 的最常用的场景之一是使用简单的 Java Bean 类配置并驱动业务逻辑。 Spring 文档应提供了使用 Spring Bean 构建应用程序的足够信息,其中没有提供任何特定于 WebSphere 的内容。以下部分将描述 Spring 在 WebSphere Application Server 上的一些使用场景。根据本文的建议开发的 Spring 应用程序应能够轻松地在 WebSphere Application Server 或 WebSphere Application Server Network Deployment 环境中执行。

    除明确指出以外,本文提供的信息适用于所有平台上的 WebSphere Application Server 版本 6.0.2.x 和 6.1.x。

    表示层注意事项

    本部分介绍的注意事项与在基于 Web 的表示层中使用 Spring 相关。

    Web MVC 框架

    Spring 的 Web MVC 框架在某一时间内一直是其他框架的备选框架。直接由 WebSphere Application Server 提交、使用和支持的 Web MVC 框架包括 JavaServer Faces (JSF) 和 Struts。Spring 文档描述了如何将 Spring 与这些 Web 框架集成。尽管 WebSphere Application Server 支持使用上面的任何 MVC,但 IBM 仅为 WebSphere Application Server 附带的框架提供产品支持。

    Portlet MVC 框架

    Spring 还提供了一个 Portlet MVC 框架(该框架镜像 Spring Web MVC 框架),而且在 WebSphere Portal V6.0 和 WebSphere Application Server V6.1 Portlet 容器中运行。有关 Spring Portlet 的示例集,请参见Spring Portlet MVC。在 WebSphere Application Server V6.1 Portlet 容器中运行 Portlet 需要创建其他 Web 应用程序才能定义 Portlet 的布局和聚合。从 WebSphere Application Server 信息中心和文章 Portlet 容器介绍 中可以获得关于如何使用 Portlet 聚合器标记库的信息。通常的做法是结合使用 JSF 和 Portlet 进行呈现。关于如何将 Spring、Hibernate、JSF 和 WebSphere Portal 组合起来的信息,请参见 Configuring Hibernate, Spring, Portlets, and OpenInSessionViewFilter with IBM WebSphere Portal。

    数据访问注意事项

    本部分介绍的注意事项与访问事务数据的 Spring Bean 配置相关。

    Spring Framework 实际上使用一个容器管理层(在 J2EE 环境中委派给基础 J2EE 运行时)包装 Spring Bean。下面将介绍应如何配置 Spring Bean,以便 Spring Framework 可以正确委派到 WebSphere Application Server 运行时并与其集成。

    访问 WebSphere Application Server 中配置的数据源

    WebSphere Application Server 管理在应用服务器执行环境中使用的资源。需要访问 JDBC 数据源之类资源的 Spring 应用程序应该利用 WebSphere 管理的资源。要完成此任务,请执行以下步骤:

    在开发过程中,应该使用资源引用配置 WAR 模块。例如:

<resource-ref> <res-ref-name>jdbc/springdb</res-ref-name> <res-type>javax.sql.DataSource</res-type> <res-auth>Container</res-auth> <res-sharing-scope>Shareable</res-sharing-scope> </resource-ref>

    对于 EJB JAR 文件,应该在需要访问数据源的每个 EJB 中声明同一资源引用。

    然后在 Spring 应用程序配置中声明数据源代理 Bean,代理 Bean 引用 WebSphere 管理的资源提供程序:

<bean id="WASDataSource" class="org.springframework.jndi.JndiObjectFactoryBean"> <property name="jndiName" value="java:comp/env/jdbc/springdb"/> <property name="lookupOnStartup" value="false"/> <property name="cache" value="true"/> <property name="proxyInterface" value="javax.sql.DataSource"/> </bean>

    通过此代理 Bean 访问数据源将会使用模块配置的引用查看数据源,因此能够由 WebSphere Application Server 正确管理。注意,jndiName 属性值匹配与资源引用中声明的资源引用名称连接的模式 java:comp/env/。

    然后,Spring 应用程序可以在适当情况下使用数据源代理 Bean。

    将应用程序部署到 WebSphere Application Server 时,必须以常规方式配置资源提供程序和资源数据源,以便由 Spring 应用程序资源引用使用。在部署过程中,在模块的部署描述符中声明的资源引用将绑定到应用服务器的配置数据源。

    使用 JDBC 本机连接

    当各种 JDBC 操作需要与本机 JDBC 资源交互时,Spring 可提供访问本机连接的机制。当在 JdbcTemplate 类上设置了 NativeJdbcExtractor 类时,Spring JdbcTemplate 类才可以利用此功能。设置 NativeJdbcExtractor 类后,当与 WebSphere Application Server 一起使用时,Spring 总是向下找到本机 JDBC 连接。这将忽略以下 WebSphere 服务质量功能和优点:

连接处理跟踪和再关联
连接共享
参与事务
连接池管理
    这带来的另一个问题是 WebSphereNativeJdbcExtractor 类将依赖于内部 WebSphere 适配器类。这些内部类可能因 WebSphere Application Server 的版本而异,并且以后可能更改,从而中断依赖于此功能的应用程序。

    在 WebSphere Application Server 上不支持使用 NativeJdbcExtractor 类实现(例如 WebSphereNativeJdbcExtractor),您应避免需要它的场景。备选方案是使用 WebSphere Application Server WSCallHelper 类来访问非标准供应商的数据源扩展。

    使用 Spring 处理事务

    WebSphere Application Server 为事务处理和管理与资源提供程序的连接提供了一个强健和可伸缩的环境。与 JDBC、JMS 和 Java Connector 资源适配器的连接由 WebSphere Application Server 管理,而无论是否在使用全局事务;甚至在缺少全局事务时,始终存在一个运行时上下文,在该上下文中可以访问所有资源提供程序连接。WebSphere Application Server 将此运行时上下文称为本地事务容器 (LTC) 作用域;在缺少全局事务时始终存在一个 LTC,并且无论是存在全局事务还是 LTC,资源访问始终由运行时管理。为确保事务上下文管理的完整性,以便可以正确管理事务资源,WebSphere Application Server 不向 WebSphere Application Server 中部署的应用程序或应用程序框架公开 javax.transaction.TransactionManager 接口。

    在 Spring 中,有许多方法可以驱动事务控制下的资源更新,这包括编程形式和声明形式。声明形式有 Java Annotation 和 XML 描述符形式。如果将 Spring 2.1 RC1 与 WebSphere Application Server V6.0.2.19 或 V6.1.0.9 或者更高版本一起使用,则可以利用对 Spring 的声明式事务模型的完全支持。Spring 2.1 RC1 有一个新的用于 WebSphere Application Server 的 PlatformTransactionManager 类,称为 WebSphereUowTransactionManager。该类利用 WebSphere Application Server 的受支持 UOWManager 接口进行事务上下文管理。通过 WebSphere Application Server 的 UOWManager 类管理事务划分可以确保在访问资源提供程序时始终可以使用适当的全局事务或 LTC 上下文。不过,较早版本的 Spring 使用了内部 WebSphere 接口以牺牲 Web 和 EJB 容器功能为代价来管理资源,并且不支持由应用程序使用。这会使容器处于未知状态,从而有可能导致数据损坏。

    Spring 2.1 RC1 或更高版本中的声明式事务划分在 WebSphere Application Server 中受支持,它使用下面的声明提供对 WebSphere 事务的支持:

<bean id="transactionManager" class="org.springframework.transaction.jta.WebSphereUowTransactionManager"/>

    引用此声明的 Spring Bean 然后将使用标准 Spring 依赖项注入来使用事务支持,例如:

<bean id="someBean" class="some.class"> <property name="transactionManager" > <ref bean="transactionManager"/> </property> ... </bean> <property name="transactionAttributes"> <props> <prop key="*">PROPAGATION_REQUIRED</prop> </props> </property>

    WebSphereUowTransactionManager 支持每个 Spring 事务属性:

PROPAGATION_REQUIRED PROPAGATION_SUPPORTS PROPAGATION_MANDATORY PROPAGATION_REQUIRES_NEW PROPAGATION_NOT_SUPPORTED PROPAGATION_NEVER

    对于不提供 org.springframework.transaction.jta.WebSphereUowTransactionManager 的早期 Spring 版本以及不提供 com.ibm.wsspi.uow.UOWManager 的 WebSphere Application Server V6.0.2.19 或 V6.1.0.9 之前的版本,WebSphere Application Server 中的事务支持通过以下 Spring 配置实现:

<bean id="transactionManager" class="org.springframework.transaction.jta.JtaTransactionManager"> <property name="autodetectTransactionManager"value="false" /> </bean>

    此配置支持一组受限制的事务属性,其中不包括 PROPAGATION_NOT_SUPPORTED 和 PROPAGATION_REQUIRES_NEW。Spring 类 org.springframework.transaction.jta.WebSphereTransactionManagerFactoryBean 也宣称提供 PROPAGATION_NOT_SUPPORTED 和 PROPAGATION_REQUIRES_NEW 功能,它使用不受支持的内部 WebSphere Application Server 接口,并且不应与 WebSphere Application Server 一起使用。

0
相关文章