磁盘IO往往是计算机系统响应速度的一个突出瓶颈,搜索引擎查询很平凡,减少搜索过程中的磁盘IO对提升搜索响应速度无疑有莫大的帮助,在solr中,提供自带的缓存机制。我们只需要在solrconfig.xml中加几个配置项就可以了。

下面我们看看solr的3个缓存。

Filter cache:这个是被用来缓存过滤器(就是查询参数fq)的结果和基本的枚举类型。

Document cache:这个是被用来缓存lucene documents的,就是存储field的那个东西。

Query result cache:这个一目了然,把查询结果缓存起来。

一、缓存配置

Solr的缓存配置在solrconfig.xml文件的查询配置部分,也就是<query>和</query>标签之间。Solr实现了2种缓存机制,分别是LRUCache、FastLRUCache;

LRUCache:基于线程安全的LinkedHashMap实现。

FastLRUCache:基于ConcurrentHashMap实现。

单线程的情况下FastLRUCache具有更快的gets操作和比较慢的puts操作,因此使用它的查询命中率会高出LRUCache 75%,当然在多线程的情况下差距可能更大。

参数说明:

Class:指定使用solr的哪种缓存机制。

Size:允许分配多少个实体(entity)的缓存空间。

initialSize:分配初始多少个实体(entity)的缓存空间。

autowarmCount:自动预装入实体数。

1、  Filter cache

[html] view
plain
copy

  1. <filterCache
  2. class="solr.FastLRUCache"
  3. size="200"
  4. initialSize="200"
  5. autowarmCount="100"/>

2、Documentcache

[html] view
plain
copy

  1. <queryResultCache
  2. class="solr.FastLRUCache"
  3. size="500"
  4. initialSize="500"
  5. autowarmCount="250"/>

3、Queryresult cache

[html] view
plain
copy

  1. <documentCache
  2. class="solr.FastLRUCache"
  3. size="11000"
  4. initialSize="11000" />

4、查询结果窗口值设置

查询结果窗口值是和Query result cache配合使用的。这个值是个什么概念呢,就是我设置查询结果窗口值为50,我查询20到30条的数据,第一次查询的时候solr会从索引库中取出0到49条的数据,我翻页的时候就不用再到索引库里面去查询了,直接从缓存里面取就可以了,大大的提高了查询响应速度。

[html] view
plain
copy

  1. <queryResultWindowSize>50</queryResultWindowSize>

二、完整配置

[html] view
plain
copy

  1. <!--缓存配置-->
  2. <query>
  3. <!--过滤器cache-->
  4. <filterCache
  5. class="solr.FastLRUCache"
  6. size="200"
  7. initialSize="200"
  8. autowarmCount="100"/>
  9. <!--查询结果cache-->
  10. <queryResultCache
  11. class="solr.FastLRUCache"
  12. size="500"
  13. initialSize="500"
  14. autowarmCount="250"/>
  15. <!--文档cache-->
  16. <documentCache
  17. class="solr.FastLRUCache"
  18. size="11000"
  19. initialSize="11000" />
  20. <queryResultWindowSize>200</queryResultWindowSize>
  21. </query>

