基于Spring框架的WebSphere应用开发3
基于Spring框架的WebSphere应用 3 spring与websphere应用效劳器的配合 spring与底层j2ee应用效劳器还是存在一些需要结合的地方,这里给出was中的一些结合点。 使用was数据源 在java应用程序中,数据库的连接一般有两种方式来得到。一种是通过java.sql.driver nager的方式来得到数据库连接。这种方式不依赖于应用效劳的支持,但是也不提供数据库连接池的功能。另外一种方式是通过javax.sql.datasour 的方式来得到数据库连接。在传统基于j2ee的应用需要通过jndi来得到数据源(javax.sql.datasour )对象,然后再通过数据源来得到相应的数据库连接。常见的应用效劳器都支持这种方式,且一般都提供了数据库连接池的支持。虽然说我们一般推荐使用数据库连接池,但是也有一些时候我们需要脱离开应用效劳器的环境使用数据库(比方单元测试,比方应用移植等)。然而应用程序使用这两种方式的时候代码是不一样的,因此只能通过代码来应变。spring提供了一个统一使用数据源的解决方案,然后通过控制反转的机制用外部配置文件来指定使用的数据源。这样一方面可以统一这两种得到数据库连接的方式,另一方面也不需要像通常的j2ee应用通过繁琐的jndi代码来得到数据源。这样应用程序也就不需要知道使用的何种数据源。 spring提供了一个driver nagerdatasour 类来统一第一种方式的数据源获取。如果使用was中的cloudscape数据库,用外部配置文件可配置如下: .ib
m.db2j.jdbc.db2jdriver jdbc:db2j:d:\\dbname
spring提供了jndiobjectfactorybean类来支持第二种方式的数据源获取。假设was中已经配置好的数据源名称为jdbc /mydb,那么用外部配置文件可配置如下: spring framework 开发参考手册
java:p/env/jdbc/mydb 或者 jdbc/mydb true
从上面配置我们可以得知,通过使用spring,应用程序能够统一使用不同的数据源实现。如果使用环境发生变化,那么只需要修改spring的配置文件即可。对于部署在was上的web应用,在生产环境中推荐使用was实现的数据库连接池。一方面是因为连接池实现地比拟完善。另一方面,使用was提供的数据库连接池可以很完善地支持jta事务。 使用was的jta web应用程序在使用事务的时候常常会涉及一个事务类型的选择。是选择像jdbc事务这样的本地事务呢还是使用jta支持的全局事务。这个与应用程序需要涉及到的事务管理器类型和个数密切相关。spring本身不支持分布式事务,因此分布式事务需要底层的jta。但是spring提供了事务的抽象,即底层真正事务实现可以切换而不影响应用程序代码。这样应用程序可以依赖于底层was,也可以轻易地脱离开应用效劳器的环境。这一点与前面数据源的抽象非常类似。 was本身对于事务划分有两种支持方式,一种是声明式的,当然这种管理方式需要ej
b容器的支持,即所谓的容器管理事务(cmt)。另外一种方式是编程式的,通过程序代码来直接使用jta编程接口。spring对于事务的划分也可以分为声明式和编程式两种方式。对于spring编程式的事务划分方式,总体上可以分为两大类。一类是通过直接使用实现platformtransaction nager接口的类。另一类是通过使用transactiontemplate模板类,模板类的使用可以简化事务控制代码。spring对于声明式事务划分的支持实际上是利用了它的aop机制。相对于编程式事务划分,这种基于aop的方式比拟灵活,而且对代码的侵入性几乎为零。因此,如果没有特殊需要推荐使用这种事务划分方式。基于aop的常用事务划分方式可以使用proxyfactorybean加transactioninter ptor方式,或者使用transactionporxyfactorybean的方式。前一种方式相比照拟灵活,而后一种那么对使用相比照拟简单。 无论是哪一种事务划分方式,底层都需要一个事务管理机制作为支撑。如果是单一的事务资源管理器,那么根据所使用的后台事务管理资源不同的类型,可以选择的platformtransaction nager实现有datasour transaction nager,hibernatetransaction nager, jdotransaction nager, persisten brokertransaction nager,和jmstransaction nager等。无论是单个还是多个事务资源管理器,都可以使用jtatransaction nager类。如果使用jtatransaction nager,那么所有事务管理实际都会委托给底层应用效劳器的jta实现。 例如,如果使用jdbc或ibatis,那么我们可以使用简单的datasour transaction nager,外部配置文件片断如下:
如果使用hibernate,那么我们可以使用hibernatetransaction nager,外部配置文件片断如下:
使用was的jta支持,我们只需要把上述对应bean中的class属性改成class属性改为ansaction.jta.jtatransaction nager,然后再把属性改为websphere对应的transaction nager,参考如下:
模板,内容仅供参考
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论