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

 更新时间:2024年01月25日 10:51:32   作者:fkjavaer  
这篇文章主要介绍了使用Nginx配置浏览器缓存,页面展示更快一步问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

1.简介

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

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

Nginx不仅仅是一个web服务器,它也是一个web缓存服务器。

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

web缓存通常有以下分类:

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

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

2.浏览器缓存

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

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

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

  • 浏览器为什么要对资源进行缓存
  • 浏览器获取缓存的流程

1)浏览器为什么要对资源进行缓存呢?

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

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

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

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

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

header示例说明
Etag“6459ce31-15499”资源的哈希码
Last-ModifiedTue, 09 May 2023 04:38:09 GMT用于表示资源最后修改时间
If-None-Match“6459ce31-15499”将当前资源的哈希码发送给服务器进行匹配
If-Modified-SinceTue, 09 May 2023 04:38:09 GMT将当前资源的最后修改时间发送给服务器进行匹配

了解流程之后,我们来具体演示一下。访问页面:http://192.168.110.98/jquery.js

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 epochExpires:Thu, 01 Jan 1970 00:00:01 GMTCache_Control:no-cache不缓存
expires maxExpires:Thu, 31 Dec 2037 23:55:55 GMTmax-age=315360000缓存10年
expires off响应头不添加Expires和Cache-Control

总结

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

这些仅为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Nginx配置后请求报404的几种问题解决方法

    Nginx配置后请求报404的几种问题解决方法

    本文主要介绍了Nginx配置后请求报404的两种常见问题及其解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2025-02-02
  • kubernetes启用PHP+Nginx网页环境教程

    kubernetes启用PHP+Nginx网页环境教程

    这篇文章主要介绍了kubernetes启用PHP+Nginx网页环境教程,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-10-10
  • nginx配置location方法总结

    nginx配置location方法总结

    这篇文章主要介绍了nginx配置location方法总结,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2019-01-01
  • NGINX配置目录遍历漏洞的解决

    NGINX配置目录遍历漏洞的解决

    目录遍历是一种安全漏洞,通常会影响Nginx服务器上的Web应用程序,本文就来介绍一下NGINX配置目录遍历漏洞的解决,感兴趣的可以了解一下
    2023-10-10
  • Nginx和GeoIP模块读取IP所在的地域信息方法

    Nginx和GeoIP模块读取IP所在的地域信息方法

    今天小编就为大家分享一篇Nginx和GeoIP模块读取IP所在的地域信息方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-08-08
  • Nginx防盗链根据UA屏蔽恶意User Agent请求(防蜘蛛)

    Nginx防盗链根据UA屏蔽恶意User Agent请求(防蜘蛛)

    相对于 Apache,Nginx 占用的系统资源更少,更适合 VPS 使用。恶意盗链的 User Agent 无处不在,博客更换到 WordPress 没几天,就被 SPAM(垃圾留言)盯上,又被暴力破解后台用户名密码。今天来介绍 Nginx 屏蔽恶意 User Agent请求的方法
    2016-07-07
  • Nginx Rewrite及Location的使用与区别

    Nginx Rewrite及Location的使用与区别

    rewrite和location的功能有点相像,都能实现跳转,本文主要介绍了Nginx Rewrite及Location的使用与区别,具有一定的参考价值,感兴趣的可以了解一下
    2023-08-08
  • 利用nginx解决cookie跨域访问的方法

    利用nginx解决cookie跨域访问的方法

    本篇文章主要介绍了利用nginx解决cookie跨域访问的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-05-05
  • Nginx为静态资源配置缓存时间的操作步骤

    Nginx为静态资源配置缓存时间的操作步骤

    最近在优化网站性能时,发现很多静态资源(比如图片、CSS 文件等)每次都会从服务器重新加载,这不仅浪费了带宽,还增加了 服务器的负载,为了解决这个问题,我研究了一下如何在 Nginx 中为静态资源配置缓存时间,下面是我的配置过程,需要的朋友可以参考下
    2025-02-02
  • Nginx开启Gzip压缩大幅提高页面加载速度的方法

    Nginx开启Gzip压缩大幅提高页面加载速度的方法

    这篇文章主要介绍了Nginx开启Gzip压缩大幅提高页面加载速度的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-08-08

最新评论