在我分享了 Nginx 的 Fastcgi 缓存之后,有不少朋友已折腾成功。不过有朋友反馈,不知道在多站点下如何配置 Nginx Fastcgi。而所有网上分享的方案都是单个站点的,我本以为多站点的直接在 php 的 location 模块中插入 fastcgi 缓存配置就好了,结果发现会报错,提示缓存空间已被使用。
经过轮番测试,最终试出了多站点下的 Fastcgi 缓存配置,下面简单分享下。
一、部署 http 模块
①、单个站点
单个站点上篇文章已经分享过了,在 http 模块内加入如下配置即可:
1 2 3 4 5 | 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 缓存时,以上配置就不行了,会报错。经过测试,修改如下即可:
1 2 3 4 5 6 7 8 9 10 | #站点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 的区别而已。
比如,我同时给中国博客联盟 站点的配置如下:
张戈博客:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 | 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; } #其他配置略 } |
中国博客联盟:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 | 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 模块
1 2 3 4 5 6 7 8 9 10 11 12 | 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 配置
1 2 3 4 | #其他配置略 proxy_cache web1_cache; #填写站点对应的keys_zone即可 proxy_cache_valid 200 302 304 301 1d; proxy_cache_valid any 1m; |
站点 2 配置:
1 2 3 4 | #其他配置略 proxy_cache web2_cache; #填写站点对应的keys_zone即可 proxy_cache_valid 200 302 304 301 1d; proxy_cache_valid any 1m; |
Ps:可能有人又要问了,这配置是放到哪的啊?唉,就这样您还瞎折腾啥呢?老老实实写文章吧!
哦了,看懂以上配置,随便部署多少站点的 fastcgi 或 proxy 缓存都不用愁了!