今天就跟大家聊聊有关Nginx中怎么避免传统缓存,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。
1、传统缓存之一(404)
这个办法是把Nginx缓存的404错误定向到后端,然后用proxy_store把后端返回的页面保存。
配置:
location / {
root /home/html/;#主目录
expires 1d;#网页的过期时间
error_page 404 =200 /fetch$request_uri;#404定向到
/fetch目录下}
location /fetch/ {#404定向到这里
internal;#指明这个目录不能在外部直接访问到
expires 1d;#网页的过期时间
alias /home/html/;#虚拟目录文件系统地址要和locaion
/一致,proxy_store会将文件保存到这目录下proxy_pass http://www.sudone.com/;#后端upstream地址,
/fetch同时是一个代理proxy_set_header Accept-Encoding '';#让后端不要返回压缩
(gzip或deflate)的内容,保存压缩后的内容会引发乱子。proxy_store on;#指定Nginx将代理返回的文件保存
proxy_temp_path /home/tmp;#临时目录,这个目录要和/home/
html在同一个硬盘分区内}
使用的时候还有要注意是Nginx缓存要有权限往/home/tmp和/home/html下有写入文件的权限,在linux下Nginx一般会配置成nobody用户运行,这样这两个目录就要chown nobody,设成nobody用户专用,当然也可以chmod 777,不过所有有经验的系统管理员都会建议不要随便使用777。
2、传统缓存之二(!-e)
原理和404跳转基本一致,但更简洁一些:
location / {
root /home/html/;
proxy_store on;
proxy_set_header Accept-Encoding '';
proxy_temp_path /home/tmp;
if ( !-f $request_filename )
{
proxy_pass http://www.sudone.com/;
}
}
看完上述内容,你们对Nginx中怎么避免传统缓存有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注亿速云行业资讯频道,感谢大家的支持。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。