这方面的资料太少了, 最终在一个上找到。
首先要先让Oracle 打开XA功能,可以通过以下几步实现 :
1) 在SQLPLUS(一定要用这个工具) 中,用Oracle 的系统管理员用户 SYSOPER 或 SYSDBA登录你的数据库(因为这个用户可以获得最多的访问权限)。
2)找到<Oracle 安装目录>\javavm\install 目录下,有两个脚本initxa.sql 和 initjvm.sql,将它们所在的完整路径分别复制到已登录的SQLPLUS环境下(注:在windows下目录分隔符应由"\"改为"/")执行该脚本。格式如: :/initxa.sql 。
注意:当执行这两个脚本时,可能会执行失败,这时需要修改两个Oracle的系统参数(文件放在<Oracle 安装目录>\database\init<实例 SID>.ora),
参数名称 | 最小值 |
java_pool_size | 12000000 |
shared_pool_size | 24000000 |
修改完后,需要重新启动Oracle实例才能生效。
3) 设置当前数据库访问用户的权限:
grant select on DBA_PENDING_TRANSACTIONS to <当前用户> grant select on pending_trans$ to <当前用户> ; grant select on dba_2pc_pending to <当前用户> ;grant execute on dbms_xa to <当前用户> ; --(如果使用Oracle 10.2.0.4 或高版本的JDBC driver时) 当前用户> 当前用户> 当前用户> 当前用户>
4) 重新启动数据实例。
5)用需要的操作用户登录数据库验证权限是否生效。
JBOSS 实例端的设置
1) 复制对应版本的数据库的JDBC 驱动库(.jar)文件到实例的LIB目录下。
2) 从JBOSS的XA样例模板中复制一份Oracle 的XA配置 ,到对应的数据源配置文件中
如:
jdbc/rrr oracle.jdbc.xa.client.OracleXADataSource jdbc:oracle:thin:@xxxx:xxx:333 33 22 5 20 Oracle10g
总结:Oracle 的XA特性是利用 JAVA驱动库调用 事务启动、事务回滚、事务提交和事务结束等存储过程方法(具体可以参考 驱动包的代码:oracle.jdbc.xa.OracleXAResource--反编译出来的),而这些存储过程又是Oracle 本地JVM的类方法。
参考资料:
1)
2)
3)
4)
5)