最终有人可以帮助我。目前,使用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追踪它的专家。
我的 modules / 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
非常感谢您解决问题的任何帮助。
提前谢谢
/大卫
答案 0 :(得分:13)
实现DataSource的类名是:
org.postgresql.ds.PGSimpleDataSource
或
org.postgresql.ds.PGPoolingDataSource
https://jdbc.postgresql.org/documentation/head/ds-ds.html
我假设Wildfly将管理连接,因此您可能不需要池化DataSource,只需要简单: 所以它应该是
<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>