博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Jboss 中添加Oracle 的XA 数据源支持
阅读量:6567 次
发布时间:2019-06-24

本文共 1442 字,大约阅读时间需要 4 分钟。

hot3.png

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

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

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

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) 

转载于:https://my.oschina.net/frankies/blog/394775

你可能感兴趣的文章
基金项目的英文
查看>>
《软件性能测试与LoadRunner实战教程》喜马拉雅有声图书上线
查看>>
ios 字典转模型
查看>>
Java类集
查看>>
类的生命周期
查看>>
php apache用户写文件夹权限设置
查看>>
浅析rune数据类型
查看>>
普通用户开启AUTOTRACE 功能
查看>>
游侠原创:推荐一款免费的Syslog转发工具
查看>>
onAttachedToWindow和onDetachedFromWindow调用时机源码解析
查看>>
根据Servlet的Filter自定义实现字符编码过滤器
查看>>
oh-my-zsh安装与配置
查看>>
团队随笔
查看>>
1.7 文件目录管理及相关的命令使用方法
查看>>
页面导入样式时,使用link和@import有什么区别?
查看>>
类成员与类的实例成员
查看>>
Spark源码编译并在YARN上运行WordCount实例
查看>>
Spring AOP + AspectJ annotation example
查看>>
Spring VS EJB 3 的若干认识误区(转)
查看>>
React.js初探(一)
查看>>