使用fastcgi_cache加速你的Nginx网站
很久以前在TW上挖了个坑,说nginx的fastcgi_cache是被大家忽视的一大金矿,今天把这个坑填上,顺祝大家新年快乐。
对于变化不太频繁的数据,大家都比较喜欢存Memcached以减少数据库的读取,但还是会有语言解析运行上的消耗(比如运行PHP,Python等),当然这个时间很短,记得OP上有个同学说P字头的语言,效率都不高,如果能省去,当然最好。(已经用上Squid等的可以忽略本文)。
还有一个问题就是很多时候一个页面由多个数据片断组成,为了提高页面速度,要么分别缓存,要么整体缓存(所谓的Page Cache),其实都比较麻烦,增加和减少数据片断的时,大多需要调整。
最后一个问题,所有的数据都存Memcached是否经济?服务器资源足够多的无所谓,捉襟见肘的就要考虑了,当然,生成静态页面是一种方法,需要维护,还是比较累。
好吧,nginx的fastcgi_cache可以解决上面的那些问题,比较squid等的好处是简单,不需再要去维护另外一个系统,适合不那么大的网站。
关于Nginx fastcgi_cache,基础的可以参看Nginx官方文档http://wiki.nginx.org/HttpFcgiModule,下面是一个典型的做法是:
全局定义一个缓存空间,配置文件名为,fastcgi_cache.conf,然后在vhost配置里面加上:
fastcgi_cache ngx_fcgi_cache; include fastcgi.conf;
大概解释下各个参数的含义:
fastcgi_temp_path:生成fastcgi_cache临时文件目录
fastcgi_cache_path:fastcgi_cache缓存目录,可以设置目录哈希层级,比如2:2会生成256*256个字目录,keys_zone是这个缓存空间的名字,cache是用多少内存(这样热门的内容nginx直接放内存,提高访问速度),inactive表示默认失效时间,max_size表示最多用多少硬盘空间,需要注意的是fastcgi_cache缓存是先写在fastcgi_temp_path再移到fastcgi_cache_path,所以这两个目录最好在同一个分区,从0.8.9之后可以在不同的分区,不过还是建议放同一分区。
fastcgi_cache_valid:定义哪些http头要缓存
fastcgi_cache_use_stale:定义哪些情况下用过期缓存
fastcgi_cache_key:定义fastcgi_cache的key,示例中就以请求的URI作为缓存的key,Nginx会取这个key的md5作为缓存文件,如果设置了缓存哈希目录,Nginx会从后往前取相应的位数做为目录。
fastcgi_cache:用哪个缓存空间
这样就可以了,基本上可以work,但还没完,如何手动清除缓存?有个Nginx的第三方扩展可帮你做到:https://github.com/FRiCKLE/ngx_cache_purge/,如果对大多数第三方扩展无爱,写个清除的脚本也非常简单,以PHP为例:
以下是代码片段: <?php function purgeCache() { $url = $this->post(’url’); if (empty($url) || !Cola_Com_Validate::url($url)) { exit(’请输入正确的URL。’); } $md5 = md5($url); $cacheFile = $this->_cacheRoot . ’/’ . substr($md5, -2, 2) . ’/’ . substr($md5, -4, 2) . ’/’ . $md5; if (!file_exists($cacheFile)) { exit(’缓存不存在。’); } if (@unlink($cacheFile)) { echo ’清除缓存成功。’; } else { echo ’清除缓存失败。’; } } |
淡定,文章还没完,要不就成标题党了,Nginx fastcgi_cache缓存很不错,但我只想在某些页面用fastcgi_cache,很简单,有两种方法,一是在location中定义fastcgi_cache,这样只有满足一定规则的url才会用上cache,其他的就不会了;另外一种方法是在你不需要缓存的页面上,输出禁止缓存的头信息,用ColaPHP的话,直接$this->response->disableBrowserCache(); 具体代码:
header("Expires: Mon, 26 Jul 1997 05:00:00 GMT"); header("Last-Modified: " . gmdate("D, d M Y H:i:s") . " GMT"); header("Cache-Control: no-store, no-cache, must-revalidate"); header("Cache-Control: post-check=0, pre-check=0", false); header("Pragma: no-cache");
这样就告诉Nginx,这个页面不需要缓存。
好吧,要淡定不要D疼,还有最后一个问题,如果页面中只有一小部分内容不可以缓存,可以用Nginx fastcgi_cache吗?比如某个内容页,大部分内容可以缓存,但希望把用户的登录信息更新上去。答案是肯定的,可以直接输出用户未登录的页面样式,等页面加载完毕之后,通过ajax异步更新用户信息:
$().ready(function() { initUser(); })
码完收工。
建议继续学习:
- 配置Nginx+uwsgi更方便地部署python应用 (阅读:105475)
- 搜狐闪电邮箱的 Nginx/Postfix 使用模式 (阅读:32584)
- 解析nginx负载均衡 (阅读:14693)
- Nginx模块开发入门 (阅读:9997)
- 检查nginx配置,重载配置以及重启的方法 (阅读:9212)
- Cacti 添加 Nginx 监控 (阅读:8982)
- Nginx+FastCgi+Php 的工作机制 (阅读:8951)
- nginx的配置文件 (阅读:8925)
- 奇怪的 Nginx 的 upstream timed out 引起响应 502 (阅读:8352)
- 解决IE6从Nginx服务器下载图片不Cache的Bug (阅读:7166)
扫一扫订阅我的微信号:IT技术博客大学习
- 作者:超群.com 来源: 超群.com的博客
- 标签: fastcgi_cache Nginx 加速
- 发布时间:2011-01-05 22:44:49
- [71] IOS安全–浅谈关于IOS加固的几种方法
- [70] Twitter/微博客的学习摘要
- [65] 如何拿下简短的域名
- [64] android 开发入门
- [63] Go Reflect 性能
- [62] find命令的一点注意事项
- [60] 流程管理与用户研究
- [59] 图书馆的世界纪录
- [59] 读书笔记-壹百度:百度十年千倍的29条法则
- [58] Oracle MTS模式下 进程地址与会话信