全面解读 HTTP 缓存机制:200 内存与硬盘缓存、304 状态码

2024-09-02 22:28

本文主要是介绍全面解读 HTTP 缓存机制:200 内存与硬盘缓存、304 状态码,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

更多内容:孔乙己大叔

        在探讨网页性能优化时,HTTP 缓存机制是不可或缺的一环。它不仅能够减少数据传输量,降低带宽消耗,还能显著提升网页的加载速度和用户体验。本文将深入解析 HTTP 状态码 200 和 304 在缓存机制中的作用,并通过 Nginx 的配置示例展示如何实现高效的静态资源缓存。

一、HTTP 状态码 200 与缓存机制

        HTTP 状态码 200(OK)是 HTTP 协议中最常见的成功响应代码,表示服务器成功处理了请求,并返回了所请求的资源。在缓存机制的上下文中,HTTP 状态码 200 涉及多种资源加载方式,包括首次请求、内存缓存和磁盘缓存。

1.1 HTTP 状态码 200 详解

1. 请求成功

        当浏览器首次请求某个资源时,如加载一个网页、图片或其他文件,服务器会返回 200 状态码,表示资源已成功传输且没有问题。例如,打开一个新的网页时,浏览器会向服务器请求 HTML、CSS 和 JavaScript 文件,服务器返回 200 状态码并传输这些文件,浏览器进行渲染以显示网页内容。

2. 内存缓存

        资源成功请求并返回 200 状态码后,浏览器会将这些资源存储在内存缓存中。内存缓存的优点在于速度快,能够迅速响应用户的请求,适合存储需要频繁访问的资源。然而,其缺点是内容在浏览器关闭或页面刷新后会被清除,因此适用于会话期间需要频繁访问的资源。

        例如,访问新闻网站的首页时,其中包含多张图片和样式表。点击新闻链接切换到详细页面时,浏览器会利用内存缓存中的图片和样式表来加速页面加载。

3. 磁盘缓存

        除了内存缓存,浏览器还会将资源存储在磁盘缓存中。磁盘缓存的优点在于可以长期保存资源,减少带宽消耗,但访问速度比内存缓存慢。因此,磁盘缓存适合存储长期需要保留的资源,如图片、样式表和脚本文件等。

        例如,访问购物网站并下载商品图片和样式表后,这些资源会被存储在磁盘缓存中。即使关闭浏览器后重新访问该网站,浏览器也会从磁盘缓存中读取这些资源,加快页面显示速度。

1.2 HTTP 状态码 200 与服务器交互情况

        在浏览器加载资源的过程中,HTTP 状态码 200 表示资源已成功从服务器获取。具体交互情况如下:

1. 首次请求

        浏览器首次请求资源时,由于缓存中不存在该资源,浏览器会向服务器发送 HTTP 请求。服务器处理请求后返回 200 状态码和资源,完成一次完整的 HTTP 请求-响应循环。

2. 内存缓存

        在同一会话期间再次请求相同资源时,浏览器会首先检查内存缓存。如果资源在内存缓存中,浏览器将直接从内存中加载资源,无需与服务器交互。这种方式访问速度非常快,因为内存缓存存储在 RAM 中。

3. 磁盘缓存

                如果资源不在内存缓存中,浏览器会继续检查磁盘缓存。如果资源存在于磁盘缓存中,浏览器会直接从磁盘中加载资源,同样无需与服务器交互。磁盘缓存的访问速度虽然比内存缓存慢,但能够长期保存资源,减少重复下载。

4. 与服务器交互的区别

在首次请求中,浏览器必须与服务器交互以获取资源。在内存缓存和磁盘缓存的情况下,浏览器则直接从本地缓存中加载资源,无需与服务器交互。但如果资源在缓存中不存在或已过期,浏览器仍需与服务器交互以重新获取资源。此时,服务器可能返回 200 状态码(资源需重新传输)或 304 状态码(资源未修改)。

二、HTTP 状态码 304 与缓存机制

        HTTP 状态码 304(Not Modified)表示资源未修改,即所请求的资源自上次请求以来没有发生任何变化。这种状态码与浏览器的缓存机制密切相关,通过减少不必要的数据传输来提升性能。

2.1 HTTP 状态码 304 基本概念

        HTTP 状态码 304 是一种重定向状态码,但它并不真正重定向到另一个资源。相反,它告诉客户端可以继续使用其本地缓存的副本,因为服务器上的资源自上次请求以来没有变化。这减少了带宽消耗,提升了加载速度。

2.2 HTTP 状态码 304 的缓存机制

        当浏览器请求某个资源时,它会检查本地缓存中是否有该资源的副本。如果有,并且资源未过期,浏览器将直接使用缓存资源;如果已过期,浏览器需要向服务器确认资源是否有更新。

浏览器通过发送带有验证信息的请求(如 ETag 或 Last-Modified)来向服务器确认资源状态。服务器根据这些验证信息判断资源是否发生了变化:

  • ETag:由服务器生成的资源唯一标识符,通常是一个哈希值或唯一标识符,用于标记资源的版本。浏览器在请求中通过 If-None-Match 头字段发送 ETag 值,服务器将请求中的 ETag 值与当前资源的 ETag 值进行比较。
  • Last-Modified:表示服务器上资源的最后修改时间。浏览器在请求中通过 If-Modified-Since 头字段发送 Last-Modified 时间戳,服务器会比较请求中的时间戳与资源的实际最后修改时间。

