我们使用的是Lucene 2.9.2,并希望迁移到Lucene.NET的近乎实时的功能。
我们从IndexWriter获取IndexReader (因此使用NRT)。我的理解是,当以这种方式使用它时,IndexReader还将包含那些已添加但尚未提交的文档的搜索结果(我们正在检查IndexReader iscurrent,如果没有,则使用reopen )。
假设我添加了50个文档,并决定将它们提交到索引中,假设文档很大,提交需要5秒钟。
如果有新的搜索进入,在这5秒内会发生什么?内部RAMDirectory会保留这50个文档,直到提交完成吗?或者,是否会出现这50个文档丢失5秒的情况?
发布于 2011-08-29 00:47:57
您仍然可以搜索这些记录。您的读取器仍然指向索引的未提交版本,就好像您从未调用过提交一样。一旦提交完成,isCurrent会反映出你需要一个新的阅读器。
https://stackoverflow.com/questions/7221314
复制相似问题