使用Infinispan和Wildfly配置Hibernate搜索

问题描述 投票:8回答:1

我正在配置Hibernate Search 5.5.5在Wildfly 10上使用Infinispan 8.2.2。我在Wildfly中只配置了Infinispan模块,而不是Hibernate Search模块。

在persistence.xml里面我把这个配置:

<property name="hibernate.search.infinispan.cachemanager_jndiname" value="java:jboss/infinispan/container/hibernateSearch" />
<property name="wildfly.jpa.hibernate.search.module" value="none" />

这是因为似乎使用了Infinispan,但不会持久保存索引。

所有缓存都在domain.xml中配置如下:

<cache-container name="hibernateSearch" default-cache="LuceneIndexesData" jndi-name="java:jboss/infinispan/hibernateSearch" statistics-enabled="false">
      <replicated-cache name="LuceneIndexesMetadata" mode="ASYNC">
          <file-store fetch-state="false" passivation="false" preload="false" purge="false" shared="false" singleton="false"/>
      </replicated-cache>
      <replicated-cache name="LuceneIndexesLocking" mode="SYNC">
           <file-store fetch-state="false" passivation="false" preload="false" purge="false" shared="false" singleton="false"/>
      </replicated-cache>
      <replicated-cache name="LuceneIndexesData" mode="ASYNC">
           <file-store fetch-state="false" passivation="false" preload="false" purge="false" shared="false" singleton="false"/>
      </replicated-cache>
 </cache-container>

在jboss-deployment-structure.xml中:

<module name="org.infinispan" slot="ispn-8.2"/>
<module name="org.hibernate.search.orm" services="export" />

当我尝试索引所有我收到此错误:

UNHANDLED_EXCEPTION: java.lang.IllegalArgumentException: java.lang.Object is not an indexed entity or a subclass of an indexed entity

但如果我删除此行:

<property name="wildfly.jpa.hibernate.search.module" value="none" />

我有

org.hibernate.search.exception.SearchException: Wrong configuration of directory provider: class org.infinispan.hibernate.search.spi.InfinispanDirectoryProvider does not implement interface org.hibernate.search.store.DirectoryProvider

问题似乎与此处描述的相同:

https://developer.jboss.org/thread/271789

但我找不到任何有效的解决方案,而且我确信我的classpath中没有一个或多个Infinispan或Hibernate版本。

怎么了? :(

java hibernate wildfly hibernate-search infinispan
1个回答
2
投票

TLDR;你的类路径中有2个Infinispan版本:一个在你的jboss-deployment-structure.xml,另一个在org.jboss.as.clustering子系统中。

Custom Hibernate Search

<property name="wildfly.jpa.hibernate.search.module" value="none" />只是意味着不会自动使用AND导出应用服务器“搜索”模块为我的应用程序。

因此,<module name="org.hibernate.search.orm" services="export" />是多余的,只要您为wildfly.jpa.hibernate.search.module而不是none输入正确的模块ID,或者只是删除属性以使用默认搜索模块,它将自动完成。

当您不想使用默认或自定义搜索模块但将其捆绑在您的应用程序中时,none选项适用于这种情况。

更多细节WildFly 10 Docs - Using Hibernate Search

Custom WildFly Infinispan subsystem

<module name="org.infinispan" slot="ispn-8.2"/>不会升级WildFly Infinispan子系统。它只允许您的应用程序直接使用Infinispan作为库。正确的方法是:

  • 简单:升级到Wildfly 10.1(默认情况下附带Infinispan 8.2和Hibernate Search 5.5)
  • 硬:升级或修改org.jboss.as.clustering.infinispan模块以使用自定义Infinispan版本
  • 荒谬:转储随WildFly提供的缓存基础结构,并在应用程序中使用您自己的捆绑和配置
© www.soinside.com 2019 - 2024. All rights reserved.