spring - Hibernate Search..访问一个没有被密封的密封工作队列

标签 spring hibernate search websphere hibernate-search

我正在尝试将 Hibernate Search 用于一个新项目。我们有没有 JPA 的 Hibernate 和 Spring。当 Hibernate Search 尝试通过事件监听器更新索引文件时,我收到以下异常。我已经阅读了有关此问题的内容,但似乎对我没有任何作用。我真的很感激任何帮助。

环境:
Spring 3.0.5
hibernate 3.5.4
hibernate 搜索 3.2.1

异常(exception):

TransactionSy E org.springframework.transaction.support.TransactionSynchronizationUtils invokeAfterCompletion TransactionSynchronization.afterCompletion threw exception
                                 org.hibernate.AssertionFailure: Exception releasing cache locks
 at org.hibernate.engine.ActionQueue$AfterTransactionCompletionProcessQueue.afterTransactionCompletion(ActionQueue.java:584)
 at org.hibernate.engine.ActionQueue.afterTransactionCompletion(ActionQueue.java:204)
 at org.hibernate.impl.SessionImpl.afterTransactionCompletion(SessionImpl.java:594)
 at org.springframework.orm.hibernate3.SpringSessionSynchronization.afterCompletion(SpringSessionSynchronization.java:229)
 at org.springframework.transaction.support.TransactionSynchronizationUtils.invokeAfterCompletion(TransactionSynchronizationUtils.java:168)
 at org.springframework.transaction.jta.JtaAfterCompletionSynchronization.afterCompletion(JtaAfterCompletionSynchronization.java:62)
 at com.ibm.ws.uow.ComponentContextSynchronizationWrapper.afterCompletion(ComponentContextSynchronizationWrapper.java:83)
 at com.ibm.tx.jta.RegisteredSyncs.coreDistributeAfter(RegisteredSyncs.java:357)
 at com.ibm.ws.tx.jta.RegisteredSyncs.distributeAfter(RegisteredSyncs.java:317)
 at com.ibm.tx.jta.TransactionImpl.distributeAfter(TransactionImpl.java:2933)
 at com.ibm.tx.jta.TransactionImpl.postCompletion(TransactionImpl.java:2892)
 at com.ibm.tx.jta.TransactionImpl.postCompletion(TransactionImpl.java:2805)
 at com.ibm.tx.jta.TransactionImpl.commitXAResources(TransactionImpl.java:1775)
 at com.ibm.ws.tx.jta.TransactionImpl.stage1CommitProcessing(TransactionImpl.java:497)
 at com.ibm.tx.jta.TransactionImpl.processCommit(TransactionImpl.java:978)
 at com.ibm.tx.jta.TransactionImpl.commit(TransactionImpl.java:913)
 at com.ibm.ws.tx.jta.TranManagerImpl.commit(TranManagerImpl.java:369)
 at com.ibm.tx.jta.TranManagerSet.commit(TranManagerSet.java:161)
 at com.ibm.ws.uow.UOWManagerImpl.uowCommit(UOWManagerImpl.java:1172)
 at com.ibm.ws.uow.UOWManagerImpl.uowEnd(UOWManagerImpl.java:1142)
 at com.ibm.ws.uow.UOWManagerImpl.runUnderNewUOW(UOWManagerImpl.java:1092)
 at com.ibm.ws.uow.UOWManagerImpl.runUnderUOW(UOWManagerImpl.java:626)
 at org.springframework.transaction.jta.WebSphereUowTransactionManager.execute(WebSphereUowTransactionManager.java:281)
 at org.springframework.transaction.interceptor.TransactionInterceptor.invoke(TransactionInterceptor.java:127)
 at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:172)
 at org.springframework.aop.framework.Cglib2AopProxy$DynamicAdvisedInterceptor.intercept(Cglib2AopProxy.java:621)
 at com.test.service.inventory.InventoryServiceImpl$$EnhancerByCGLIB$$847cc0d8.updateInventoy(<generated>)
 at com.test.web.servlet.SearchServlet.doPost(SearchServlet.java:51)
 at com.test.web.servlet.SearchServlet.doGet(SearchServlet.java:75)
 at javax.servlet.http.HttpServlet.service(HttpServlet.java:718)
 at javax.servlet.http.HttpServlet.service(HttpServlet.java:831)
 at com.ibm.ws.webcontainer.servlet.ServletWrapper.service(ServletWrapper.java:1449)
 at com.ibm.ws.webcontainer.servlet.ServletWrapper.handleRequest(ServletWrapper.java:790)
 at com.ibm.ws.webcontainer.servlet.ServletWrapper.handleRequest(ServletWrapper.java:443)
 at com.ibm.ws.webcontainer.servlet.ServletWrapperImpl.handleRequest(ServletWrapperImpl.java:175)
 at com.ibm.ws.webcontainer.servlet.CacheServletWrapper.handleRequest(CacheServletWrapper.java:91)
 at com.ibm.ws.webcontainer.WebContainer.handleRequest(WebContainer.java:859)
 at com.ibm.ws.webcontainer.WSWebContainer.handleRequest(WSWebContainer.java:1557)
 at com.ibm.ws.webcontainer.channel.WCChannelLink.ready(WCChannelLink.java:173)
 at com.ibm.ws.http.channel.inbound.impl.HttpInboundLink.handleDiscrimination(HttpInboundLink.java:455)
 at com.ibm.ws.http.channel.inbound.impl.HttpInboundLink.handleNewInformation(HttpInboundLink.java:384)
 at com.ibm.ws.http.channel.inbound.impl.HttpInboundLink.ready(HttpInboundLink.java:272)
 at com.ibm.ws.tcp.channel.impl.NewConnectionInitialReadCallback.sendToDiscriminators(NewConnectionInitialReadCallback.java:214)
 at com.ibm.ws.tcp.channel.impl.NewConnectionInitialReadCallback.complete(NewConnectionInitialReadCallback.java:113)
 at com.ibm.ws.tcp.channel.impl.AioReadCompletionListener.futureCompleted(AioReadCompletionListener.java:165)
 at com.ibm.io.async.AbstractAsyncFuture.invokeCallback(AbstractAsyncFuture.java:217)
 at com.ibm.io.async.AsyncChannelFuture.fireCompletionActions(AsyncChannelFuture.java:161)
 at com.ibm.io.async.AsyncFuture.completed(AsyncFuture.java:138)
 at com.ibm.io.async.ResultHandler.complete(ResultHandler.java:202)
 at com.ibm.io.async.ResultHandler.runEventProcessingLoop(ResultHandler.java:766)
 at com.ibm.io.async.ResultHandler$2.run(ResultHandler.java:896)
 at com.ibm.ws.util.ThreadPool$Worker.run(ThreadPool.java:1527)
