当前位置: 首页 > article >正文

Next.js第八课 - 缓存机制

前面几节我们学习了数据获取和数据变更本节来深入了解 Next.js 的缓存机制。缓存是提升应用性能的关键技术用好了能让你的应用速度提升好几倍。缓存架构Next.js 使用多层缓存来优化性能理解这个架构很重要请求流程: 浏览器 → CDN/边缘缓存 → Next.js 数据缓存 → 数据源缓存层级浏览器缓存 - 客户端存储CDN/边缘缓存 - Vercel Edge NetworkNext.js 数据缓存 - 服务器端缓存完全动态请求 - 每次都获取新数据每一层缓存都有自己的作用合理配置能让应用性能最优。数据缓存默认缓存行为在 Next.js 中fetch请求默认会被缓存// 默认缓存 export default async function Page() { const res await fetch(https://api.example.com/data) const data await res.json() return div{data.title}/div }缓存选项禁用缓存如果需要实时数据可以完全禁用缓存export default async function Page() { const res await fetch(https://api.example.com/data, { cache: no-store, }) const data await res.json() return div{data.title}/div }设置缓存时间最常用的是设置缓存过期时间export default async function Page() { // 缓存 10 秒 const res await fetch(https://api.example.com/data, { next: { revalidate: 10 }, }) const data await res.json() return div{data.title}/div }基于标签的缓存标签缓存是一个很强大的特性它允许你按标签批量清除缓存。添加缓存标签export default async function PostsPage() { const posts await fetch(https://api.example.com/posts, { next: { tags: [posts, blog] }, }).then((res) res.json()) return PostList posts{posts} / }重新验证标签当数据更新时可以按标签清除缓存use server import { revalidateTag } from next/cache export async function createPost() { // 创建新文章 await db.post.create({ /* ... */ }) // 重新验证所有带 posts 标签的缓存 revalidateTag(posts) }多个标签一个请求可以有多个标签// 获取时添加多个标签 const data await fetch(https://api.com/dashboard, { next: { tags: [dashboard, analytics, user-123] }, }) // 可以单独重新验证 revalidateTag(dashboard) revalidateTag(analytics)基于路径的缓存除了标签还可以按路径重新验证缓存use server import { revalidatePath } from next/cache export async function updatePost(id: string, data: FormData) { // 更新文章 await db.post.update({ where: { id }, data: { title: data.get(title) }, }) // 重新验证相关页面 revalidatePath(/posts) revalidatePath(/posts/${id}) revalidatePath(/) // 首页也可能显示文章 }时间基础重新验证页面级配置整个页面设置缓存时间// app/posts/page.tsx export const revalidate 3600 // 1 小时 export default async function PostsPage() { const posts await getPosts() return PostList posts{posts} / }特定请求配置不同请求使用不同的缓存策略async function getFreshData() { const res await fetch(https://api.com/data, { next: { revalidate: 0 }, }) return res.json() } async function getCachedData() { const res await fetch(https://api.com/data, { next: { revalidate: 3600 }, }) return res.json() }缓存策略根据数据特性选择合适的缓存策略静态内容适合博客文章、产品页面等不经常变化的内容// 适合博客文章、产品页面 export const revalidate 3600 // 1 小时 export default async function BlogPage() { const posts await fetch(https://api.com/posts, { next: { revalidate: 3600 }, }).then((res) res.json()) return PostList posts{posts} / }动态内容适合用户数据、实时统计等需要最新数据的内容// 适合用户数据、实时统计 export const dynamic force-dynamic export default async function DashboardPage() { const stats await fetch(https://api.com/stats, { cache: no-store, }).then((res) res.json()) return Stats data{stats} / }按需重新验证适合内容更新不频繁但需要快速生效的场景// 适合内容更新不频繁 export const revalidate 86400 // 24 小时 // 当内容更新时手动触发 // app/api/revalidate/route.ts import { revalidateTag } from next/cache export async function POST(request: Request) { const { tag } await request.json() revalidateTag(tag) return Response.json({ revalidated: true }) }缓存实用技巧这里分享几个在缓存配置中特别实用的技巧。根据数据特性选择策略实际开发中,根据数据更新频率选择合适的缓存策略特别重要:// 静态内容可以长时间缓存 export const revalidate 86400 // 24 小时 const staticData await fetch(https://api.com/static, { next: { revalidate: 86400 }, }) // 频繁更新的内容建议短时间缓存 const frequentlyUpdated await fetch(https://api.com/frequent, { next: { revalidate: 60 }, }) // 实时数据最好不缓存 const realtimeData await fetch(https://api.com/realtime, { cache: no-store, })使用标签进行精确控制这个技巧在实际项目中特别有用——使用标签可以更精确地控制缓存:// 推荐这样做 - 使用标签进行精确控制 const posts await fetch(https://api.com/posts, { next: { tags: [posts, blog] }, }) // 当创建新文章时,只重新验证相关缓存 revalidateTag(posts) // 尽量避免这种情况 - 使用路径可能重新验证过多内容 revalidatePath(/posts)分层缓存策略这里有个小建议:不同层级可以使用不同的缓存时间,这样更灵活:// 页面级别使用较长缓存 export const revalidate 3600 // 组件级别使用较短缓存 async function PostList() { const posts await fetch(https://api.com/posts, { next: { revalidate: 600 }, }) return div{/* ... */}/div } // 实时数据调用不缓存 async function getUserActivity() { const activity await fetch(https://api.com/activity, { cache: no-store, }) return div{/* ... */}/div }不同场景的缓存策略电商网站// 产品列表 - 中等缓存 export const revalidate 1800 // 30 分钟 // 产品详情 - 短缓存库存可能变化 export const revalidate 60 // 1 分钟 // 用户购物车 - 不缓存 export const dynamic force-dynamic // 静态内容关于页面等- 长缓存 export const revalidate 86400 // 24 小时新闻网站// 文章列表 - 短缓存 export const revalidate 300 // 5 分钟 // 文章详情 - 发布后不变化 export const revalidate 86400 // 24 小时 // 实时新闻 - 不缓存 export const dynamic force-dynamic社交媒体// 用户资料 - 中等缓存 export const revalidate 600 // 10 分钟 // 用户帖子 - 短缓存 export const revalidate 60 // 1 分钟 // 通知 - 不缓存 export const dynamic force-dynamic总结本节我们深入了解了 Next.js 的缓存机制包括多层缓存架构、基于标签和路径的缓存、不同的缓存策略等。合理使用缓存能让你的应用性能大幅提升但也要注意根据数据特性选择合适的缓存策略。如果你对本节内容有任何疑问欢迎在评论区提出来我们一起学习讨论。原文地址https://blog.uuhb.cn/archives/next-js-08.html

