Varnish解决带参数的URL可能造成多份缓存的问题
来源:互联网 发布:南水北调 知乎 编辑:程序博客网 时间:2024/06/06 00:20
当Varnish遇到带参数的URL(这些参数还经常变)的时候,通常会存在同一个真正的URL存放多份缓存及缓存命中率低的情况,根据官方网站的文档说明,可以在sub_recv中加入如下段解决。
if (req.url ~ ".(jpg|gif|png)\?.*") {
set req.url = regsub(req.url, "\?.*", "");
}
但当实际设置了以后仍然会出现URL参数变化后Varnish返回miss,这说明Varnish实际上还是以全部req.url作为hash进行缓存的。有兴趣的同学可以自己试试:)
我想了很久,最后终于发现这个重置了以后的req.url并没有作为sub_hash中hash key进行缓存,于是做了如下变通终于实现了按照不带参数的URL进行缓存以达到提高缓存命中率和避免多份缓存的目的。
其实配置的方法很简单,即
sub_hash {
if (req.url ~ ".(jpg|gif|png)\?.*") {
set req.hash += regsub(req.url, "\?.*", "");
}
else {
set req.hash += req.url;
}
hash;
}
Varnish 2.0.2和2.0.3版本都有这个问题,我已在官方网站报了bug,见http://varnish.projects.linpro.no/ticket/465 各位有兴趣的也可关注一下:)
更新: 在sub_recv中set req.url = regsub(req.url, "\?.*", "");即可,不用再在hash中添加
在header中添加cache的命中状态的方法(在sub_deliver中添加)
if (obj.hits > 0) {
set resp.http.X-Cache = "Server-6-HIT";
} else {
set resp.http.X-Cache = "Server-6-MISS";
}
替换到后端的URL请求
sub vcl_miss {
if (req.request == "PURGE") {
error 404 "Not in cache.";
}
set bereq.url = regsub(req.url, "\?.*", "");
fetch;
}
- Varnish解决带参数的URL可能造成多份缓存的问题
- Varnish解决带参数的URL可能造成多份缓存的问题
- Varnish解决带参数的URL可能造成多份缓存的问题
- 解决url参数带”&“被截断的问题
- varnish 过滤某个参数的url
- varnish缓存清除的问题和陷阱
- 解决Url带中文参数乱码问题
- 解决Url带中文参数乱码问题
- 解决Url带中文参数乱码问题
- 解决Url带中文参数乱码问题
- Activity的生命周期可能造成的问题
- GET重定向url带特殊字符参数拼接问题的解决
- 解决URL中文参数乱码的问题
- 解决URL中文参数乱码的问题
- django 带参数的 url
- url带中文参数显示乱码的问题
- iphone开发,请求url参数带中文的问题
- asp.net url带中文参数显示乱码的问题
- Tweening transition of Brightness in ActionScript with Tweener
- activemq的web管理界面
- Axis调用webservice查看天气情况(固定地区)
- android开发环境问题
- ExpandableListView的下拉图标替换
- Varnish解决带参数的URL可能造成多份缓存的问题
- strtok()--SelectItem--HitTest
- VC编写vista或win7下需要管理员权限运行的程序
- VMWare进入BIOS
- ubuntu下 GCC编译程序出现 undefined reference to `std::ios_base::Init::Init()'问题
- 继承与虚函数
- “Failed to upload *.app on Device ” Error in iPhone
- 怎么才能得到积分呢
- Google首页电吉他