Solr4.7缓存技术的更多相关文章

  1. 网站缓存技术总结( ehcache、memcache、redis对比)

    网站技术高速发展的今天,缓存技术已经成为大型网站的一个关键技术,缓存设计好坏直接关系的一个网站访问的速度,以及购置服务器的数量,甚至影响到用户的体验. 网站缓存按照存放的地点不同,可以分为客户端缓存. ...

  2. ASP.NET Core 缓存技术 及 Nginx 缓存配置

    前言 在Asp.Net Core Nginx部署一文中,主要是讲述的如何利用Nginx来实现应用程序的部署,使用Nginx来部署主要有两大好处,第一是利用Nginx的负载均衡功能,第二是使用Nginx ...

  3. .Net环境下的缓存技术介绍 (转)

    .Net环境下的缓存技术介绍 (转) 摘要:介绍缓存的基本概念和常用的缓存技术,给出了各种技术的实现机制的简单介绍和适用范围说明,以及设计缓存方案应该考虑的问题(共17页) 1         概念 ...

  4. [.net 面向对象程序设计进阶] (14) 缓存(Cache) (一) 认识缓存技术

    [.net 面向对象程序设计进阶] (14) 缓存(Cache)(一) 认识缓存技术 本节导读: 缓存(Cache)是一种用空间换时间的技术,在.NET程序设计中合理利用,可以极大的提高程序的运行效率 ...

  5. 分布式缓存技术redis学习系列(三)——redis高级应用(主从、事务与锁、持久化)

    上文<详细讲解redis数据结构(内存模型)以及常用命令>介绍了redis的数据类型以及常用命令,本文我们来学习下redis的一些高级特性. 安全性设置 设置客户端操作秘密 redis安装 ...

  6. 分布式缓存技术redis学习系列(一)——redis简介以及linux上的安装

    redis简介 redis是NoSQL(No Only SQL,非关系型数据库)的一种,NoSQL是以Key-Value的形式存储数据.当前主流的分布式缓存技术有redis,memcached,ssd ...

  7. PHP开发中的缓存技术汇总

    在PHP开发中,出于对网站服务器负载的考虑,往往需要对页面.数据等内容进行缓存处理,下面就来看看,在PHP开发中有哪些缓存方式吧. 1.页面部分缓存该种方式,是将一个页面中不经常变的部分进行静态缓存, ...

  8. .Net环境下的缓存技术介绍

    .Net环境下的缓存技术介绍 摘要: 介绍缓存的基本概念和常用的缓存技术,给出了各种技术的实现机制的简单介绍和适用范围说明,以及设计缓存方案应该考虑的问题(共17页) 1         概念 1.1 ...

  9. ASP.NET 缓存技术分析

    缓存功能是大型网站设计一个很重要的部分.由数据库驱动的Web应用程序,如果需要改善其性能,最好的方法是使用缓存功能.可能的情况下尽量使用缓存,从内存中返回数据的速度始终比去数据库查的速度快,因而可以大 ...

随机推荐

  1. Flex LinkButton鼠标划过出现下划线

    在LinkButton中 textDecoration属性设置label的是否有下划线装饰,属性值分为"none","underline" 代码如下------ ...

  2. Foundation Sorting: Shellsort

    /* Shell Sorting. * Implemention history:. * 2013-09-15, Mars Fu, first version. */ /* [Shell Sortin ...

  3. 【cocos2d-x】Win7下配置Cocos2d-x开发环境

    一.下载安装包 先去Cocos2d-x官网下载安装包,最新版本为cocos2d-2.1.5 http://www.cocos2d-x.org/news/134 二.解压安装包 下载完成后,解压文件,解 ...

  4. STL之stack(栈)

    栈(statck)这种数据结构在计算机中是相当出名的.栈中的数据是先进后出的(First In Last Out, FILO).栈只有一个出口,允许新增元素(只能在栈顶上增加).移出元素(只能移出栈顶 ...

  5. 调试带有源代码的DLL文件

    工作环境:dll源代码是c,在Visual studio 2010中调试. 第一步,调试的准备. 用C#语言编写一个测试dll文件的程序,由于dll源程序是c的,且运行结果是黑屏的,所以C#代码也是运 ...

  6. mysql支持emoji解决办法

    mysql显示不了emoji表情或者显示??,原因这里不解释,直接说解决办法.(主要就是修改utf8mb4) 1.修改表 ALTER TABLE `TABLE_NAME` CHARACTER SET ...

  7. 13. Roman to Integer

    Given a roman numeral, convert it to an integer. Input is guaranteed to be within the range from 1 t ...

  8. 完全掌握KMP算法思想

    文档下载页面http://download.csdn.net/detail/yedeqixian/4209500      80页在讲KMP算法的开始先举了个例子,让我们对KMP的基本思想有了最初的认 ...

  9. maven GroupID和ArtifactID填什么

    GroupID是项目组织唯一的标识符,实际对应JAVA的包的结构,是main目录里java的目录结构. ArtifactID就是项目的唯一的标识符,实际对应项目的名称,就是项目根目录的名称.一般Gro ...

  10. Linux的五个查找命令find,locate,whereis,which,type

    Linux的五个查找命令 1. find 最常见且最强大的命令,可以查找任何文件. 格式 $ find   指定目录   指定条件   指定动作   指定目录: 所要搜索的目录及其子目录,默认当前目录 ...