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

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

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

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

2)找到<Oracle 安装目录>\javavm\install 目录下,有两个脚本initxa.sql 和  initjvm.sql,将它们所在的完整路径分别复制到已登录的SQLPLUS环境下(注:在windows下目录分隔符应由"\"改为"/")执行该脚本。格式如:@d :/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配置 ,到对应的数据源配置文件中

  •   如:

  <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大叔给你指点下!



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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
首先,您需要将Oracle JDBC驱动程序添加JBoss 7。您可以按照以下步骤操作: 1. 下载适用于您的Oracle版本的JDBC驱动程序(通常是一个.jar文件)。 2. 将驱动程序文件复制到JBoss 7的“modules”目录。例如,如果您使用的是Oracle 12c,您可以将驱动程序文件复制到“modules/system/layers/base/com/oracle/jdbc/main”目录。 3. 在该目录创建一个新的“module.xml”文件,并将以下内容添加到该文件: ``` <?xml version="1.0" encoding="UTF-8"?> <module xmlns="urn:jboss:module:1.1" name="com.oracle.jdbc"> <resources> <resource-root path="ojdbc7.jar"/> <!--替换为您的驱动程序名称--> </resources> <dependencies> <module name="javax.api"/> <module name="javax.transaction.api"/> </dependencies> </module> ``` 4. 在JBoss 7的“standalone.xml”配置文件,找到以下部分: ``` <drivers> ... </drivers> ``` 5. 添加以下内容: ``` <driver name="oracle" module="com.oracle.jdbc"> <driver-class>oracle.jdbc.driver.OracleDriver</driver-class> <xa-datasource-class>oracle.jdbc.xa.client.OracleXADataSource</xa-datasource-class> </driver> ``` 6. 现在,您可以在EJB 3.1使用JNDI来访问您的Oracle数据库。您可以在您的应用程序使用以下代码: ``` Context ctx = new InitialContext(); DataSource ds = (DataSource)ctx.lookup("java:jboss/datasources/MyOracleDS"); Connection conn = ds.getConnection(); ``` 其,“MyOracleDS”是您在“standalone.xml”定义的数据源的名称。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值