Nginx 缓存那些事儿:原理、配置和最佳实践

Nginx 缓存那些事儿:原理、配置和最佳实践

在当今的互联网世界,网站的访问量和数据处理量不断攀升,如何确保用户能够快速、稳定地访问我们的网站,已经成为每个运维工程师面临的挑战。幸运的是,Nginx 作为一款高性能的反向代理服务器,能够帮助我们轻松应对这一挑战,不仅能处理大量的请求,还能作为缓存服务器来提高系统性能,减轻后端服务器的压力。


一、Nginx 缓存的工作原理

要理解 Nginx 如何作为缓存服务器工作,我们可以通过一个实际的请求流程来讲解:

1. 客户端发起请求

假设你访问的是 http://www.example.com/index.html,浏览器向 Nginx 发送请求。

2. Nginx 检查缓存

在接到请求后,Nginx 会首先检查缓存目录(比如 /var/cache/nginx)是否已经存储了这个请求的缓存。如果这个请求的响应数据已经缓存过,并且没有过期,Nginx 就会直接从缓存中读取响应,返回给客户端。

  • 缓存命中:如果缓存中有该内容,并且缓存没有过期,Nginx 会直接返回缓存中的数据,响应速度非常快,几乎不需要与后端通信。

  • 缓存未命中:如果缓存中没有找到该内容,或者缓存已过期,Nginx 就会将请求转发到后端服务器。

3. 转发请求到后端

如果缓存未命中,Nginx 会把请求转发给后端的应用服务器,后端服务器会处理请求并返回响应数据。

4. 缓存响应并保存到本地

当 Nginx 接收到后端返回的响应数据时,它会将这些数据存储到本地缓存目录,等待下一次相同请求到来时直接从缓存中取出。

5. 返回数据给客户端

不管缓存是否命中,Nginx 最终都会将响应数据返回给客户端,这样用户就能够看到自己请求的页面内容。

6. 后续请求命中缓存

如果其他用户或者相同用户在一段时间内再次访问相同的 URL,Nginx 就会直接从缓存中返回数据,避免再次访问后端,从而提高响应速度,减少后端服务器的压力。


二、缓存目录的生成规则

那么,Nginx 是如何管理这些缓存文件的呢?它是通过哈希值来决定缓存文件的存储路径的。下面我们详细看看这个过程:

1. 缓存目录结构

我们在配置 Nginx 缓存时,通常会使用 proxy_cache_path 指定缓存存储的路径。例如:

proxy_cache_path /var/cache/nginx levels=1:2 keys_zone=cache_zone:10m inactive=60m max_size=1g;
  • levels=1:2:这表示 Nginx 会根据缓存文件的哈希值生成多层目录结构。第一层目录由哈希值的最后 1 位字符组成,第二层目录由哈希值的倒数第 2 和第 3 位字符组成。

    举个例子,如果 URL http://www.example.com/index.html 的 MD5 哈希值是 a3f8d2fbe0dca4dbec3ed5a033dbfbe0295b1b5a,那么缓存路径的目录结构会是:

    /var/cache/nginx/a/5b/a3f8d2fbe0dca4dbec3ed5a033dbfbe0295b1b5a
    
    • 第一层目录 a 是哈希值的最后 1 位字符
    • 第二层目录 5b 是哈希值倒数第 2 和第 3 位字符。
    • 文件名则是哈希值的完整值,a3f8d2fbe0dca4dbec3ed5a033dbfbe0295b1b5a
  • keys_zone=cache_zone:10m:这里定义了一个名为 cache_zone 的内存区域,大小为 10MB,用于存储缓存的元数据,比如缓存的文件名、大小、过期时间等。

  • inactive=60m:表示如果缓存 60 分钟内没有被访问,它将被自动删除。

  • max_size=1g:指定缓存目录的最大大小为 1GB,一旦超过这个大小,Nginx 会自动清理一些不常访问的缓存文件。

2. 缓存文件的命名和存储

Nginx 会根据请求的 URL 生成一个唯一的哈希值,并将缓存文件存储在相应的目录下。哈希值确保每个 URL 对应的缓存文件是唯一的,避免文件冲突。

3. 缓存文件的生命周期

缓存文件并不会永远存在,它们有自己的“生命周期”。比如,我们在上述配置中设置了 inactive=60m,意味着如果 60 分钟内没有请求访问该缓存文件,它会被删除。同时,通过 max_size=1g 限制了缓存目录的最大容量,超出限制后,Nginx 会清理掉最早没有被访问的缓存文件。


三、Nginx 缓存的使用场景

那么,Nginx 缓存到底适合在哪些场景下使用呢?下面我总结了几个常见的应用场景:

1. 缓存静态资源

