4

最终有人可以帮助我。目前,当使用 postgres 驱动程序启动wildfly 10 Final但使用相同的设置Wildfly 10 CR4将启动时,我遇到了一个非常奇怪的问题。

我得到的例外如下:

Caused by: javax.resource.ResourceException: IJ031089: Failed to load datasource: org.postgresql.Driver
    at org.jboss.jca.adapters.jdbc.local.LocalManagedConnectionFactory.getDataSource(LocalManagedConnectionFactory.java:650)
    at org.jboss.jca.adapters.jdbc.local.LocalManagedConnectionFactory.createLocalManagedConnection(LocalManagedConnectionFactory.java:311)
    ... 6 more
Caused by: java.lang.ClassCastException: org.postgresql.Driver cannot be cast to javax.sql.DataSource
    at org.jboss.jca.adapters.jdbc.local.LocalManagedConnectionFactory.getDataSource(LocalManagedConnectionFactory.java:633)
    ... 7 more

奇怪的是,它适用于 Wildfly 10 CR4,但不适用于最终版本的 Wildfly 10 Final。任何的想法?对我来说,这看起来像是一个类加载器问题,但我不是 Wildfly 的专家来追踪它。

我的模块/org/postgres/main/module.xml

<?xml version="1.0" encoding="UTF-8"?>
<module xmlns="urn:jboss:module:1.1" name="org.postgres">
  <resources>
    <resource-root path="postgresql-9.4.1208.jar"/>
  </resources>
  <dependencies>
    <module name="javax.api"/>
    <module name="javax.transaction.api"/>
    <module name="javax.servlet.api" optional="true"/>
  </dependencies>
</module>

我在standalone.xml中的驱动程序定义

<driver name="postgres" module="org.postgres">
    <xa-datasource-class>org.postgresql.xa.PGXADataSource</xa-datasource-class>
    <datasource-class>org.postgresql.Driver</datasource-class>
</driver>

Java JDK为:jdk1.8.0_73

非常感谢任何帮助解决我的问题。

提前谢谢

/大卫

4

1 回答 1

17

实现 DataSource 的类名是:

org.postgresql.ds.PGSimpleDataSource

或者

org.postgresql.ds.PGPoolingDataSource

https://jdbc.postgresql.org/documentation/head/ds-ds.html

我假设 Wildfly 将管理连接,所以你可能不需要池数据源,只需要简单的:所以它应该是

<driver name="postgres" module="org.postgres">
    <xa-datasource-class>org.postgresql.xa.PGXADataSource</xa-datasource-class>
    <datasource-class>org.postgresql.ds.PGSimpleDataSource</datasource-class>
</driver>
于 2016-03-26T08:31:59.267 回答