使用Java开源组件JOTM开发分布式事务应用

    JOTM(Java Open Transaction Manager)是ObjectWeb的开源事务中间件,支持分布式事务,实现了JTA规范。下面以jotm-2.0.10为例说明其在J2EE项目中的用法。
    需要的jar包:carol.jar、commons-logging.jar、connector-1_5.jar、jotm.jar、jotm_iiop_stubs.jar、jotm_jrmp_stubs.jar、jta-spec1_0_1.jar、jts1_0.jar、objectweb-datasource.jar、xapool.jar。
    JOTM默认在classpath下使用名为carol.properties的配置文件。下面给一个carol.properties的例子,可以根据自己的需要修改:
# JNDI (Protocol Invocation)
carol.protocols=jrmp

# Local RMI Invocation
carol.jvm.rmi.local.call=true

# do not use CAROL JNDI wrapper
carol.start.jndi=false

# do not start a name server
carol.start.ns=false

# Naming Factory
carol.jndi.java.naming.factory.url.pkgs=org.apache.naming
    在context中配置以下资源:
<Resource name="jdbc/db" auth="Container" type="javax.sql.DataSource"
factory="org.objectweb.jndi.DataSourceFactory"
username="db_user_name"
password="db_user_pwd"
driverClassName="oracle.jdbc.driver.OracleDriver"
url="jdbc:oracle:thin:@192.168.0.10:1521:oradb" />

<Resource name="jdbc/db1" auth="Container" type="javax.sql.DataSource"
factory="org.objectweb.jndi.DataSourceFactory"
username="db_user_name"
password="db_user_pwd"
driverClassName="oracle.jdbc.driver.OracleDriver"
url="jdbc:oracle:thin:@192.168.0.11:1521:oradb1" />

<Transaction name="UserTransaction" auth="Container"
type="javax.transaction.UserTransaction"
factory="org.objectweb.jotm.UserTransactionFactory"
jotm.timeout="60"/>
    为了使用方便,建立一个获取资源的工具类:
package demo.jotm;

import javax.naming.Context;
import javax.naming.InitialContext;
import javax.sql.DataSource;
import javax.transaction.UserTransaction;

public class DBUtil {
private static Context _ctx;

private static Context getContext() throws Exception {
if (_ctx != null) return _ctx;
_ctx = new InitialContext();
return _ctx;
}

public static UserTransaction getUserTransaction() throws Exception {
Context ctx = getContext();
UserTransaction ut = (UserTransaction)ctx.lookup("java:comp/UserTransaction");
return ut;
}

public static DataSource getDataSource() throws Exception {
Context ctx = getContext();
DataSource ds = (DataSource)ctx.lookup("java:comp/env/jdbc/db");
return ds;
}

public static DataSource getDataSource1() throws Exception {
Context ctx = getContext();
DataSource ds = (DataSource)ctx.lookup("java:comp/env/jdbc/db1");
return ds;
}
}
    建立一个jsp文件,完成事务的功能:
<%@page import="java.sql.Statement"%>
<%@page import="java.sql.Connection"%>
<%@page import="javax.transaction.UserTransaction"%>
<%@page import="demo.jotm.DBUtil;"%>

<%
boolean rollback = false;
UserTransaction ut = DBUtil.getUserTransaction();
Connection conn = DBUtil.getDataSource().getConnection();
Connection conn1 = DBUtil.getDataSource1().getConnection();
try {
ut.begin();

Statement stmt = conn.createStatement();
stmt.executeUpdate("insert into t values(1,'1234567890')");
stmt.close();

Statement stmt1 = conn1.createStatement();
stmt1.executeUpdate("insert into t values(2,'abc')");
stmt1.close();
}
catch (Exception e) {
rollback = true;
e.printStackTrace();
}
finally {
if (rollback) ut.rollback();
else ut.commit();

conn.close();
conn1.close();
}

out.print(rollback);
%>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值