Wildfly Postgres JDBC模块问题

时间:2017-01-30 08:57:25

标签: postgresql maven jdbc scope wildfly-10

我在Wildfly 10中配置了作为模块的postgres jdbc驱动程序。我想要做的是将该驱动程序用作将部署在服务器上的应用程序中的依赖项 - 所以在应用程序中,我将此依赖项标记为已提供(在pom.xml文件中)但它似乎无法正常工作。

当前配置:

Wildfly postgres模块已添加到wildfly-10.1.0.Final\modules\org\postgresql\main,其中包含以下内容:postgresql-9.4-1206-jdbc4.jarmodule.xml

<module xmlns="urn:jboss:module:1.1" name="org.postgresql"> 
  <resources> 
    <resource-root path="postgresql-9.4-1206-jdbc4.jar"/> 
  </resources> 
   <dependencies> 
     <module name="javax.api"/> 
     <module name="javax.transaction.api"/> 
   </dependencies> 
</module> 

模块用于定义数据源。到目前为止,一切运行良好 - 使用hibernate帮助表可以很好地映射到实体。除了一件事:

我开始使用javax.persistence.AttributeConverter映射postgres-jsonb列并发生以下情况:

情景1

当我使用postgresql-9.4-1206-jdbc4.jar作为provided(在pom.xml - 已部署的应用程序中)时,我在尝试转换任何内容时出现以下错误:

Caused by: java.lang.ClassNotFoundException: org.postgresql.util.PGobject from [Module "deployment.priject-1.0.1.ear.project.data-1.0.1-SNAPSHOT.jar:main" from Service Module Loader]
    at org.jboss.modules.ModuleClassLoader.findClass(ModuleClassLoader.java:198)
    at org.jboss.modules.ConcurrentClassLoader.performLoadClassUnchecked(ConcurrentClassLoader.java:363)
    at org.jboss.modules.ConcurrentClassLoader.performLoadClass(ConcurrentClassLoader.java:351)
    at org.jboss.modules.ConcurrentClassLoader.loadClass(ConcurrentClassLoader.java:93)
    ... 269 more

情景2

当我使用postgresql-9.4-1206-jdbc4.jar默认范围时,会出现以下错误:

Caused by: java.lang.ClassCastException: org.postgresql.util.PGobject cannot be cast to org.postgresql.util.PGobject
    at com.project.entity.util.converters.JSONBTypeConverter.convertToEntityAttribute(JSONBTypeConverter.java:33)
    at com.project.entity.util.converters.JSONBTypeConverter.convertToEntityAttribute(JSONBTypeConverter.java:1)
    at org.hibernate.type.descriptor.converter.AttributeConverterSqlTypeDescriptorAdapter$2.doConversion(AttributeConverterSqlTypeDescriptorAdapter.java:140)
    ... 266 more

这意味着:类加载器加载同一个jar两次,并且不能将此对象强制转换为自身。

问题:为什么provided依赖的范围不适用于手动添加(对于wildfly)postgres驱动程序? (我想这对我来说就是解决方案)

1 个答案:

答案 0 :(得分:2)

您需要使用jboss-deployment-structure.xml将模块依赖项添加到部署中。

<jboss-deployment-structure>
    <deployment>
        <dependencies>
            <module name="org.postgresql" />
        </dependencies>
    </deployment>
    <sub-deployment name="project.data-1.0.1-SNAPSHOT.jar">
        <dependencies>
            <module name="org.postgresql" />
        </dependencies>
    </sub-deployment>
</jboss-deployment-structure>

请注意,可能不需要模块对EAR的依赖性。这取决于您的EAR设置方式。

另一种选择是添加Dependencies manifest entry。由于您正在使用Maven,因此您可以使用maven-jar-plugin(因为它看起来这是EAR中的JAR)来创建条目。

<plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-jar-plugin</artifactId>
    <configuration>
        <archive>
            <manifestEntries>
                <Dependencies>org.postgresql</Dependencies>
            </manifestEntries>
        </archive>
    </configuration>
</plugin>