相关文章:

Next.js第八课 - 缓存机制

前面几节我们学习了数据获取和数据变更,本节来深入了解 Next.js 的缓存机制。缓存是提升应用性能的关键技术,用好了能让你的应用速度提升好几倍。 缓存架构 Next.js 使用多层缓存来优化性能,理解这个架构很重要: 请求流程: 浏览…...

新鲜出炉!2026简历模板服务商推荐排行 专业评测榜 AI适配/全行业覆盖

一、摘要据中国人力资源开发研究会2026年行业报告显示,国内简历模板服务市场中,仅有30%的服务商能实现ATS系统通过率90%以上,求职者因简历模板不适配、内容不规范导致面试邀约率偏低,平均错失40%的求职机会;企业则因模…...

OpenClaw技能市场探秘:Qwen3.5-9B适配的十佳插件

OpenClaw技能市场探秘:Qwen3.5-9B适配的十佳插件 1. 为什么需要关注Qwen3.5-9B适配插件? 上周我在调试一个自动化周报生成流程时,发现同样的任务脚本在Qwen3.5-9B上运行时,效率比预期低了40%。经过排查才发现,我使用…...

从一次线上事故复盘:我们如何用OWASP ZAP揪出jQuery遗留的AJAX CSRF漏洞

实战复盘:如何用OWASP ZAP挖掘jQuery遗留的AJAX CSRF漏洞 那天凌晨2点,运维群突然炸出一连串报警——某金融模块出现异常转账记录,涉及金额虽不大,但所有操作都显示来自真实用户会话。作为技术负责人,我立刻意识到&…...

0欧姆电阻在电子设计中的关键应用与选型指南

1. 0欧姆电阻的实质与特性在电子工程实践中,0欧姆电阻(Zero-Ohm Resistor)是一种表面贴装或插装形式的特殊电子元件。虽然标称值为零欧姆,但实际测量时会发现其存在微小的阻值——典型值在20-50毫欧之间。这个特性使其既不同于理想…...

别让ChatGPT变成你的安全漏洞:OWASP LLM Top 10(2024)实战避坑指南

别让ChatGPT变成你的安全漏洞:OWASP LLM Top 10(2024)实战避坑指南 当大型语言模型(LLM)从实验室走向企业级应用时,安全风险正以指数级速度增长。2023年某金融科技公司因提示词注入导致百万用户数据泄露的案…...

