前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Nginx配置多站点下的Proxy_cache或Fastcgi_cache缓存加速

Nginx配置多站点下的Proxy_cache或Fastcgi_cache缓存加速

作者头像
张戈
发布2018-03-21 16:03:18
1.4K0
发布2018-03-21 16:03:18
举报
文章被收录于专栏:张戈的专栏

张戈博客分享过很多关于缓存加速的教程,自己也是不断的在摸索,追求最佳的网站静态缓存加速方案。在这里简单的总结一下:

1、使用虚拟主机的朋友推荐使用缓存插件或 php 代码版缓存方案=>点此直达 2、使用独立主机的朋友推荐使用 Nginx 的 Fastcgi 纯静态缓存方案=>点此直达

在我分享了 Nginx 的 Fastcgi 缓存之后,有不少朋友已折腾成功。不过有朋友反馈,不知道在多站点下如何配置 Nginx Fastcgi。而所有网上分享的方案都是单个站点的,我本以为多站点的直接在 php 的 location 模块中插入 fastcgi 缓存配置就好了,结果发现会报错,提示缓存空间已被使用。

经过张戈轮番测试,最终试出了多站点下的 Fastcgi 缓存配置,下面简单分享下。

一、部署 http 模块

①、单个站点

单个站点上篇文章已经分享过了,在 http 模块内加入如下配置即可:

代码语言:javascript
复制
fastcgi_cache_path /tmp/wpcache levels=1:2 keys_zone=WORDPRESS:150m inactive=31d max_size=10G;
fastcgi_temp_path /tmp/wpcache/temp;
fastcgi_cache_key "$scheme$request_method$host$request_uri";
fastcgi_cache_use_stale error timeout invalid_header http_500;
fastcgi_ignore_headers Cache-Control Expires Set-Cookie;

②、多个站点

当要给多个站点开启 fastcgi 缓存时,以上配置就不行了,会报错。经过测试,修改如下即可:

代码语言:javascript
复制
#站点1缓存配置
fastcgi_cache_path /tmp/zhangge_cache levels=1:2 keys_zone=zhangge.net:384m inactive=1d max_size=5G;
#站点2缓存配置
#如果要开启更多站点缓存,请继续增加,注意每个站点的 缓存路径 和 keys_zone 要自定义区分一下
#Ps:代码中的参数都只是范例,实际使用请根据服务器配置自行修改
fastcgi_cache_path /tmp/zgboke_cache levels=1:2 keys_zone=zgboke.com:384m inactive=1d max_size=5G;
#其他配置可以不变
fastcgi_temp_path /tmp/temp_cache;
fastcgi_cache_key "$scheme$request_method$host$request_uri";
fastcgi_cache_use_stale error timeout invalid_header http_500;

二、部署 server 模块

配置好了 http 模块之后,server 模块就很简单了!

只要在不同的站点的 php 模块下插入不同的 fastcgi 缓存配置即可,其实就是 key_zone 的区别而已。

比如,我同时给张戈博客和中国博客联盟 2 个站点的配置如下:

张戈博客:

代码语言:javascript
复制
server(
#其他配置略 
location ~ [^/]\.php(/|$)
            {
                try_files $uri =404;
                fastcgi_pass  unix:/dev/shm/php-cgi.sock;
                fastcgi_index index.php;
                include fastcgi.conf;
                #fastcgi缓存配置
                fastcgi_cache_bypass $skip_cache;
                fastcgi_no_cache $skip_cache;
                add_header X-Cache "$upstream_cache_status From $host";
                fastcgi_cache zhangge.net;
                fastcgi_cache_valid 200 301 302 1d;
        }
#其他配置略
}

中国博客联盟:

代码语言:javascript
复制
server(
#以上配置略 
location ~ [^/]\.php(/|$)
            {
                try_files $uri =404;
                fastcgi_pass  unix:/dev/shm/php-cgi.sock;
                fastcgi_index index.php;
                include fastcgi.conf;
                #fastcgi缓存配置
                fastcgi_cache_bypass $skip_cache;
                fastcgi_no_cache $skip_cache;
                add_header X-Cache "$upstream_cache_status From $host";
                fastcgi_cache zgboke.com;
                fastcgi_cache_valid 200 301 302 1d;
        }
#以下配置略
}

其实就是和 http 模块内定义的缓存一 一对应而已,这样才能区分开来啊!否则就会报错。

三、Proxy_cache 缓存

分享了多站点的 fastcgi 缓存配置,顺带也分享一下 Proxy_cache 的多站点缓存配置好了。免得某些朋友不会依葫芦画瓢。。。

其实,我也没实际测试,但是依此类推应该如下配置即可,有需求的测试一番就知道了:

①、http 模块

代码语言:javascript
复制
proxy_connect_timeout 5;
proxy_read_timeout 60;
proxy_send_timeout 5;
proxy_buffer_size 16k;
proxy_buffers 4 64k;
proxy_busy_buffers_size 128k;
proxy_temp_file_write_size 128k;
#同样的有几个站点就配几条proxy_cache_path,注意缓存路径和keys_zone需要自定义区分
#Ps:代码中的参数只是范例,实际使用请根据服务器配置自行修改
proxy_cache_path /tmp/web1_cache levels=1:2 keys_zone=web1_cache:256m inactive=31d max_size=2g;
proxy_cache_path /tmp/web2_cache levels=1:2 keys_zone=web2_cache:256m inactive=31d max_size=2g;
proxy_temp_path /tmp/temp_cache;

②、server 模块

至于 server 模块应该就不用跟上面介绍的那样详细了吧!不同站点只是 proxy_cache 这个配置不一样而已!比如:

站点 1 配置

代码语言:javascript
复制
#其他配置略
proxy_cache web1_cache; #填写站点对应的keys_zone即可
proxy_cache_valid 200 302 304 301 1d;
proxy_cache_valid any 1m;

站点 2 配置:

代码语言:javascript
复制
#其他配置略
proxy_cache web2_cache; #填写站点对应的keys_zone即可
proxy_cache_valid 200 302 304 301 1d;
proxy_cache_valid any 1m;

Ps:可能有人又要问了,这配置是放到哪的啊?唉,就这样您还瞎折腾啥呢?老老实实写文章吧!

哦了,看懂以上配置,随便部署多少站点的 fastcgi 或 proxy 缓存都不用愁了!

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2015年10月06日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、部署 http 模块
    • ①、单个站点
    • 二、部署 server 模块
    • 三、Proxy_cache 缓存
      • ①、http 模块
        • ②、server 模块
        相关产品与服务
        轻量应用服务器
        轻量应用服务器(TencentCloud Lighthouse)是新一代开箱即用、面向轻量应用场景的云服务器产品,助力中小企业和开发者便捷高效的在云端构建网站、Web应用、小程序/小游戏、游戏服、电商应用、云盘/图床和开发测试环境,相比普通云服务器更加简单易用且更贴近应用,以套餐形式整体售卖云资源并提供高带宽流量包,将热门软件打包实现一键构建应用,提供极简上云体验。
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档