【问题标题】:Unable to access datasource remotely through JBoss无法通过 JBoss 远程访问数据源
【发布时间】:2012-01-26 00:09:57
【问题描述】:

上下文

我有一个 JBoss,我已经成功部署了一个数据源 mydatasource-ds.xml。 它的 JNDI 名称是 java:mydatasourceDS。 JBoss 声称数据源已成功部署。 JMX 控制台也是如此。

问题

我想从在单独的 JVM 上启动的客户端 java 应用程序中使用此数据源。 但我收到一个异常,说找不到 java:mydatasourceDS

java.lang.ClassCastException: javax.naming.Reference cannot be cast to javax.sql.DataSource

详情

这是persistence.xml 文件:

<?xml version="1.0" encoding="UTF-8"?>
<persistence version="1.0"
xmlns="http://java.sun.com/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_1_0.xsd">
<persistence-unit name="mydatasource-db" transaction-type="JTA">
    <jta-data-source>java:mydatasourceDS</jta-data-source>
    <properties>
        <property name="hibernate.show_sql" value="true" />
        <property name="hibernate.format_sql" value="true" />

        <property name="hibernate.dialect" value="org.hibernate.dialect.PostgreSQLDialect" />
        <property name="hibernate.hbm2ddl.auto" value="update" />
        <property name="hibernate.default_schema" value="rec" />

        <property name="hibernate.transaction.manager_lookup_class" value="org.hibernate.transaction.JBossTransactionManagerLookup"/>
    </properties>
</persistence-unit>

这是jndi.properties 文件:

java.naming.factory.initial=org.jnp.interfaces.NamingContextFactory
java.naming.provider.url=jnp://localhost:1099
java.naming.factory.url.pkgs=org.jboss.naming:org.jnp.interfaces

这是应用程序类路径:

jndi.properties
log4j.properties
META-INF\persistence.xml
hibernate-jpa-2.0-api-1.0.0.Final.jar
jnp-client-5.0.3.GA.jar
jboss-common-core-2.2.14.GA.jar
jboss-logging-spi-2.1.0.GA.jar
hibernate-entitymanager-3.6.4.Final.jar
hibernate-core-3.6.4.Final.jar
antlr-2.7.6.jar
commons-collections-3.1.jar
dom4j-1.6.1.jar
hibernate-commons-annotations-3.2.0.Final.jar
jta-1.1.jar
javassist-3.12.0.GA.jar
slf4j-api-1.6.1.jar
slf4j-log4j12-1.6.1.jar
log4j-1.2.16.jar
xstream-1.4.1.jar
xmlpull-1.1.3.1.jar
xpp3_min-1.1.4c.jar

编辑 我找到了问题的根源。我的客户端应用程序可用的javax.sql.DataSource 不是从JNDI 收到的。我从 JNDI 收到的是 JBoss javax.sql.DataSource。同名但类略有不同,因此 ClassCastException...

在撰写本文时,JBoss javax.sql.DataSource 可以在这个包中找到:jboss-j2ee-4.2.3.GA.jar

【问题讨论】:

  • 很高兴知道你解决了:D
  • 不是真的。我找到了根本原因,但我无法解决它。如何从 JDK 中删除 javax.sql.DataSource 以支持 JBoss 中的 javax.sql.DataSource ?我可以从类路径中删除 rt.jar 但我需要 java.lang.String :-o

标签: java jboss datasource jndi


【解决方案1】:

如果你得到一个

javax.naming.Reference 

这意味着您缺少解决它所需的运行时依赖项。您可以通过

检查 Reference 对象的 classFactory 成员
getFactoryClassName() 

找出您缺少的第一个依赖项。

在我使用 JBoss6.1 的情况下是:

org.jboss.resource.adapter.jdbc.remote.DataSourceFactory

将这个类所在的 jar 放入类路径 (common/lib/jbosscx-client.jar) 让我通过了第一步,然后就是跟踪所有 ClassNotFoundException 错误。

JBoss6.1 的完整列表原来是:

- client/jnp-client.jar
- client/jboss-logging.jar
- common/lib/jbosscx-client.jar
- client/concurrent.jar
- client/jboss-client.jar
- client/jboss-common-core.jar
- client/jboss-integration.jar
- client/jboss-remoting.jar
- client/jboss-security-spi.jar
- client/jboss-serialization.jar
- client/jboss-transaction-api_1.1_spec.jar

【讨论】:

    【解决方案2】:

    This guide 说你要设置

    <use-java-context>false</use-java-context>
    

    mydatasource-ds.xml。不知道你有没有。

    【讨论】:

    • 感谢您的建议。在指南中的一个 cmets 中,一个说当连接池已满时,无法建立更多连接。我们如何解决这个问题?
    • 您必须确保您的应用程序在池中有足够的连接。有多少取决于您的环境。如果池已满,池管理器将等待一段时间,直到重试。确保在使用后关闭每个连接。您还可以定义仅由客户端使用的第二个数据源。
    • 我现在可以检索 DataSource 但我有一个 CCE :\ java.lang.ClassCastException: javax.naming.Reference cannot be cast to javax.sql.DataSource
    • 我已阅读此资源。我将 postgresql jar 放在类路径中,但没有运气。我也找到了这个:mastertheboss.com/jboss-howto/42-jboss-config/…。也没有运气。
    • 您确定在您的类路径中有一个包含 DataSource 实现/接口的 jar 文件吗?看来光靠司机是不够的。
    猜你喜欢
    • 2019-07-12
    • 1970-01-01
    • 1970-01-01
    • 2015-06-25
    • 1970-01-01
    • 2011-11-30
    • 1970-01-01
    • 2014-05-30
    • 1970-01-01
    相关资源
    最近更新 更多