保险丝6.3 dbcp基本数据源

时间:2017-06-13 18:30:29

标签: oracle datasource jbossfuse

我无法让dbcp2在JBoss fuse 6.3中运行。 下面给出的代码在Fuse容器中工作正常。

<bean id="oracleDSTest" class="oracle.jdbc.pool.OracleDataSource"
        destroy-method="close">
        <property name="driverClassName" value="oracle.jdbc.driver.OracleDriver" />
        <property name="url" value="jdbc:oracle:thin:@127.0.0.1:1521:XE" />
        <property name="username" value="hr" />
        <property name="password" value="hr" />
        <property name="maxIdle" value="5" />
        <property name="minIdle" value="1" />
        <property name="initialSize" value="1" />
    </bean>

    <service interface="javax.sql.DataSource" ref="oracleDSTest">
        <service-properties>
            <entry key="osgi.jndi.service.name" value="jdbc/oracleDSTest" />
            <entry key="datasource.name" value="oracleDSTest" />
        </service-properties>
    </service>

但如果我使用org.apache.commons.dbcp.BasicDataSource代替oracle.jdbc.pool.OracleDataSource,则会因以下错误而失败:

  

执行命令时出错:oracle.jdbc.driver.T4CConnection.isValid(I)Z

出现此错误的原因是什么?

1 个答案:

答案 0 :(得分:2)

我正在使用ojdbc6-11.2.0.3.jar并且驱动程序在两种配置中都有效。

我使用JBoss Fuse Console的查询进行了测试

jdbc:query jdbc/oracle 'select * from somewhere.sometable WHERE rownum < 5'

检查是否已安装JDBC和JNDI

features:install jdbc
features:install jndi

您可以将包含以下内容的XML文件放入deploy/,以自动部署数据源。

OracleDataSource

<?xml version="1.0" encoding="UTF-8"?>
<blueprint xmlns="http://www.osgi.org/xmlns/blueprint/v1.0.0">

    <bean id="oracleDSTest" class="oracle.jdbc.pool.OracleDataSource"
          destroy-method="close">
        <property name="URL" value="jdbc:oracle:thin:@db.host:1521:SID" />
        <property name="user" value="UrName" />
        <property name="password" value="YourPasswrd" />
    </bean>

    <service interface="javax.sql.DataSource" ref="oracleDSTest">
        <service-properties>
            <entry key="osgi.jndi.service.name" value="jdbc/oracle" />
            <entry key="datasource.name" value="oracleDSTest" />
        </service-properties>
    </service>
</blueprint>

的BasicDataSource

<bean id="oracleDSTest" class="org.apache.commons.dbcp.BasicDataSource">
    <property name="driverClassName" value="oracle.jdbc.driver.OracleDriver" />
    <property name="url" value="jdbc:oracle:thin:@db.host:1521:SID"/>
    <property name="username" value="UrName"/>
    <property name="password" value="YourPasswrd"/>
    <property name="maxIdle" value="5" />
    <property name="minIdle" value="1" />
    <property name="initialSize" value="1" />
</bean>

<service interface="javax.sql.DataSource" ref="oracleDSTest">
    <service-properties>
        <entry key="osgi.jndi.service.name" value="jdbc/oracle" />
        <entry key="datasource.name" value="oracleDSTest" />
    </service-properties>
</service>

类加载

请注意,此版本的Oracle JDBC驱动程序 OSGi就绪。 要使所有内容在OSGi下工作,您可能希望从中导出Oracle类 系统包。
ojdbc6-11.2.0.3.jar(或您的版本)复制到JBoss Fuse的lib/文件夹 修改etc/config.properties并将包添加到org.osgi.framework.system.packages属性

org.osgi.framework.system.packages= \
  other.packages.here, \
  oracle.jdbc;version="11.2.0.3", \
  oracle.jdbc.driver;version="11.2.0.3", \
  oracle.jdbc.pool;version="11.2.0.3", \
  some.other.stuff

重新启动并查看exports | grep oracle

JBossFuse:karaf@root> exports | grep oracle
     0 oracle.jdbc; version=11.2.0.3
     0 oracle.jdbc.driver; version=11.2.0.3
     0 oracle.jdbc.pool; version=11.2.0.3