- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 Lucene.net 3.0.3.0 (现在是最新版本)。我想知道是否使用 的单个实例IndexWriter 和 索引搜索器 在生产环境中是一个不错的选择(考虑线程安全)。我在文档中读到创建这些实例的新对象是一项昂贵的操作,并且在内部 lucene 可以很好地处理并发请求。
这是给在生产环境中使用过lucene.net的人一个疑问;请让我知道这是否可行!
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using Lucene.Net.Search;
using Lucene.Net.Store;
using System.IO;
using Directory = Lucene.Net.Store.Directory;
using Version = Lucene.Net.Util.Version;
using Lucene.Net.Index;
using Lucene.Net.Analysis.Standard;
using Lucene.Net.Analysis;
namespace MXLuceneConsoleApp
{
/// <summary>
/// This helper class applies a singleton pattern to create Searcher and Writer objects as it's recommended to create them only once.
/// Also the searcher gets reinitialized, if any write happens.
/// </summary>
public class MXLuceneIndexHelper
{
private static IndexSearcher _searcher;
private static Directory _directory;
private static Lazy<IndexWriter> _writer = new Lazy<IndexWriter>(() => new IndexWriter(_directory, new StandardAnalyzer(Version.LUCENE_30), IndexWriter.MaxFieldLength.UNLIMITED));
//this private constructor makes it a singleton now.
private MXLuceneIndexHelper() { }
//Static constructor, opening the directory once for all.
static MXLuceneIndexHelper()
{
_directory = FSDirectory.Open(new DirectoryInfo(Environment.CurrentDirectory + "\\LuceneIndexDir"));
}
public static IndexSearcher IndexSearcher
{
get
{
if (_searcher == null)
{
InitializeSearcher();
}
else if (!_searcher.IndexReader.IsCurrent())
{
//_searcher.IndexReader.Reopen();
//refreshing the underlying Reader above doesn't do the trick, so I'm reinitializing the Searcher.
_searcher.Dispose();
InitializeSearcher();
}
return _searcher;
}
}
public static IndexWriter IndexWriter
{
get
{
//_writer.SetRAMBufferSizeMB(30.0);
return _writer.Value;
}
}
private static void InitializeSearcher()
{
_searcher = new IndexSearcher(_directory, false);
}
}//End of class
}
最佳答案
我的理解是每个索引应该只有 1 个 IndexWriter 实例。默认情况下,Lucene 中启用了内置锁定以确保这种情况。至于单例模式,我认为你应该看看新的 Lazy .NET 4 中的类。它免费处理所有锁定和空值检查。
对于 IndexSearcher,您可以随意拥有任意数量的实例。但是,我认为如果您重用现有的搜索器,性能会有所提升。我可以从您的代码中看出,您知道重新打开现有搜索器比创建新搜索器便宜得多。搜索器中还有内置缓存,在您进行第一次搜索时会初始化。您还可以实现一个 IndexReaderWarmer 来控制搜索器何时被加热(就像在第一次搜索之前一样)。
关于lucene.net - IndexWriter 和 IndexSearcher 的单例模式 Lucene.net,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14473427/
当文档根据 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
我是一名优秀的程序员,十分优秀!