Solr4.4 优化之 Filter Cache配置

11 篇文章 0 订阅
3 篇文章 0 订阅

 

 

      本文描述solr的cache类型之一:filter cache。接下来,我会解释它是什么、怎么配置它以及如何更好的使用它。 

What it is used for? 
       先从内部机制开始。FilterCache存储了一些无序的文档标识号(ID)。这些ID并不是我们在schema.xml里配置的unique key,而是solr内部的一个文档标识。请记住这个。 

        FilterCache的任务是保持与用户过滤的结果关联。另外,cache可以辅助facet机制(在使用TermEnum时),在solrconfig.xml中的<useFilterForSortedQuery/>参数设为true时,还可以进行排序。 

FilterCache的标准定义如下: 

Xml代码   收藏代码
  1. <filterCache  
  2.     class="solr.FastLRUCache"  
  3.     size="16384"  
  4.     initialSize="4096"  
  5.     autowarmCount="4096" />  



有以下的配置可供选择: 
    class:实现类。建议使用solr.FastLRUCache,它能在大量的GET、PUT操作下,提供更好的性能。 
    size:cache的最大值。 
    initialSize:cache的初始化值。 
    autowarmCount:从旧的cache到新的cache时,需要被复制的数量。 
    minSize:在full restoraton的情况下,将cache减小后的值 
    acceptableSize:如果minSize没有设置,则该值会替代之 
    cleanupThread:默认false,如果设为true则会使用一个分离的topic来清理cache。 

大部分情况下,设置initialSize和autowarmCount就已经足够了。 

How to configure? 
       cache的大小,需要根据基本的查询语句而定;maximum大小应该至少等于我们使用的过滤字段的大小。举个例子说明:如果在某个时间内,你的应用程序使用了2000个查询参数,则minimum的大小应该最小设为2000。 

Efficient use 
    然而,光有配置是不够的,我们还需要让查询能够使用它。请看下面的例子: 

Url代码   收藏代码
  1. q=name:solr+AND+category:ksiazka+AND+section:ksiazki  



初看起来,查询语句是正确的。但是有个问题:它并没有用到filterCache。所有的请求将会绑定到queryResultCache中并创建一个单独的条目。我们来作一下修改: 

Url代码   收藏代码
  1. q=name:solr&fq=category:ksiazka&fq=section:ksiazki  



有什么变化呢?在这个例子中,一个条目会写入到queryResultCache中;另外,还会有两个条目会写入到filterCache中。现在看一下下面的语句: 

Url代码   收藏代码
  1. q=name:lucene&fq=category:ksiazka&fq=section:ksiazki  



这个查询会创建一个条目到queryResultCache中,但是会使用filterCache中两个已经存在的条目。这样查询的执行时间会降低,IO的使用也会节省。 

然而,对于下面的查询: 

Url代码   收藏代码
  1. q=name:lucene+AND+category:ksiazka+AND+section:ksiazki  



solr不能使用任何cache并且需要从lucene索引中收集所有的信息。 

Last few words 
就像你所看到的,配置cache 的正确方法不是如何保证solr能够使用它,而是如何构建查询语句来提升性能。当考虑查询的时候,请考虑这一点。 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
提供的源码资源涵盖了安卓应用、小程序、Python应用和Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值