Nginx2/4---缓存简介

1.缓存简介

nginx的http_proxy模块,可以实现类似于 Squid的缓存功能、
nginx对客户已经访问过的内容在nginx服务器本地建立副本,这样在一段时间内再次访问该数据,就不需要通过nginx服务器再次向后端服务器发出请求,所以能够减少nginx服务器与后端服务器之间的网络流量,减轻网络拥塞,同时还能减少数据传输延迟,提高用户访问速度。

同时,当后端服务器当即时,nginx服务上的副本资源还能够回应相关的用户请求,提高后端服务器的健壮性。
在这里插入图片描述

2.对于缓存的问题

(1)缓存文件放在哪?

proxy_cache_path:ngxin使用该参数指定缓存位置
proxy_cache:该参数为之前的缓存名称

proxy_cache_path:两个必填参数,
第一个:缓存目录
第二个:keys_zone指定缓存名称和占用内存空间的大小
在这里插入图片描述
注:实例中的10m是对内存中缓存内容元数据信息大小的限制,如果想限制缓存总量大小,需要用max_size参数。

(2)如何指定哪些请求被缓存

nginx默认会缓存所有的get和head方法的请求结果,缓存的key默认使用请求字符串。

自定义key,例如:proxy_cache_key "$host$request_url$cookie_user"

指定请求至少被发送了多少次以上时才缓存,可以防止低频请求被缓存。
例如:proxy_cache_min_user 5;

指定哪些方法的请求被缓存
例如:proxy_cache_methods GET HEAD POST;
在这里插入图片描述

(3)缓存的有效期是多久

默认情况下, 缓存的内容是长期保留的,除非缓存的总量超出限制。可以指定缓存有效时间。例如:
响应状态码为200 302时,10分钟有效 例如:proxy_cache_valid 200 302 10m;
对应任何状态码,5分钟有效,例如:proxy_cache_valid 5m;
在这里插入图片描述

(4)对应某些请求,是否可以不走缓存

proxy_cache_bypass:该指令来自原服务器而不是缓存。
例如:proxy_cache_bypass $cookie_nocache $arg_nocache$arg_comment;

如果任何一个参数值不为空,或者不等于0,nginx就不会直接查找缓存,直接进行代理转发。
在这里插入图片描述
网页的缓存是由HTTP消息头中"Cache-control"来控制的,常见的取值有private、 no-cacahe、 max-age 、must-revalidate等,默认为private。起作用根据不同的重新访问方式分为以下几种情况。

Cache-directive说明
public所有内容都将被缓存(客户端和代理服务器都可缓存)
private内容只缓存到私有缓存中(仅客户端可以缓存,代理服务器不可缓存)
no-cache必须先与服务器确认返回的响应是否被更改,然后才能使用该响应来满足后续对同一个网址的请求。因此,如果存在合适的验证令牌(ETag),no-cache会发起往返通信来验证缓存的响应,如果资源未被更改,可以避免下载。
no-store所有内容都不会被缓存到缓存或Internet临时文件中
must-revalidation/proxy-revalidation如果缓存的内容失效,请求必须发送到服务器/代理以进行重新验证
max-age=XXX (xxx is numeric)缓存的内容将在xxx秒后失效,这个选项只在HTTP1.1可用,并如果 和Last-Modified一起使用时,优先级较高

小结:解决这些问题后,nginx的缓存也就基本配置完成了。新请求--存不存--存多久---继续

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值