oracle jboss,Jboss 中添加Oracle 的XA 数据源支持

这方面的资料太少了, 最终在一个IBM的网页上找到。

首先要先让Oracle 打开XA功能,可以通过以下几步实现 :

1) 在SQLPLUS(‍‍一定要用这个工具‍‍) 中,用Oracle 的系统管理员用户 SYSOPER 或 SYSDBA登录你的数据库(因为这个用户可以获得最多的访问权限)。

2)找到\javavm\install目录下,有两个脚本initxa.sql和  initjvm.sql,将它们所在的完整路径分别复制到已登录的SQLPLUS环境下(注:在windows下目录分隔符应由"\"改为"/")执行该脚本。格式如:@d :/initxa.sql 。

注意:当执行‍‍这两个脚本时,可能会执行失败,这时需要修改两个Oracle的系统参数(文件放在\database\init.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的类方法。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值