- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我们有基于 Lucene 的本土搜索服务。我前段时间遇到的一个特殊问题是获取 IndexWriter
上待处理更改的数量。如果挂起的更改计数器为零,则无需提交索引,重新打开 IndexReader
、IndexSearcher
等。此外,我们还有一些链接到 IndexReader.commit() 调用的应用程序级逻辑,如果提交点没有实际更改,最好不要调用它。
我可以访问调用方法 IndexReader.updateDocument()
和 IndexReader.remove()
的所有位置,因此我只需编写自己的挂起计数器即可变化。但我很感兴趣 Lucene API 本身是否已经存在一个? API 检查没有为我提供有关该主题的足够信息。
最佳答案
您可以使用IndexWriter.numRAMDocs
来获取添加的文档数量,但我认为没有公共(public)API来获取当前缓冲删除的数量。
IndexWriter.ramSizeInBytes
在这里也可能有用。它告诉您当前正在使用多少 RAM,因此当您添加或删除文档时,该 RAM 会增加(但在发生刷新时会减少)。
请注意,IndexReader.isCurrent
仅当您从 IndexWriter
提交更改时才可用,即,如果您有挂起的更改但尚未提交(或关闭)写入器那么 IndexReader.isCurrent
仍将返回 true。
关于java - 获取 IndexWriter 上待处理更改的数量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5644877/
当文档根据 Java Web 应用程序中的内容上传到不同的索引时,我需要对文档进行索引,其中多个用户可以同时上传多个文档 我使用 Lucene 6.2.1 进行索引 为此我创建了一个无状态 EJB。它
我们有基于 Lucene 的本土搜索服务。我前段时间遇到的一个特殊问题是获取 IndexWriter 上待处理更改的数量。如果挂起的更改计数器为零,则无需提交索引,重新打开 IndexReader、I
我正在开发一个小型 lucene 项目,我必须在其中索引一堆文本文件。我想到目前为止我已经成功创建了索引。代码运行,我得到一堆名为 0_.* fdt/fdx/fnm 等的文件。 我想知道的是,我可以选
我刚刚将我们的 Lucene 实现从 3.1 移植到 4.9,如果没有 forceMerge(1) (曾经是优化的),我似乎仍然无法更新索引中的文档。据我了解,每当我更新文档时,旧文档都会被标记为已删
这是我的问题,我执行 add() 将文档添加到我的索引,然后我关闭它。效果很好! 现在我有一个新需求,每次我在我的数据库中保存一些东西时,我都需要更新我的索引。我无法再次创建 indexWriter,
我有一个程序运行了 2 天,为大约 1.6 亿个文本文件建立了一个 Lucene 索引,程序结束后,我尝试搜索索引,发现索引没有正确建立,indexReader.numDocs() 返回 0 .我检查
我写了一个小循环,将 10,000 个文档添加到 IndexWriter 中,这花了很长时间。 还有其他方法可以索引大量文档吗? 我问是因为当它上线时它必须加载 15,000 条记录。 另一个问题是如
我的索引有以下字段:ID(长整型、已索引、已存储、未分析)、内容(字符串、未索引、未分析、已存储)和标签(字符串、已索引、已分析、已存储)。 需要更新给定 ID 的内容 - 如何使用 IndexW
我在一个目录中有两个大文件(约 200 MB),想在它们上建立索引,所以这是我的代码: public class LuceneUtil { private void indexDoc(In
我想了解 Solr3.5.0 中 IndexWriter 类中的一个函数。任何人都可以让我知道 forceMerge() 函数到底做了什么。它是否优化了分割? 谢谢, 杰亚普拉卡什 最佳答案 是的,f
我正在编写一个使用 Lucene 索引的应用程序,用户必须在其中使用 经常更新或删除索引的文档。 我知道如果有人想从 Lucene 索引中永久删除标记为删除的文档,那么他有两个选择: Indexwri
我正在使用 lucene 6.3.0 创建索引器。它从一个文件夹读取集合并创建另一个文件夹的索引。这工作正常,但我想进行多线程处理,我的意思是,给定 2 个集合(c1 和 c2),运行 2 个线程,每
我正在使用 Crawler Controller 来抓取中型网站的所有页面。它随机抓取 2-3 个页面,然后导致 IndexWriter 上的锁定 Directory dir = FSDirector
我正在使用 lucene.net 在 vs 代码中构建一个 .net 核心 mvc 应用程序,每当我尝试运行这段代码时,它都会抛出一个异常提示(是的,索引路径确实存在) 未处理的异常:System.T
这是代码: Try Dim util As New IndexerUtil() Dim dir As Lucene.Net.Store.Directory = FSDi
对不起,这个简单的问题,但似乎没有任何明显的方法。根据文档,建议保留 IndexWriter 的单个实例。在内存中可以一次又一次地用于更新,而不是为每次更改打开和关闭一个(成本更高)。 但是,文档还指
我正在接手一个项目,所以我还在学习这个。该项目使用 Lucence.NET。我也不知道这个功能是否正确。不管怎样,我正在实例化: var writer = new IndexWriter(direct
我们遇到了 Lucene .Net 抛出 LockObtainFailedException 的锁定问题。这是一个 Multi-Tenancy 站点,每个客户在磁盘上都有自己的物理搜索索引,并使用 I
我的 Lucene Java 实现占用了太多文件。我按照 Lucene Wiki 中有关打开文件太多的说明进行操作,但这只会帮助减缓问题的发生。这是我将对象 (PTicket) 添加到索引的代码: /
我是 Lucene.net 新手,正在努力适应 search code from here这实际上在每个方法中创建了一个新的 Analyzer、IndexSearcher 和 IndexWriter
我是一名优秀的程序员,十分优秀!