Nginx缓存有不少需要我们学习的知识,尤其是在面对很多错误的时候,那么首先我们就先了解下有关404错误吧。貌似从来没有写过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缓存的详细介绍,希望大家有所收获。
【编辑推荐】