龙空技术网

Nginx配置浏览器缓存,页面展示更快一步

Java狂人 422

前言:

现时咱们对“nginx缓存怎么看”大概比较关注,姐妹们都需要剖析一些“nginx缓存怎么看”的相关内容。那么小编在网上汇集了一些有关“nginx缓存怎么看””的相关知识,希望咱们能喜欢,各位老铁们快快来了解一下吧!

1.简介

缓存能够存储请求的响应结果,可以很方便的再次访问,使用缓存的优点是很明显的。

加速内容的访问,降低响应时间减少服务器的负载

Nginx不仅仅是一个web服务器,它也是一个web缓存服务器。通过Nginx缓存,我们对一些静态资源或者更新频率低的数据做缓存,降低请求的响应时间,同时也能降低服务器的负载,一举多得。

web缓存通常有以下分类:

客户端缓存(浏览器缓存等)服务器缓存(Nginx缓存、Redis缓存等)

我们将着重介绍浏览器缓存

2.浏览器缓存

B/S架构是一种很流行的软件架构,浏览器在这种架构中扮演着极其重要的角色。

在使用浏览器的过程中,要刷新页面,可以使用快捷键F5刷新,这个时候有些小伙伴可能会遇到页面信息并没有刷新的情况,这就是浏览器缓存在“作祟”,这个时候我们需要强制刷新(Ctrl + F5),才能够越过浏览器缓存获取最新的数据。

对于浏览器缓存,有以下几个关键点:

浏览器为什么要对资源进行缓存浏览器获取缓存的流程1)浏览器为什么要对资源进行缓存呢?

为了节约网络资源,加速访问,浏览器会在用户磁盘上对最近访问的页面的资源进行存储,当再次访问该页面时,浏览器就可以从磁盘缓存中加载这些资源,避免频繁向服务器发起请求,这样可以加速页面的展示,并降低服务器的负载。

2)浏览器获取缓存的流程

既然浏览器可以将页面的资源缓存到本地磁盘,那么浏览器又是怎么去加载这些缓存资源的呢?

下面这张图就是具体流程:

图里面存在几个header的定义:

header

示例

说明

Etag

"6459ce31-15499"

资源的哈希码

Last-Modified

Tue, 09 May 2023 04:38:09 GMT

用于表示资源最后修改时间

If-None-Match

"6459ce31-15499"

将当前资源的哈希码发送给服务器进行匹配

If-Modified-Since

Tue, 09 May 2023 04:38:09 GMT

将当前资源的最后修改时间发送给服务器进行匹配

了解流程之后,我们来具体演示一下。访问页面:

1)第一次访问,没有缓存,响应状态码:200,资源大小87.5kb

请求头信息:

响应头信息:

2)新建标签页访问,响应状态码:200,资源来自disk cache,说明是直接加载的磁盘缓存

3)F5刷新页面,状态304,资源大小182B,说明会向web服务器发送请求,服务器响应304,因此浏览器去磁盘缓存加载资源。

Tips:F5刷新页面,会让浏览器认为缓存已过期,因此会走缓存已过期的流程。Ctrl+F5强制刷新页面,会直接跳过浏览器缓存。

请求头信息:

相比第一次访问时,多了两个header:If-Modified-SinceIf-None-Match

3)Nginx对浏览器缓存的配置

前面,在看浏览器获取缓存的流程时,有一步是请求响应,缓存协商,这就涉及到nginx的一些配置指令。

ngx_http_headers_module模块中,该模块可以将ExpiresCache-Control添加到响应头中,供浏览器使用,我们可以对其进行配置。主要的指令如下:

作用域:http, server, location, if in location

语法:expires [modified] time; expires epoch | max | off;

默认值expires off;

1)expires [modified] time;

time可以为正数,也可以为负数,默认单位为秒。

如果为负数,则响应为:Cache-Control:no-cache,即不缓存如果为正数或0,则响应为:Cache-Control:max-age=time

示例:设置缓存过期时间10s

location /jquery {    gzip_types application/javascript;    gzip_min_length 20;    # 缓存过期时间10s    expires 10;    root   html;}

发送请求,查看结果,和预期保持一致。Date和Expires的时间也是相差10s。

2) expires epoch | max | off;

指令

响应头

expires epoch

Expires:Thu, 01 Jan 1970 00:00:01 GMT Cache_Control:no-cache

expires max

Expires:Thu, 31 Dec 2037 23:55:55 GMT max-age=315360000

expires off

响应头不添加Expires和Cache-Control

以上就是Nginx对浏览器缓存的配置,Nginx是多模块化的,还有很多高级功能,我们后面继续探索。

标签: #nginx缓存怎么看