- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想使用 Lucene.NET 在两个应用程序之间共享全文搜索:一个是 ASP.NET MVC 应用程序,另一个是控制台应用程序。这两个应用程序都应该搜索和更新索引。
应该如何处理并发?
我找到了一个 tutorial on ifdefined.com 其中讨论了类似的用例。我担心的是锁定将成为一个很大的瓶颈。
PS:
我还注意到 IndexSearcher 使用索引的快照,并且在上面提到的教程中搜索器仅在索引更新时创建。这是一个好方法吗?我可以在每次搜索时创建一个常规搜索器对象,如果是,开销是多少?
我发现了一个相关问题 Does Lucene.Net manage multiple threads accessing the same index, one indexing while the other is searching?什么声称进程间并发是安全的。这是否意味着索引没有竞争条件?
也是非常重要的一个方面。如果假设有 10-15 个线程试图通过获取 this solution 中提供的共享锁来更新 Lucene 索引,那么性能受到的影响是什么? ?
使用它几个月后,我必须添加搜索的打开索引,如果查询使用排序,通常会在高 CPU 和内存负载下创建 OutOfMemory 异常。索引打开操作的成本很小(以我的经验),但 GC 的成本可能相当高。
最佳答案
首先,我们必须定义一个“写”操作。一旦您开始写操作,写操作将对象锁定,并将持续到您关闭正在执行工作的对象。例如创建一个 IndexWriter 并索引一个文档将导致写入对象锁定,并且它将保持此锁定直到您关闭 IndexWriter。
现在我们可以稍微谈谈锁。这个对象锁是一个基于文件的锁。就像前面提到的 mythz 一样,创建了一个名为“write.lock”的文件。一旦写锁被反对,它就是排他的!此锁导致所有索引修改操作(IndexWriter 和来自 IndexReader 的一些方法)等待,直到锁被移除。
总的来说,你对一个索引有多次读取。您甚至可以同时读写,没问题。但是当有多个作者时就会出现问题。如果一个线程等待锁的时间过长,它将超时。
1) 可能的解决方案 #1 直接操作
如果您确定您的索引操作既短又快,您也许可以同时使用相同的索引。否则,您将不得不考虑如何组织应用程序的索引操作。
2) 可能的解决方案 #2 Web 服务
由于您正在使用 Web 解决方案,因此可能可以创建 Web 服务。在实现此 Web 服务时,我会专门使用一个工作线程进行索引。我会创建一个工作队列来包含工作,如果队列包含多个要完成的工作,它应该将它们全部抓取并批量处理。这将解决所有问题。
3)创建另一个索引,然后合并
如果控制台应用程序在索引上做了繁重的工作,您可以考虑使用控制台应用程序,您可以在控制台应用程序中创建一个单独的索引,然后使用 IndexWriter.AddIndexes 在某个安全的预定时间合并索引。
从这里您可以通过两种方式执行此操作,您可以与直接索引合并。或者你可以合并创建第三个索引,然后当这个索引准备好时替换原来的索引。你在这里所做的也必须小心,以确保你不会锁定大量使用的东西并导致其他写入操作超时。
4)索引和搜索多个索引
我个人认为人们需要将他们的索引分开。这有助于分离程序的职责并最大限度地减少停机时间并保持所有索引的单一点。例如,如果您的控制台应用程序仅负责添加某些字段,或者您正在扩展索引,则您可以将索引分开,但通过在每个文档中使用 ID 字段来维护身份。现在,您可以利用内置支持使用 MultiSercher 类搜索多个索引。或者,如果您想要,还有一个很好的 ParallelMultiSearch 类可以同时搜索两个索引。
5)调查SOLR
其他可以帮助您为索引维护单一位置的问题,您可以更改您的程序以使用 SOLR 服务器。 http://lucene.apache.org/solr/还有一个不错的 SOLRNET http://code.google.com/p/solrnet/在这种情况下可以提供帮助的库。虽然我对 solr 没有经验,但我的印象是它可以帮助您管理这样的情况。它还具有其他好处,例如通过查找项目“MoreLikeThis”或提供拼写检查来突出显示和搜索相关项目。
我确定还有其他方法,但这些都是我能想到的方法。总的来说,您的解决方案取决于有多少人在写作以及您需要的搜索索引的最新程度。总体而言,如果您可以将某些操作推迟到稍后的时间并在任何情况下执行一些批处理操作,则将为您提供最佳性能。我的建议是了解您的工作能力并从那里开始。祝你好运
关于.net - Lucene.NET 中的并发。,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2263141/
我想做的是让 JTextPane 在 JPanel 中占用尽可能多的空间。对于我使用的 UpdateInfoPanel: public class UpdateInfoPanel extends JP
我在 JPanel 中有一个 JTextArea,我想将其与 JScrollPane 一起使用。我正在使用 GridBagLayout。当我运行它时,框架似乎为 JScrollPane 腾出了空间,但
我想在 xcode 中实现以下功能。 我有一个 View Controller 。在这个 UIViewController 中,我有一个 UITabBar。它们下面是一个 UIView。将 UITab
有谁知道Firebird 2.5有没有类似于SQL中“STUFF”函数的功能? 我有一个包含父用户记录的表,另一个表包含与父相关的子用户记录。我希望能够提取用户拥有的“ROLES”的逗号分隔字符串,而
我想使用 JSON 作为 mirth channel 的输入和输出,例如详细信息保存在数据库中或创建 HL7 消息。 简而言之,输入为 JSON 解析它并输出为任何格式。 最佳答案 var objec
通常我会使用 R 并执行 merge.by,但这个文件似乎太大了,部门中的任何一台计算机都无法处理它! (任何从事遗传学工作的人的附加信息)本质上,插补似乎删除了 snp ID 的 rs 数字,我只剩
我有一个以前可能被问过的问题,但我很难找到正确的描述。我希望有人能帮助我。 在下面的代码中,我设置了varprice,我想添加javascript变量accu_id以通过rails在我的数据库中查找记
我有一个简单的 SVG 文件,在 Firefox 中可以正常查看 - 它的一些包装文本使用 foreignObject 包含一些 HTML - 文本包装在 div 中:
所以我正在为学校编写一个 Ruby 程序,如果某个值是 1 或 3,则将 bool 值更改为 true,如果是 0 或 2,则更改为 false。由于我有 Java 背景,所以我认为这段代码应该有效:
我做了什么: 我在这些账户之间创建了 VPC 对等连接 互联网网关也连接到每个 VPC 还配置了路由表(以允许来自双方的流量) 情况1: 当这两个 VPC 在同一个账户中时,我成功测试了从另一个 La
我有一个名为 contacts 的表: user_id contact_id 10294 10295 10294 10293 10293 10294 102
我正在使用 Magento 中的新模板。为避免重复代码,我想为每个产品预览使用相同的子模板。 特别是我做了这样一个展示: $products = Mage::getModel('catalog/pro
“for”是否总是检查协议(protocol)中定义的每个函数中第一个参数的类型? 编辑(改写): 当协议(protocol)方法只有一个参数时,根据该单个参数的类型(直接或任意)找到实现。当协议(p
我想从我的 PHP 代码中调用 JavaScript 函数。我通过使用以下方法实现了这一点: echo ' drawChart($id); '; 这工作正常,但我想从我的 PHP 代码中获取数据,我使
这个问题已经有答案了: Event binding on dynamically created elements? (23 个回答) 已关闭 5 年前。 我有一个动态表单,我想在其中附加一些其他 h
我正在尝试找到一种解决方案,以在 componentDidMount 中的映射项上使用 setState。 我正在使用 GraphQL连同 Gatsby返回许多 data 项目,但要求在特定的 pat
我在 ScrollView 中有一个 View 。只要用户按住该 View ,我想每 80 毫秒调用一次方法。这是我已经实现的: final Runnable vibrate = new Runnab
我用 jni 开发了一个 android 应用程序。我在 GetStringUTFChars 的 dvmDecodeIndirectRef 中得到了一个 dvmabort。我只中止了一次。 为什么会这
当我到达我的 Activity 时,我调用 FragmentPagerAdapter 来处理我的不同选项卡。在我的一个选项卡中,我想显示一个 RecyclerView,但他从未出现过,有了断点,我看到
当我按下 Activity 中的按钮时,会弹出一个 DialogFragment。在对话框 fragment 中,有一个看起来像普通 ListView 的 RecyclerView。 我想要的行为是当
我是一名优秀的程序员,十分优秀!