【独家原创】基于分位数回归PSO-QRLightGBM多变量时序预测-区间预测(多输入单输出) Matlab代码

✅作者简介:热爱科研的Matlab仿真开发者,擅长毕业设计辅导、数学建模、数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。👇 关注我领取海量matlab电子书和数学建模资料🍊个人信条:格物致知,完整Matl…...

收藏必备!小白程序员必看:如何用AI智能体操作系统赋能医疗行业?

本文介绍了一项创新性研究,旨在解决大语言模型智能体在医疗场景中的应用难题。传统AI智能体在医疗领域存在权限过大、记忆碎片化、沟通机制单一和医院IT系统死板等问题。为解决这些痛点,研究团队提出了医疗版“AI操作系统”(AOS-H&#xff09…...

鸿蒙应用对接DeepSeek大模型:构建智能问答系统的技术实践

鸿蒙应用对接DeepSeek大模型:构建智能问答系统的技术实践 随着鸿蒙系统(HarmonyOS)在全场景智能终端的深度布局,以及AI大模型技术的快速迭代,将鸿蒙原生应用与DeepSeek大模型深度融合,已成为打造智能问答系…...

《高效能人士的七个习惯》:从内圣到外王的完整方法论

这本书在全世界卖了千万册,斯蒂芬柯维用七个习惯构建了一套从自我管理到影响他人的完整体系。一、前言:比七个习惯更重要的两件事 很多人读这本书只关注七个习惯本身,却忽略了前言中两个至关重要的前提: 1. 积极乐观是一切的起点 …...

从进度到资源:7款适合PMO的项目集管理系统

本文将深入对比7大项目集管理系统:PingCode、Worktile、GanttPRO、奥博思、TAPD、Trello、氚云 在管理大型、跨部门的复杂项目时,PMO(项目管理办公室)常面临资源冲突、信息孤岛和进度失控的挑战。传统的单项目管理工具已难以承载组…...

信息化基础设施层建设

4.1 基础设施层建设 4.1.4 基础软件环境 基础软件环境的理论定位 基础软件环境是企业信息化建设的“操作系统”,其理论任务是为上层应用系统提供统一的运行环境、开发框架、数据服务和协作工具,包括操作系统、数据库、中间件、开发框架、版本控制、协…...

SCH1633-D01 |Murata村田|汽车级|±300度的角速率六轴陀螺仪|惯性导航

SCH1633-D01 |Murata村田|汽车级|300度的角速率六轴陀螺仪|惯性导航用于汽车应用的六自由度XYZ轴陀螺仪和XYZ轴加速度计,带数字SPI接口SCH1633-D01SCH1600传感器系列通过冗余设计选项和内置可调双输出通道为资深客户提供更大的灵活性。●300/s的角速率测量范围●8g的…...

PyCharm Community 版新手一站式安装与配置指南

1. PyCharm Community版是什么? PyCharm Community版是JetBrains公司推出的免费Python集成开发环境(IDE),专为个人开发者和小型项目设计。我第一次接触这个工具时,发现它比想象中要强大得多 - 代码自动补全、错误检查、…...

EXE Ver 适用于 未安装Python 以及包的Windows OS

上图~EXE Ver END...

计算机内存与缓存完全指南

计算机内存与缓存完全指南 目录 计算机存储体系概览内存(RAM)深度解析 2.1 RAM 的基本原理2.2 DRAM vs SRAM2.3 DDR 内存发展历史与对比2.4 内存关键参数详解2.5 内存模组类型(DIMM / SO-DIMM / LPDDR) CPU 缓存深度解析 3.1 缓…...

查重踩坑血泪史:免费软件、PaPerPass、AIGC率、淘宝旗舰店

规避雷区 最近为了查重,折腾得心力交瘁。多方打听、多次数据对比之后,总结了一些“花钱买教训”的经验,写成几个点分享出来,希望能帮大家少走弯路。千万避雷某多多。 1️⃣ 免费软件的“Pass查重”低于10%还算靠谱 经过多个数据…...

通义千问1.5-1.8B-Chat商业应用:企业智能助手快速落地方案

通义千问1.5-1.8B-Chat商业应用:企业智能助手快速落地方案 1. 企业智能助手市场现状与需求 当前企业运营面临人力成本上升、服务标准化不足、数据分析需求激增等挑战。传统解决方案往往需要投入大量资源进行定制开发,而基于大模型的智能助手提供了快速…...

从‘丑拒’到‘真香’:MaterialButton的iconGravity和inset属性,帮你搞定那些烦人的UI细节

从‘丑拒’到‘真香’:MaterialButton的iconGravity和inset属性,帮你搞定那些烦人的UI细节 设计师递过来一张设计稿,要求按钮图标精确位于文字左侧8dp处,且垂直方向与相邻视图严格对齐。你信心满满地用MaterialButton实现&#xf…...

Linux内存监控工具与实战技巧

1. Linux 内存监控概述作为一名运维工程师,我每天都要和服务器内存打交道。内存就像系统的血液,一旦出现异常,整个系统就会变得迟缓甚至崩溃。在Linux系统中,我们可以通过多种方式来监控内存使用情况,每种方法都有其独…...

OpenClaw调试技巧:捕获Qwen3.5-9B错误推理的5个方法

OpenClaw调试技巧:捕获Qwen3.5-9B错误推理的5个方法 1. 为什么需要关注模型推理错误 上周我让OpenClaw自动整理项目文档时,发现它把"API响应时间优化方案"归类到了"前端样式规范"目录。这个看似简单的错误背后,是Qwen3…...

AD09实战:3分钟搞定BOM表导出与自动化分类(附模板下载)

AD09实战:3分钟高效生成智能分类BOM表的完整指南 在电子设计领域,BOM表(物料清单)是连接设计与生产的核心纽带。传统手工整理BOM表不仅耗时费力,还容易因人为疏忽导致元器件分类错误、数量统计偏差等问题。AD09作为业界…...

【C】static

static1、修饰局部变量:使其变为静态变量,这个局部变量在函数执行完成后不会被释放,而是继续保留在内存里。2、修饰全局变量:使其只在本文件内部有效,在其他文件不可用。3、修饰函数:使函数只能在本文件中使…...

Pix4D安装与激活全攻略:从卸载到成功运行的详细指南

1. 彻底卸载旧版本:不留任何残余 很多人在安装Pix4D时遇到问题,往往是因为旧版本没有卸载干净。我见过太多案例,就是因为残留的注册表项导致新版本无法正常激活。这里分享一个我用了多年的"深度清洁法"。 首先打开控制面板&#xf…...

解决鸿蒙方向的Flutter框架版切换问题-当前最新版本3.35.8——工具切换与命令切换

欢迎加入开源鸿蒙跨平台社区: https://openharmonycrossplatform.csdn.net 最新版本的仓库地址: https://gitcode.com/openharmony-tpc/flutter_flutter/tree/oh-3.35.7-release 本地版本非最新版本 我当前的版本是3.27.5。 需要更新到最新的。 升…...

大模型训练实战:分布式训练、显存优化与知识蒸馏全解析!

全景路线图: 我们将按模块逐步展开,每个模块都是最终搭建完整平台的一块拼图:之前的章节参考我之前写的文章;G. 分布式训练篇:大模型训练的工程实践 – 学习在多卡多机环境下训练大模型的方法,包括数据并行…...

性能分析定界(OpenHarmony平台)指南

性能分析定界指南 前置条件 OpenHarmony Next系统前台运行Flutter页面分析工具 DevEco Studio Profiler SmartPerf Flutter线程介绍 Flutter 使用多个线程来完成其必要的工作,图层中仅展示了其中两个线程。你写的所有 Dart 代码都在 UI 线程上运行。尽管你没有直…...

Kuikly动态化跨端框架的多维特性与选型实践

Kuikly,是指基于Kotlin MultiPlatform(KMP)构建的跨端开发框架,利用KMP的逻辑跨平台能力,抽象通用跨平台UI渲染接口,复用平台UI组件,实现UI跨平台,具备轻量、高性能、可动态化优势;其核心特点是…...

STM32启动流程解析与嵌入式开发实践

1. STM32启动流程深度解析作为一名嵌入式开发者,我经常需要深入理解MCU的启动机制。今天我想分享STM32启动流程的详细分析,这是每个嵌入式工程师都应该掌握的核心知识。STM32的启动过程看似简单,实则包含了许多精妙的设计。理解这个过程不仅能…...

企业级AI Agent Harness工程落地的5个核心步骤与关键里程碑

企业级AI Agent Harness工程落地的5个核心步骤与关键里程碑 开篇:从「大模型玩具」到「生产级生产力工具」的鸿沟 各位技术同仁、架构师、企业数字化负责人,下午好!欢迎来到我的「AI工程化落地指南」专栏——这是我们的第17篇原创深度文章。 过去18个月里,我作为全球TOP3…...