您的位置:首页 > 运维架构 > Nginx

nginx实现缓存功能

2015-09-29 13:25 621 查看
Nginx实现缓存功能:

proxy_cache_path
语法: proxy_cache_path path [levels=number] keys_zone=zone_name:zone_size [inactive=time] [max_size=size];
默认值:None
使用字段:http
指令指定缓存的路径和一些其他参数,缓存的数据存储在文件中。缓存的文件名和key为代理URL的MD5 码。levels参数指定缓存的子目录数,所有活动的key和元数据存储在共享的内存区域中,这个区域用keys_zone参数指定,如果在inactive参数指定的时间内缓存的数据没有被请求则被删除,默认inactive为10分钟。
cache manager进程控制磁盘的缓存大小,在max_size参数中定义,超过其大小后最少使用数据将被删除。区域的大小按照缓存页面数的比例进行设置,一个页面(文件)的元数据大小按照操作系统来定,FreeBSD/i386下为64字节,FreeBSD/amd64下为128字节,当区域满了以后key将按照LRU(最近最少使用算法)进行处理。
proxy_cache_path和proxy_temp_path应该使用在相同的文件系统上。
proxy_cache
语法:proxy_cache  zone_name;
默认值:None
使用字段:http, server, location

设置一个缓存区域的名称,一个相同的区域可以在不同的地方使用。在0.7.48后,缓存遵循后端的”Expires”, “Cache-Control: no-cache”, “Cache-Control: max-age=XXX”以及其他等。然而,目前nginx会忽略一些缓存控制指令,如:”private”和”no-store”,同样,nginx在缓存过程中不会处理”Vary”头,为了确保一些私有数据不被所有的用户看到,后端必须设置 “no-cache”或者”max-age=0″头,或者proxy_cache_key包含用户指定的数据如$http_cookie_xxx,在proxy_cache_key中使用一部分cookie的值可以防止缓存私有数据,所以可以分别指定location以便分开私有数据和公有数据。缓存指令依赖代理缓冲区(buffers),如果proxy_buffers设置为off,缓存不会生效。
proxy_cache_valid
语法:proxy_cache_valid reply_code [reply_code ...] time;
默认值:None
使用字段:http, server, location
该指令为不同的http响应状态码设置不同的缓存时间
编辑主配置文件设置缓存功能
1.#vim /etc/nginx/nginx.conf
###缓存的路径和一些其他参数,keys_zone的值很重要, proxy_cache的值要与之一样
proxy_cache_path /nginx/cache/first levels=1:2:1 keys_zone=first:20m max_size=1g;
server {
add_header X-Cache "$upstream_cache_status from $server_addr"; ##添加一个首部标记缓存是否命中
location / {
proxy_pass  http://backend; proxy_set_header  X-Real-IP  $remote_addr;
proxy_cache first;
proxy_cache_valid 200 10m;   ##指定响应状态码为200的页面缓存10m
}
}
2.创建缓存目录
#mkdir /nginx/cache/first -pv
3.重启服务并且进行测试
#service nginx restart
PS: $upstream_cache_status
MISS: 未命中
EXPIRED - expired。请求被传送到后端。 UPDATING - expired。由于proxy/fastcgi_cache_use_stale正在更新,将使用旧的应答。 STALE - expired。由于proxy/fastcgi_cache_use_stale,后端将得到过期的应答。 HIT: 命中测试时如果是Chrome浏览器按f12调用调试工具,火狐的话安装firebug插件

本文出自 “珞辰的博客” 博客,请务必保留此出处http://luochen2015.blog.51cto.com/9772274/1699100
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: