【问题标题】:Wildfly Postgres JDBC module issueWildfly Postgres JDBC 模块问题
【发布时间】:2017-06-15 09:04:45
【问题描述】:

我在 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 驱动程序? (我想这对我来说是解决方案)

【问题讨论】:

  • 您能否粘贴您的pom.xml 编辑您的答案?我和你一样被困住了,但是关于所选答案的第二个建议并没有解决我的问题。恐怕我做的和你做的略有不同。提前致谢

标签: postgresql maven jdbc scope wildfly-10


【解决方案1】:

您需要使用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>

【讨论】:

  • 感谢您的回答。第二个选项对我有用,但我不得不将此清单条目放入我的 ear-plugin 并将 export 添加到依赖项中,而不是 jar-plugin:org.postgresql export
  • 第一个解决方案适用于我的 webapp/WEB-INF/jboss-deployment-structure.xml 文件,不是必须声明项目名称的粉丝,如果版本或名称发生更改,则必须更改...
  • 如果你使用的是 maven,你可以使用资源插件来替换表达式值。
猜你喜欢
  • 2017-04-28
  • 1970-01-01
  • 2018-10-26
  • 1970-01-01
  • 1970-01-01
  • 2019-04-22
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多