设为首页收藏本站
开启辅助访问
切换到宽版

创星网络[分享知识 传递快乐]

 找回密码
 立即注册

QQ登录

只需一步,快速开始

用新浪微博登录

只需一步,快速搞定

搜索
查看: 4304|回复: 0
打印 上一主题 下一主题

Solr httpCache 缓存分析

[复制链接]

我玩的应用:

跳转到指定楼层
楼主
发表于 2012-12-12 12:47:57 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
Solr httpCache 主要是用来判断当前的搜索请求request的请求头header的If-Modified-Since和If-None-Match的两个值,
If-Modified-Since和If-None-Match这两个header信息可以参考我的另一篇博客
有关Last-Modified 与 If-Modified-Since  要想Solr的httpCache缓存生效,需要修改solr的配置文件solrconfig.xml,因为solr的过滤器会做如下判断:
HttpCacheHeaderUtil.setCacheControlHeader(config, resp, reqMethod);
if (config.getHttpCachingConfig().isNever304() ||
                !HttpCacheHeaderUtil.doCacheHeaderValidation(solrReq, req, reqMethod, resp)){
  这里是没有httpcache缓存要做的所有工作。
}
要缓存,首先让solr生成header信息,这个代码就是HttpCacheHeaderUtil.setCacheControlHeader里完成的,
代码如下:

    if (Method.POST==method || Method.OTHER==method) {
      return;
    }
    final String cc = conf.getHttpCachingConfig().getCacheControlHeader();
    if (null != cc) {
      resp.setHeader("Cache-Control", cc);
    }
    Long maxAge = conf.getHttpCachingConfig().getMaxAge();
    if (null != maxAge) {
      resp.setDateHeader("Expires", System.currentTimeMillis()
                         + (maxAge * 1000L));
    }

但是solr默认是没有启用的,需要改solrconfig配置文件,改动如下:

<httpCaching never304="true" >
         <cacheControl>max-age=30, public</cacheControl>
</httpCaching>

<!--
       <httpCaching lastModifiedFrom="openTime"
                    etagSeed="Solr">
         <cacheControl>max-age=30, public</cacheControl>
       </httpCaching>
-->

两个可以任选一个,如果两个都选,则第一个有效。

把这个httpcache的注释去掉就可以,solr在初始化时取cacheControl这个值的。上面代码CC就是cacheControl的值,
从上面代码可以看出,max-age的值写到header的Expires表示该资源的有效期,单位没秒。
public 表示可以所有的资源。如果cc的值为空的话,SOlr就不会生成header信息,导致在客户端下次请求时相关的header信息就位空。

config.getHttpCachingConfig().isNever304() 的值就是配置文件solrconfig.xml中

<httpCaching never304="true" /> 的值,默认是true,从上面的if判断可以看出,为true的话,就是不启用httpCache缓存。
所以要启用httpcache缓存,先把这个值改为false,这里改好了,solr就根据head头来判断是否要直接用httpcache了。这个就是在HttpCacheHeaderUtil.doCacheHeaderValidation里判断实现的.代码如下:

   if (Method.POST==reqMethod || Method.OTHER==reqMethod) {
         return false;
    }
   
    final long lastMod = HttpCacheHeaderUtil.calcLastModified(solrReq);
    final String etag = HttpCacheHeaderUtil.calcEtag(solrReq);
   
    resp.setDateHeader("Last-Modified", lastMod);
    resp.setHeader("ETag", etag);

    if (checkETagValidators(req, resp, reqMethod, etag)) {
      return true;
    }

    if (checkLastModValidators(req, resp, lastMod)) {
      return true;
    }
从上面可以看出,如果是post请求,不会启用httpCache缓存,
lastMod 的值是索引最近修改时间,这里是根据取的是<httpCaching lastModifiedFrom="openTime"   etagSeed="Solr">
里lastModifiedFrom的值来计算,当为opentime时,lastModifiedFrom为solr index的打开时间。如果没有,默认也是。
etagSeed的值是用来计算etag 的,根据etag的值生成一个唯一的值。并写会给客户端。

from:http://go.cxweb.com.cn/pvg4t
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 转播转播 分享分享 分享淘帖
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|小黑屋|创星网络 ( 苏ICP备11027519号|网站地图  

GMT+8, 2024-9-22 07:17 , Processed in 0.087707 second(s), 23 queries .

Powered by Discuz! X3

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表