Caused by: org.hibernate.HibernateException: Error while indexing in Hibernate Search (ater transaction completion)
 at org.hibernate.search.backend.impl.EventSourceTransactionContext$DelegateToSynchronizationOnAfterTx.doAfterTransactionCompletion(EventSourceTransactionContext.java:179)
 at org.hibernate.engine.ActionQueue$AfterTransactionCompletionProcessQueue.afterTransactionCompletion(ActionQueue.java:577)
 ... 51 more
Caused by: org.hibernate.annotations.common.AssertionFailure: Access a Sealed WorkQueue which has not been sealed
 at org.hibernate.search.backend.WorkQueue.getSealedQueue(WorkQueue.java:87)
 at org.hibernate.search.backend.impl.BatchedQueueingProcessor.performWorks(BatchedQueueingProcessor.java:280)
 at org.hibernate.search.backend.impl.PostTransactionWorkQueueSynchronization.afterCompletion(PostTransactionWorkQueueSynchronization.java:96)
 at org.hibernate.search.backend.impl.EventSourceTransactionContext$DelegateToSynchronizationOnAfterTx.doAfterTransactionCompletion(EventSourceTransactionContext.java:176)
 ... 52 more

我知道有一个类似问题 [#HSEARCH-540] 的修复程序,但这似乎对我不起作用。

这是我的 Spring 上下文:
<bean id="sessionFactory"
    class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">
    <property name="dataSource" ref="dataSource" />
    <property name="packagesToScan" value="com.test.entity.inventory" />
    <property name="hibernateProperties">
        <props>
            <prop key="hibernate.dialect">org.hibernate.dialect.Oracle10gDialect</prop>
            <prop key="hibernate.show_sql">true</prop>
            <prop key="hibernate.format_sql">true</prop>
            <prop key="hibernate.jdbc.batch_size">40</prop>
            <!-- Hibernate Search properties -->
            <prop key="hibernate.search.default.indexBase">/POC/index</prop>
            <prop key="hibernate.search.default.directory_provider">org.hibernate.search.store.FSDirectoryProvider</prop>

        </props>
    </property>
</bean>

<bean id="transactionManager"
    class="org.springframework.transaction.jta.WebSphereUowTransactionManager" />

<tx:annotation-driven />

<bean id="inventoryDao"
    class="com.test.dao.inventory.InventoryDao">
    <property name="sessionFactory" ref="sessionFactory" />
</bean>

这是我的inventoryDao 方法,它抛出异常。
       @Transactional
       public Inventory updateInventoy(long id) {
  Inventory inv = null;
                Session session = sessionFactory.getCurrentSession();
  inv = (Inventory) session.load(Inventory.class, id);
  inv.setPrice(100000);
  inv.setModel("Testing123");

      return inv;
}

数据库更新得很好但是我的索引没有更新。

请帮忙。提前致谢..

最佳答案

要保持索引与数据库同步,您必须将 Hibernate session 包装在全文 session 中,如下所示:

FullTextSession session = Search.getFullTextSession(sessionFactory.getCurrentSession());

然后使用全文 session 代替包装 session 。

关于spring - Hibernate Search..访问一个没有被密封的密封工作队列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4339125/

相关文章:

java - JPA Hibernate 意外获取 @OneToOne 映射实体的记录,我应该将映射更改为 @ManyToOne 还是执行其他操作?

java - 将多对多关系保存在相应的映射表中

java - 使用 O(n) 时间复杂度搜索对给定方法返回 true 的二维数组

java - 从 Jar 文件中使用 Thymeleaf 模板

java - Spring - 将服务 Autowiring 到 POJO

spring - 如何在 HibernateJpaAutoConfiguration 中指定 packagesToScan?

javascript - 为什么 Array.indexOf 找不到相同的对象

php - 为较大的句子分配标签?

java - 为什么 Spring 不将我的 @Autowired 成员连接到依赖的 jar 中?

java - 我可以在 Grails 中使用 @Async 注释吗