对于静态资源(如图片、CSS、JavaScript 文件等),缓存可以显著提高访问速度,因为这些资源一般不会频繁变动,且被多次请求。使用 Nginx 缓存静态资源可以避免每次请求都访问后端服务器,从而减少带宽消耗和服务器负担。

2. 缓存动态生成的页面

一些动态页面(比如新闻网站的首页、商品详情页等),虽然是动态生成的,但更新频率较低。你可以为这些页面设置缓存,避免每次请求都需要访问数据库或进行复杂的计算。比如可以缓存 10 分钟或 1 小时,从而减轻后端服务器的压力。

3. 减轻后端负担

对于一些高并发的网站,后端服务器可能会因为请求过多而变得非常繁忙。Nginx 缓存可以帮助你减轻这种压力,尤其是对于一些热门页面的请求,通过缓存可以大幅提升响应速度。

4. 节省带宽和提高性能

如果你的网站有大量用户访问相同的页面或资源,通过缓存,不仅可以节省带宽消耗,还能提高整体的性能,尤其是在高并发的情况下,能够有效提升用户体验。


四、Nginx 缓存配置实战

接下来,让我们通过一个简单的实例,来看看如何在 Nginx 中配置缓存。

1. 配置缓存路径

http {proxy_cache_path /var/cache/nginx levels=1:2 keys_zone=cache_zone:10m inactive=60m max_size=1g;
}

这里我们指定了缓存路径 /var/cache/nginx,并设置了缓存的层级、大小、过期时间等参数。

2. 配置缓存策略