服务器根据比较结果作出响应:

  • 如果资源未改变,服务器返回 304 状态码,不包含任何消息体。浏览器从本地缓存加载资源并渲染页面。
  • 如果资源已改变,服务器返回 200 状态码和更新后的资源内容。浏览器更新缓存并渲染新资源。
2.3 完整的工作流程

以下是 HTTP 状态码 304 缓存机制的完整工作流程:

  1. 浏览器请求资源。
  2. 浏览器检查本地缓存中是否有该资源的副本。
  3. 如果资源在缓存中且未过期,浏览器直接使用缓存资源。
  4. 如果资源已过期,浏览器向服务器发送带有验证信息的请求(ETag 或 Last-Modified)。
  5. 服务器根据验证信息判断资源是否发生变化。
  6. 如果资源未改变,服务器返回 304 状态码,浏览器从缓存加载资源。
  7. 如果资源已改变,服务器返回 200 状态码和更新后的资源,浏览器更新缓存并渲染新资源。
2.4 缓存机制的优势

HTTP 状态码 304 的缓存机制具有以下优势:

  • 减少带宽使用:未修改的资源不会重复下载,降低了带宽消耗。
  • 提高加载速度:浏览器可以直接从本地缓存中加载资源,提升了网页的加载速度。
  • 减轻服务器负担:减少了服务器处理请求的频率和数据传输量,提高了服务器的处理效率。
孔乙己大叔您的一站式代码技术资源中心。我们汇集了各种编程语言的教程、最佳实践和行业解决方案,帮助您轻松掌握最新技术。此外,我们还提供了一系列实用的开发者工具和代码库,助您提升开发效率。立即访问,探索更多精彩内容!icon-default.png?t=N7T8http://www.rebootvip.com/

这篇关于全面解读 HTTP 缓存机制:200 内存与硬盘缓存、304 状态码的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1131240

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

NameNode内存生产配置

Hadoop2.x 系列,配置 NameNode 内存 NameNode 内存默认 2000m ,如果服务器内存 4G , NameNode 内存可以配置 3g 。在 hadoop-env.sh 文件中配置如下。 HADOOP_NAMENODE_OPTS=-Xmx3072m Hadoop3.x 系列,配置 Nam

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

hdu1565(状态压缩)

本人第一道ac的状态压缩dp,这题的数据非常水,很容易过 题意:在n*n的矩阵中选数字使得不存在任意两个数字相邻,求最大值 解题思路: 一、因为在1<<20中有很多状态是无效的,所以第一步是选择有效状态,存到cnt[]数组中 二、dp[i][j]表示到第i行的状态cnt[j]所能得到的最大值,状态转移方程dp[i][j] = max(dp[i][j],dp[i-1][k]) ,其中k满足c

缓存雪崩问题

缓存雪崩是缓存中大量key失效后当高并发到来时导致大量请求到数据库,瞬间耗尽数据库资源,导致数据库无法使用。 解决方案: 1、使用锁进行控制 2、对同一类型信息的key设置不同的过期时间 3、缓存预热 1. 什么是缓存雪崩 缓存雪崩是指在短时间内,大量缓存数据同时失效,导致所有请求直接涌向数据库,瞬间增加数据库的负载压力,可能导致数据库性能下降甚至崩溃。这种情况往往发生在缓存中大量 k

MCU7.keil中build产生的hex文件解读

1.hex文件大致解读 闲来无事,查看了MCU6.用keil新建项目的hex文件 用FlexHex打开 给我的第一印象是:经过软件的解释之后,发现这些数据排列地十分整齐 :02000F0080FE71:03000000020003F8:0C000300787FE4F6D8FD75810702000F3D:00000001FF 把解释后的数据当作十六进制来观察 1.每一行数据

Java ArrayList扩容机制 (源码解读)

结论:初始长度为10,若所需长度小于1.5倍原长度,则按照1.5倍扩容。若不够用则按照所需长度扩容。 一. 明确类内部重要变量含义         1:数组默认长度         2:这是一个共享的空数组实例,用于明确创建长度为0时的ArrayList ,比如通过 new ArrayList<>(0),ArrayList 内部的数组 elementData 会指向这个 EMPTY_EL

BUUCTF靶场[web][极客大挑战 2019]Http、[HCTF 2018]admin

目录   [web][极客大挑战 2019]Http 考点:Referer协议、UA协议、X-Forwarded-For协议 [web][HCTF 2018]admin 考点:弱密码字典爆破 四种方法:   [web][极客大挑战 2019]Http 考点:Referer协议、UA协议、X-Forwarded-For协议 访问环境 老规矩,我们先查看源代码

状态dp总结

zoj 3631  N 个数中选若干数和(只能选一次)<=M 的最大值 const int Max_N = 38 ;int a[1<<16] , b[1<<16] , x[Max_N] , e[Max_N] ;void GetNum(int g[] , int n , int s[] , int &m){ int i , j , t ;m = 0 ;for(i = 0 ;

【编程底层思考】垃圾收集机制,GC算法,垃圾收集器类型概述

Java的垃圾收集(Garbage Collection,GC)机制是Java语言的一大特色,它负责自动管理内存的回收,释放不再使用的对象所占用的内存。以下是对Java垃圾收集机制的详细介绍: 一、垃圾收集机制概述: 对象存活判断:垃圾收集器定期检查堆内存中的对象,判断哪些对象是“垃圾”,即不再被任何引用链直接或间接引用的对象。内存回收:将判断为垃圾的对象占用的内存进行回收,以便重新使用。