gpt4 book ai didi

java - Infinispan 搜索索引错误 : LockedObtainFailedException

转载 作者:太空宇宙 更新时间:2023-11-04 07:29:14 25 4
gpt4 key购买 nike

我是 Infinispan 的新手,目前正在尝试使用搜索功能。我尝试密切关注文档。首先我更新我的cache.xml:

<namedCache 
name="cache">
<transaction transactionMode="NON_TRANSACTIONAL"/>
<indexing enabled="true" indexLocalOnly="true"/>
</namedCache>

我正在尝试编写一个查询,该查询将为我提供 search_value 属性的结果列表。这是我的 Java 代码:

SearchManager searchManager = org.infinispan.query.Search.getSearchManager(cache);
Term t = new Term("attribute_name", search_value);
Query q = new TermQuery(t);
CacheQuery cacheQuery = searchManager.getQuery(q);
List<Object> found = cacheQuery.list();

但是,当我尝试运行测试时,我收到此错误:

org.apache.lucene.store.LockObtainFailedException: Lock obtain timed out: NativeFSLock@.\Key\write.lock
at org.apache.lucene.store.Lock.obtain(Lock.java:84)
at org.apache.lucene.index.IndexWriter.<init>(IndexWriter.java:1098)
at org.hibernate.search.backend.impl.lucene.IndexWriterHolder.createNewIndexWriter(IndexWriterHolder.java:148)
at org.hibernate.search.backend.impl.lucene.IndexWriterHolder.getIndexWriter(IndexWriterHolder.java:115)
at org.hibernate.search.backend.impl.lucene.AbstractWorkspaceImpl.getIndexWriter(AbstractWorkspaceImpl.java:117)
at org.hibernate.search.backend.impl.lucene.LuceneBackendQueueTask.applyUpdates(LuceneBackendQueueTask.java:101)
at org.hibernate.search.backend.impl.lucene.LuceneBackendQueueTask.run(LuceneBackendQueueTask.java:67)
at java.util.concurrent.Executors$RunnableAdapter.call(Unknown Source)
at java.util.concurrent.FutureTask$Sync.innerRun(Unknown Source)
at java.util.concurrent.FutureTask.run(Unknown Source)
at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(Unknown Source)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
at java.lang.Thread.run(Unknown Source)
13/08/02 14:08:25 ERROR lucene.LuceneBackendQueueTask: HSEARCH000072: Couldn't open the IndexWriter because of previous error: operation skipped, index ouf of sync!

什么原因导致写锁错误?我什至尝试仅使用索引配置删除 Java 部分,并且存在相同的错误。是我没有正确配置缓存吗?任何帮助是极大的赞赏!谢谢!

最佳答案

底层搜索引擎基于 Hibernate Search 和 Apache Lucene,使用锁来请求对索引的独占写访问权限。假设您没有第二个应用程序尝试在同一索引目录上写入,则该目录中可能有一个由于 JVM 被终止或硬件崩溃而遗留的锁定文件。

查找在文件系统上创建的目录,该目录与您正在使用的索引同名,并删除标记文件write.lock(如果您确定没有进程正在写入它)。

您还可以配置不同的锁定策略,但请确保您不会开枪: LockFactory configuration

如果这不是先前终止的 JVM 留下的锁,则可能是您正在运行多个 Infinispan 实例。确保它们将索引存储在单独的基本目录中(默认是您启动进程的当前路径)。

Directory configuration

关于java - Infinispan 搜索索引错误 : LockedObtainFailedException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18023669/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com