server {listen 80;server_name www.example.com;location / {proxy_cache cache_zone;  # 启用缓存proxy_cache_valid 200 10m;  # 对 200 状态码的响应缓存 10 分钟proxy_cache_valid 404 1m;   # 对 404 状态码的响应缓存 1 分钟add_header X-Cache-Status $upstream_cache_status;  # 显示缓存状态proxy_pass http://backend.example.com;  # 转发请求到后端服务器# 设置头部信息proxy_set_header Host $host;proxy_set_header X-Real-IP $remote_addr;proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;# 忽略后端的缓存控制头proxy_ignore_headers Cache-Control Expires;}
}

这里,我们为 www.example.com 配置了缓存策略。所有的请求都会经过缓存,如果缓存命中,则直接返回缓存的内容。如果没有命中,则从后端获取并缓存。


结语

相信你对 Nginx 作为缓存服务器的工作原理、配置方法以及缓存的使用场景有了更清晰的认识。通过合理配置缓存,不仅能够提高网站的访问速度,减轻后端服务器的压力,还能提高整个系统的性能和可扩展性。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/63783.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【智体OS】官方上新发布智体电视:基于rtpc和rttouchpad实现智体电视的手机遥控-可安装任意PC应用用于智体电视

【智体OS】官方上新发布智体电视:基于rtpc和rttouchpad实现智体电视的手机遥控-可安装任意PC应用用于智体电视 dtns.network是一款主要由JavaScript编写的智体世界引擎(内嵌了three.js编辑器的定制版-支持以第一视角浏览3D场馆),…

ES(elasticsearch)整合Spring boot使用实例

1.1通过docker安装es详细教程参考 docker部署elasticsearch(内涵集群部署的compose文件)-CSDN博客 2.1创建MySQL数据库,通过sql命令进行表的创建与数据的写入(sql命令如下) /*Navicat Premium Data TransferSource Server : localSo…

GitHub使用

太久不用GitHub发现自己又有些不会了,突发奇想为何不把每次看到的有指导意义的博客收录一下以便下次查阅呢 如何上传文件夹到GitHub上(配图详解)?_github上傳資料夾-CSDN博客 github上如何删除自己的仓库_github删除仓库-CSDN博…

单独测试 pyautogui 的鼠标点击功能,确保它能够在当前环境中正常工作,鼠标自动点击的录制回放功能

感谢您提供的详细日志信息。根据您的反馈,问题可能出在 pyautogui 没有正确获取鼠标焦点或无法在预期的位置执行点击操作。我们将采取以下步骤来进一步诊断和解决这个问题: 1. **确保 pyautogui 正确执行点击操作**: - 我们将添加更多的调…

保姆级教学 uniapp绘制二维码海报并保存至相册,真机正常展示图片二维码

一、获取二维码 uni.request({url: https://api.weixin.qq.com/wxa/getwxacode?access_token${getStorage("token")},responseType: "arraybuffer",method: "POST",data: {path: "/pages/index/index"},success(res) {// 转换为 Uint…

coco数据集转换SAM2格式

coco是一个大json汇总了所有train的标签 SAM2训练一张图对应一个json标签 import json import os from pycocotools import mask as mask_utils import numpy as np import cv2def poly2mask(points, width, height):points_array np.array(points, dtypenp.int32).reshape(-…

Vue.createApp的对象参数

目录 template 属性 data 属性 methods 属性 疑问 function 函数的两种写法 methods 属性中 this 的指向 总结 Vue 实例是通过 Vue.createApp() 创建的,该函数需要接收一个对象作为参数,该对象可添加 template、data、methods 等属性。 template …

LLM大语言模型私有化部署-OpenEuler22.03SP3上容器化部署Ollama与OpenWebUI

背景 你是不是也有私有化部署大模型的需求?如今有了 Ollama , HuggingFace , ModelScope 等开源平台,我们可以非常方便地搭建一个属于自己的大模型,如果网速给力,真是分分钟~~。简单起见,这篇文…

使用字典进行动态编程

在你的程序中,你想要执行各种计算,例如计算卫星的总数。 此外,当你进行更高级的编程时,你可能会发现你需要从文件或数据库中加载此类信息,而不是直接编码到 Python 中。 为了帮助支持这些场景,Python 使你…

Linux——rootfs根文件系统构建

根文件系统也叫做rootfs FATFS这类的文件系统属于Linux内核的一部分,属于软件代码,所以ROOTFS不等于FATFS。 Linux的根文件系统实际上是一个文件夹或者叫目录,这个目录下会有许多子目录,这些目录中存放许多Linux运行所必须的文件…

go语言的成神之路-标准库篇-os标准库

一、权限 在操作系统(OS)中,标准库的权限管理是非常重要的,它确保了不同用户和进程能够安全地访问系统资源。以下是一些常见的权限概念和说明: 1.用户权限 用户ID(UID):每个用户在…

linux 生成 nginx 的https ssl 证书详解

证书生成 1. 生成证书 会提示输入密码,输入两次相同密码即可。 openssl genrsa -des3 -out server.key 20482. 去除密码校验 如果想去除此输密码的步骤,可以执行如下命令,根据使用需求选择。 openssl rsa -in server.key -out server.ke…

LabVIEW实现MQTT通信

目录 1、MQTT通信原理 2、硬件环境部署 3、云端环境部署 4、程序架构 5、前面板设计 6、程序框图设计 7、测试验证 本专栏以LabVIEW为开发平台,讲解物联网通信组网原理与开发方法,覆盖RS232、TCP、MQTT、蓝牙、Wi-Fi、NB-IoT等协议。 结合实际案例,展示如何利用LabVIEW和常用…

【OpenCV】直方图

理论 可以将直方图视为图形或曲线图,从而使您对图像的强度分布有一个整体的了解。它是在X轴上具有像素值(不总是从0到255的范围),在Y轴上具有图像中相应像素数的图。 这只是理解图像的另一种方式。通过查看图像的直方图,您可以直观地了解该…

【PlantUML系列】用例图(三)

目录 一、组成部分 二、典型案例 一、组成部分 参与者(Actors):使用关键字 actor 后跟参与者的名称。用例(Use Cases):使用关键字 usecase 后跟用例的名称和编号(可选)。系统边界…

Transformer部分知识点解释

传统Transformer 经典QKV算法 Transformer架构的优势与问题 万能模型,直接套用,代码实现简单,现成例子一大片并行的,比LSTM快,全局信息丰富,注意力机制效果好长序列中attention需要每一个点跟其他点计算(…

docker-compose 之 禅道(zentao) 社区版

docker-compose 关于 zentao 的配置片段如下所示: 镜像使用的官方镜像:https://hub.docker.com/r/easysoft/zentao zentao: image: easysoft/zentao:21.2container_name: zentaoports: - "8088:80"- "23306:3306"environment:TZ: A…

聚类及Python下实现 K-means 算法

聚类 聚类是无监督学习中的一种重要方法,旨在将数据集中相似的数据对象划分到同一个簇中,使得不同簇之间的数据对象差异尽可能大。在大数据环境下,聚类可以帮助挖掘数据中的隐藏结构和模式,应用场景十分广泛,比如在客…

LabVIEW调用Thorlabs的动态库进行开发

Thorlabs 产品在科研与生产领域中的应用广泛,当需要基于LabVIEW 进行二次开发时,可按照以下方法操作,以充分发挥设备性能并满足特定的项目需求。 创建 Kinesis LabVIEW 项目文件和文件夹 更详细的说明参见附件 在 LabVIEW 的启动界面中选择…

SQL中的通配符:使用LIKE操作符进行模式匹配

在SQL中,LIKE 操作符用于在查询中进行模式匹配。它常用于 WHERE 子句中,以便根据特定模式查找数据。与直接进行精确匹配的 操作符不同,LIKE 允许你使用通配符来对数据进行模糊查询,从而使查询更加灵活和强大。 常见的SQL通配符 …