素材巴巴 > 程序开发 >

关于 http 请求的缓存问题?(nginx 缓存、浏览器缓存)

程序开发 2023-09-03 11:32:31

关于 http 的缓存什么时候刷新,什么时候是用的本地的缓存数据,这个问题其实在开发的时候经常会遇见;有时候我们明明更新了代码,但是本地还是显示旧的文件或者数据;现在我们就来分析下这是为什么?

注意:http 请求有个约定:GET 有缓存,POST 一般没有缓存
RFC 规范中明确指出 POST 只有在特定头的情况下才会有缓存数据,一般不会缓存。

网页请求过程:


这里我们看到有 3 个地方会产生缓存:
1、本地浏览器缓存
2、CDN 缓存
3、Nginx 代理缓存

本地浏览器缓存

本地浏览器缓存涉及到以下几个项的控制:
1、URL 是否有更新,本地的浏览器缓存会基于 URL 这个 key 来进行查找,如果 URL 发生变化则不会从本地缓存中读取。
2、请求和响应中的 Cache-Control 头,Cache-Control 头一般用的比较多的两个值是:no-cache、max-age=[seconds],no-cache 表示不走缓存,永远都从服务器加载数据,max-age=[seconds] 表示缓存多久时间的数据。
3、Expires 头,也是表示缓存时间,等同 Cache-Control 的 max-age 效果。但是如果同时存在,则被 Cache-Control 的 max-age 覆盖。
4、请求中的 If-Modified-Since,响应中的 Last-Modified,这两个头信息用于判断文件是否发生修改,如果时间相同或者大于服务器时间,则该文件返回 304,表示内容没有发生变化不需要服务端传递数据回来,这其实也是一种变相的缓存(本地数据没有更新)。

CDN 缓存:

CDN 缓存主要受制于 CDN 的缓存时间配置和 URL 的变化。

Nginx 代理缓存:

Nginx 在做代理转发的时候为了减少网络开销,可以配置 proxy_cache 缓存代理。
一般默认情况下 Nginx 代理缓存是没有配置的,不过有些运维工具是自带有这个功能(宝塔),所以还是要了解一下。
Nginx 配置举例:

​
 http {#设置缓存路径、大小和别名等proxy_cache_path /app/runtimes/openresty/nginx/proxy_cache_dir levels=1:2 keys_zone=cache_one:20m inactive=1d max_size=5g;server {#开启缓存,缓存基本设置proxy_buffering on;proxy_connect_timeout 60;proxy_read_timeout 60;proxy_send_timeout 60;proxy_buffer_size 32k;proxy_buffers 4 64k;proxy_busy_buffers_size 128k;proxy_temp_file_write_size 128k;proxy_next_upstream error timeout invalid_header http_500 http_503 http_404;#对特定的请求使用缓存location ~ .*.(jpg|png|gif|css|js|html|ttf|svg)$ {proxy_cache cache_one;proxy_pass http://oa.zhihuikg.com;proxy_set_header X-Real-IP $remote_addr;proxy_set_header REMOTE-HOST $remote_addr;proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;}}
 }
 

 


标签:

素材巴巴 Copyright © 2013-2021 http://www.sucaibaba.com/. Some Rights Reserved. 备案号:备案中。