`
jlj008
  • 浏览: 96977 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

Weblogic + SqlServer2000 JTA 配置 step by step

阅读更多

JTA在处理分布式事务闻名已久,但是一直没有真正去玩过JTA,趁着这几天空闲,心血来潮想玩一把。经过一番周折,通过weblogic的JTA,并结合spring提供的简单配置,跑通了自己的第一个JTA事务。
记录一下,留个纪念,如果有朋友在实验中遇到同样的问题,也可以略加参考,希望对你有点帮助。

Step by Step
1. 安装Sqlserver 2000 + sp4

2. 在www.bea.com 下载weblogic express 8.1。

3. 安装weblogic,并创建自己的domain实例,然后启动domain实例。

4. 浏览http://localhost:7001/console ,如果出现管理页面,则安装已成功。

5. 进入管理页面后,选择Services Configurations - JDBC - Connection Pools,配置连接池。
选择创建一个新的连接池,Database Type选择MS Sql Server,然后在Database Driver中选择*BEA's MS Sql Server Driver (Type 4 XA)。注意,要真正使用JTA事务,必须选择带XA的驱动,以支持JTA事务的两阶段提交。
然后Continue,输入HOST,数据库名称,用户名和密码,Continue

6. 进入下一个页面后,测试一下是否配置正确,Test Driver Configuration,此时对于第一次使用JTA的朋友来说,一般是测试通不过的,weblogic可能会给出一些原因,比如:sp_xxx存储过程找不到、DTC是否已经开启啊、xa_open (0) returns -3之类的错误,解决办法如下:
sp_xxx存储过程找不到 - 在需要JTA事务的master数据库中运行%BEA_HOME%/weblogic81/server/lib/instjdbc.sql,并且复制sqljdbc.dll到%SQLSERVER_HOME%/MSSQL/Binn目录下。
DTC是否已经开启 - 在服务中,启动 Distributed Transaction Coordinator。
xa_open (0) returns -3 - 数据库用户名必须是系统管理员,如果还是不行,则修改注册表HKLM\Software\Microsoft\MSDTC\Security的XaTransactions,如果该值为0,说明现在不支持分布式事务,我们把它改成1,然后重起Sqlserver和DTC。
以上问题都解决了,如果看到测试通过,恭喜您,主要问题都解决了。

5. 配置Datasource,写好jndi名字,选择刚才配好的连接池。可以尝试配置多个不同的服务器和数据库,然后再程序里测试JTA。

6. 配置Spring

xml 代码
  1. <? xml   version = "1.0"   encoding = "UTF-8" ?>   
  2.   
  3. <!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" "http://www.springframework.org/dtd/spring-beans.dtd" >   
  4.   
  5. < beans >   
  6.        
  7.      < bean   id = "dataSource1"   class = "org.springframework.jndi.JndiObjectFactoryBean" >   
  8.           < property   name = "jndiName"   value = "jdbc/datasource1"   />   
  9.      </ bean >   
  10.        
  11.      < bean   id = "dataSource2"   class = "org.springframework.jndi.JndiObjectFactoryBean" >   
  12.           < property   name = "jndiName"   value = "jdbc/datasource2"   />   
  13.      </ bean >   
  14.        
  15.      < bean   id = "transactionManager"   class = "org.springframework.transaction.jta.JtaTransactionManager" >   
  16.      </ bean >   
  17.        
  18.      <!-- Dao configuration -->   
  19.      < bean   id = "memberDao"   class = "com.dgc.jta.dao.impl.MemberDaoImpl" >   
  20.          < property   name = "dataSource"   ref = "dataSource1"   />   
  21.      </ bean >   
  22.        
  23.      < bean   id = "orderDao"   class = "com.dgc.jta.dao.impl.OrderDaoImpl" >   
  24.          < property   name = "dataSource"   ref = "dataSource2"   />   
  25.      </ bean >   
  26.        
  27.      <!-- Service configuration -->   
  28.      < bean   id = "commonManagerTarget"   class = "com.dgc.jta.service.impl.commonManagerImpl" >   
  29.          < property   name = "memberDao"   ref = "memberDao"   />   
  30.          < property   name = "orderDao"   ref = "orderDao"   />   
  31.      </ bean >   
  32.        
  33.      < bean   id = "commonManager"   class = "org.springframework.transaction.interceptor.TransactionProxyFactoryBean" >   
  34.          < property   name = "target"   ref = "commonManagerTarget" />   
  35.          < property   name = "transactionManager"   ref = "transactionManager" />   
  36.          < property   name = "transactionAttributes" >   
  37.              < props >   
  38.                  < prop   key = "*" > PROPAGATION_REQUIRED </ prop >   
  39.              </ props >   
  40.          </ property >   
  41.      </ bean >   
  42.        
  43. </ beans >   


7. 部署war应用,测试得到,使用commonManagerTarget是不带分布式事务的,使用commonManager是带分布式事务的,成功!

分享到:
评论

相关推荐

    Weblogic8.X+SQL SERVER2000安装及连接池配置指南

    ### Weblogic8.X+SQL SERVER2000安装及连接池配置详解 #### 环境配置与基础知识 在深入探讨Weblogic8.X与SQL SERVER2000的集成及连接池配置之前,我们首先需要了解一些基本概念和环境设置。 **Weblogic 8.X简介**...

    Oracle+Weblogic+Server+Java反序列化漏洞 解决方案

    Oracle+Weblogic+Server+Java反序列化漏洞 解决方案 Oracle+Weblogic+Server+Java反序列化漏洞 解决方案

    Weblogic+Server+9.2群集配置.rar

    WebLogic Server 9.2 群集配置详解 WebLogic Server 是 Oracle 公司提供的一个企业级 Java 应用服务器,它支持集群部署,能够提供高可用性、负载均衡和故障转移等关键功能。在 WebLogic Server 9.2 版本中,群集...

    Weblogic8.X+SQLSERVER2k.pdf

    【Weblogic8.X+SQLSERVER2k.pdf】文档主要涵盖了如何在Windows XP SP2系统上配置WebLogic 8.1 SP3与SQL Server 2000的集成,包括安装JDK、WebLogic Server、SQL Server及其补丁,以及部署J2EE Web项目和创建数据源的...

    个人网上书店 myeclipse+sqlserver2005

    它包含了对Java、JSP、Servlet、JSF、JPA、Struts、Spring等开发的支持,以及对多种服务器如Tomcat、WebLogic、JBoss等的配置和调试功能。在本项目中,MyEclipse被用作代码编辑、编译、调试和部署的工具。 2. **JSP...

    weblogic10配置sqlServer2000数据源

    本文将详细阐述如何在WebLogic 10中配置SQL Server 2000作为数据源,以便让WebLogic应用程序能够连接并操作SQL Server数据库。 首先,你需要确保你的环境满足以下前提条件: 1. 安装并运行了WebLogic Server 10。 2...

    Weblogic 8.0中SQL Server 2000的JDBC连接池配置

    用FLASH,详细的演示了在,Weblogic 8.0中SQL Server 2000的JDBC连接池配置的过程

    《JavaEE实用开发指南:基于Weblogic+EJB3+Struts2+Hibernate+Spring》-- part2/3

    《JavaEE实用开发指南:基于Weblogic+EJB3+Struts2+Hibernate+Spring》-- part2/3

    weblogic+myeclipse配置!

    如果项目需要连接数据库,还需要添加相应的JDBC驱动库,如WebLogic自带的SQL Server驱动库D:BEAweblogic81serverlibmssqlserver4v65.jar。 5. **启动和停止WebLogic**: 配置完成后,可以通过Eclipse工具栏的"Run/...

    weblogic+db2部署配置完全手册

    ### Weblogic+DB2部署配置完全手册:详细解析与步骤指南 #### 一、Weblogic安装与基础配置 Weblogic是Oracle公司推出的一款强大的企业级Java应用服务器,它提供了丰富的功能来支持各种复杂的业务需求。在生产环境...

    WebLogic+Server+9.2+集群配置多服务器版.doc

    【WebLogic Server 9.2 集群配置详解】 WebLogic Server 是一款由 Oracle 公司提供的企业级 Java 应用服务器,它支持集群配置,以提高应用程序的可用性和可伸缩性。在 WebLogic Server 9.2 版本中,集群配置是一个...

    Linux+WebLogic+Oracle建站参考资料

    在“Linux+WebLogic+Oracle建站参考资料”中,你可能找到以下内容: 1. Linux系统管理指南:这可能包含如何安装和配置Linux系统,以及如何管理和维护Linux服务器的教程。 2. WebLogic部署手册:这部分资料可能会...

    weblogic中sqlserver连接池的配置.rar

    下面将详细介绍如何在WebLogic中配置SQL Server 2005的连接池。 首先,理解连接池的概念至关重要。连接池是一种管理数据库连接的机制,它允许重复使用已建立的数据库连接,而不是每次需要时都创建新的连接,从而...

    Linux + JDK + WebLogic Server+ Oracle 的安装配置过程

    本教程将详细介绍如何在Linux操作系统上安装Java Development Kit (JDK),配置Oracle数据库,并部署WebLogic Server,这是一套完整的后端服务环境搭建流程。以下是详细的步骤和注意事项: 一、Linux系统准备 首先,...

    配置+WebLogic+Server+11g+集+群+Linux版

    ### WebLogic Server 11g 集群配置详解(Linux版) #### 一、预备知识 在深入了解如何配置WebLogic Server 11g集群之前,我们先来了解一下几个重要的概念: 1. **Domain(域)**:在WebLogic Server环境中,...

    WebLogic+Server+9.2+集群配置多服务器版实用.pdf

    WebLogic Server 9.2 集群配置详解 WebLogic Server 是一款广泛使用的Java EE应用服务器,由Oracle公司提供。在9.2版本中,它支持集群配置,以提高应用的可用性和可扩展性。集群是通过多个独立的服务器实例协同工作...

    -WebLogic+Server集群包括apache.ra

    WebLogic+Server集群包括apache.chm 中文版

    weblogic10下配置Sql Server 数据源

    在WebLogic 10中配置SQL Server数据源是企业级应用服务器与数据库连接的重要步骤,这对于运行基于Java EE的应用程序至关重要。以下是一个详尽的步骤指南,解释如何完成这一过程。 1. **环境准备**: - 首先确保你...

    weblogic+myeclipse6.5

    【标题】:“Weblogic+MyEclipse6.5”整合指南 在IT行业中,Weblogic是Oracle公司开发的一款企业级应用服务器,它主要用于部署、管理Java EE(Java Enterprise Edition)应用程序。MyEclipse则是一款强大的集成开发...

Global site tag (gtag.js) - Google Analytics