在尝试Ghost中提到过托管博客的VPS由于内存不足导致服务宕机。今天意识到可以通过Nginx缓存避免请求落到PHP和MySQL端,从而提升整体性能。此外博客发布后很少改动,读多写少,是使用缓存(或静态化)的好场景。
缓存机制
Nginx提供了基于代理(proxy)和基于fastcgi的两种缓存方式,两者指令集十分相似,使用上差别不大。由于本站博客采用Nginx+PHP-FPM架构,故而使用基于fastcgi的缓存,即fastcgi cache。
配置
fastcgi cache的机制是将后端CGI服务返回的页面缓存起来,后续请求到来时直接返回缓存页面。fastcgi cache与squid、varnish、CDN等原理类似,省去与后端服务通信及生成页面的消耗,原则上性能会比WordPress的各种缓存插件高许多。
fastcgi cache隶属于fastcgi模块,而fastcgi模块又归属于http模块,所以与缓存相关的配置应当都出现在这两个及下属配置块中(主要是http, server和location)。
根据官方文档,博客站点采用的缓存配置如下:
http {
...
fastcgi_connect_timeout 30s;
# 全局设置, fastcgi_cache_path只能出现在http配置块中
# fastcgi_cache_path设置全局的缓存路径、文件大小等,可多次出现设置不同的缓存池
fastcgi_cache_path /var/cache/nginx levels=1:2 keys_zone=WORDPRESS:10m inactive=10m max_size=500m;
fastcgi_cache_key $scheme$request_method$host$request_uri;
# 设置使用过期缓存的情形:后端错误、超时等
fastcgi_cache_use_stale error timeout invalid_header http_500 http_503;
...
server {
...
# 缓存策略指示变量
set $skip_cache 0;
# 缓存策略
if ($query_string != "") {
set $skip_cache 1;
}
if ($request_uri ~* "/wp-admin/|/xmlrpc.php|wp-.*.php|/feed/|sitemap(_index)?.xml") {
set $skip_cache 1;
}
# 登录用户或发表评论者
if ($http_cookie ~* "comment_author|wordpress_[a-f0-9]+|wp-postpass|wordpress_no_cache|wordpress_logged_in") {
set $skip_cache 1;
}
location ~ \.php$ {
...
# 使用的keyzone,这里使用http中定义的WORDPRESS
fastcgi_cache WORDPRESS;
# 是否跳过缓存
fastcgi_cache_bypass $skip_cache;
fastcgi_no_cache $skip_cache;
# 后端返回成功的情况下缓存10分钟
fastcgi_cache_valid 200 10m;
# 添加header字段,指示缓存命中状态(调试使用)
add_header X-Cache $upstream_cache_status;
}
}
}
上述配置做了以下工作:
- 设置缓存池信息(fastcgi_cache_path);
- 设置缓存key(fastcgi_cache_key);
- 过期文件处理(fastcgi_cache_use_stale)
- 缓存策略(fastcgi_cache_bypass/fastcgi_no_cache)
- 后端请求成功时缓存时间(fastcgi_cache_valid)
- 增加了调试信息头(add_header)
重启Nginx,然后访问页面,查看页面的header状态和响应时间。可以看到,请求一次过后(次数可通过fastcgi_cache_min_uses
设置),后续请求都从缓存请求(X-Cache值为HIT),速度提升非常明显。对于管理后台页面,x-cache
的值为BYPASS
,正是我们需要的。
其他
开源版的Nginx不能自动清除缓存,当文章变动或者有新评论时不能立即更新页面。要达到此目的,可使用商业版Nginx或者通过开源插件解决,详情查看此文。
参考
- http://nginx.org/en/docs/http/ngx_http_fastcgi_module.html
- https://www.mf8.biz/wordpress-fastcgi-cache/
原文链接:https://www.qiquanji.com/post/4727.html
本站声明:网站内容来源于网络,如有侵权,请联系我们,我们将及时处理。
微信扫码关注
更新实时通知