我有一个war应用程序,其中包含使用Spring容器打包和引导的JPA 2.1 API和Hibernate 4.3.0.Final(JPA 2.1实现),我想在JBoss EAP 6.1中部署它。
我知道JBoss EAP 6.1符合JPA 2.0所以我决定强迫JBoss在我的应用程序中使用JPA版本和实现
我尝试做的是使用jboss-deployment-structure.xml排除JPA子系统,但我发现即使我从standalone.xml注释掉JPA扩展和JPA子系统并将JPA子系统排除在jboss中-deployment-structure.xml(也排除org.hibernate模块使用应用程序中打包的hibernate),没有运行JPA扫描程序(按预期)但是任何战争类的时刻(在我的情况下) Spring容器)指的是javax.persistence类,API从JBoss模块加载(modules / system / layers / base / javax / persistence / api / main / hibernate-jpa-2.0-1.0.1.Final-redhat-2 .jar!)提供战争中提供的API jar的INSTEAD。所以很明显我得到了JBoss提供的API(2.0)及其不匹配的例外 在战争申请中实施(2.1)。 一个例外是例如注释javax.persistence.Table的索引相关属性无法识别,因为这是JPA 2.1中的一个附加项,在JPA 2.0中不可用
我可以通过将模块目录中的JPA 2.0 API替换为JPA 2.1(并将module.xml指向新的2.1 API jar)来解决这个问题,一切正常。但是我认为这不是正确的方法,因为这就像尝试更改所有应用程序的服务器行为一样。
这是有意的JBoss类加载行为,所有规范API类(JBoss是实现者)总是优先考虑所使用的实现,无论我们告诉它使用应用程序内的特定API。我认为制作特定规格的服务器然后提供 覆盖规范版本本身的方式有些矛盾,但有没有办法可以在我的应用程序中干净地使用API和实现?
另一个选择是转移到Wildfly,这是JPA 2.1实现,但我的问题是JBoss EAP 6.1中是否可以完全实现这一点?
答案 0 :(得分:5)
我们找到了另一种解决方案 您还可以在war的jboss-deployment-structure.xml中排除jpa子系统:
<exclude-subsystems>
<subsystem name="jpa" />
</exclude-subsystems>
<exclusions>
<module name="javaee.api" />
</exclusions>
答案 1 :(得分:4)
如果你是Maven,这对我有用。
<dependency>
<groupId>javax</groupId>
<artifactId>javaee-api</artifactId>
<version>7.0</version>
</dependency>
的JBoss部署-structure.xml
<deployment>
<exclude-subsystems>
<subsystem name="jpa" />
</exclude-subsystems>
<exclusions>
<module name="javaee.api" />
</exclusions>
</deployment>
答案 2 :(得分:3)
找到一个似乎适用于hibernate-core-4.3.1的解决方案。
步骤1:从standalone.xml中删除子系统jpa:
<subsystem xmlns="urn:jboss:domain:jpa:1.1">
<jpa default-datasource="" default-extended-persistence-inheritance="DEEP"/>
</subsystem>
感谢这篇博客文章: http://mariemjabloun.blogspot.nl/2014/02/jboss-eap-6-persistence-unit-problem.html
步骤2:在战争的jboss-deployment-structure.xml中排除jpa,javaee模块:
<exclusions>
<module name="javax.persistence.api"/>
<module name="javaee.api"/>
</exclusions>
答案 3 :(得分:3)
上述答案很棒,但它们通过排除整个Java EE API在许多应用程序中引入了其他问题。
如果您不想这样做,请转到JBOSS_HOME\modules\javaee\api\main\module.xml
并将javax.persistence.api
的导出设置为false,如下所示:
<module name="javax.persistence.api" export="false"/>
请注意,这将禁用部署在同一EAP中的每个应用程序的持久性API。
您仍然需要从standalone.xml
删除JPA子系统,但您不需要更改jboss-deployment-structure.xml
,或者至少我没有必要。