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 代码
-
<?
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
>
??
-
???? ??
-
????
??
-
????
<
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
>
??
-
???? ??
-
????
??
-
????
<
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是带分布式事务的,成功!