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

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

  • 首先要先让Oracle 打开XA功能,能够经过如下几步实现 :java

1) 在SQLPLUS必定要用这个工具 中,用Oracle 的系统管理员用户 SYSOPERSYSDBA登陆你的数据库(由于这个用户能够得到最多的访问权限)。web

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

 注意:当执行这两个脚本时,可能会执行失败,这时须要修改两个Oracle的系统参数(文件放在<Oracle 装目录>\database\init<实例 SID>.ora)数据库

参数名称 最小值
java_pool_size
12000000
shared_pool_size
24000000

修改完后,须要从新启动Oracle实例才能生效。windows

3) 设置当前数据库访问用户的权限:oracle

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) 从新启动数据实例。app

5)用须要的操做用户登陆数据库验证权限是否生效。jvm

  • JBOSS 实例端的设置工具

    1) 复制对应版本的数据库的JDBC 驱动库(.jar)文件到实例的LIB目录下。

    2) 从JBOSS的XA样例模板中复制一份Oracle 的XA配置 ,到对应的数据源配置文件中

  •   如:

  <xa-datasource>
    <jndi-name>jdbc/rrr</jndi-name>
    <xa-datasource-class>oracle.jdbc.xa.client.OracleXADataSource</xa-datasource-class>
	<xa-datasource-property name="URL">jdbc:oracle:thin:@xxxx:xxx:333</xa-datasource-property>
    <xa-datasource-property name="User">33</xa-datasource-property>
    <xa-datasource-property name="Password">22</xa-datasource-property>

    <min-pool-size>5</min-pool-size>
    <max-pool-size>20</max-pool-size>

    <!-- corresponding type-mapping in the standardjbosscmp-jdbc.xml (optional) -->
    <metadata>
    	<type-mapping>Oracle10g</type-mapping>
    </metadata>
  </xa-datasource>

 


       5) 这几个过程是如何调用的,BURLESON大叔给你指点下!

相关文章
相关标签/搜索