设为首页 收藏本站
查看: 734|回复: 0

[经验分享] Weblogic + SqlServer2000 JTA 配置 step by step

[复制链接]
累计签到:2 天
连续签到:1 天
发表于 2017-2-16 10:40:00 | 显示全部楼层 |阅读模式
  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 代码

  • <?xml version="1.0" encoding="UTF-8"?>  
  •   
  • <!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" "http://www.springframework.org/dtd/spring-beans.dtd">  
  •   
  • <beans>  
  •        
  •     <bean id="dataSource1" class="org.springframework.jndi.JndiObjectFactoryBean">  
  •          <property name="jndiName" value="jdbc/datasource1" />  
  •     </bean>  
  •        
  •     <bean id="dataSource2" class="org.springframework.jndi.JndiObjectFactoryBean">  
  •          <property name="jndiName" value="jdbc/datasource2" />  
  •     </bean>  
  •        
  •     <bean id="transactionManager" class="org.springframework.transaction.jta.JtaTransactionManager">  
  •     </bean>  
  •        
  •     <!-- Dao configuration -->  
  •     <bean id="memberDao" class="com.dgc.jta.dao.impl.MemberDaoImpl">  
  •         <property name="dataSource" ref="dataSource1" />  
  •     </bean>  
  •        
  •     <bean id="orderDao" class="com.dgc.jta.dao.impl.OrderDaoImpl">  
  •         <property name="dataSource" ref="dataSource2" />  
  •     </bean>  
  •        
  •     <!-- Service configuration -->  
  •     <bean id="commonManagerTarget" class="com.dgc.jta.service.impl.commonManagerImpl">  
  •         <property name="memberDao" ref="memberDao" />  
  •         <property name="orderDao" ref="orderDao" />  
  •     </bean>  
  •        
  •     <bean id="commonManager" class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean">  
  •         <property name="target" ref="commonManagerTarget"/>  
  •         <property name="transactionManager" ref="transactionManager"/>  
  •         <property name="transactionAttributes">  
  •             <props>  
  •                 <prop key="*">PROPAGATION_REQUIRED</prop>  
  •             </props>  
  •         </property>  
  •     </bean>  
  •        
  • </beans>  

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

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-342922-1-1.html 上篇帖子: [转]使用Ant管理配置Weblogic 下篇帖子: weblogic下的jsp预编译
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表