Egg.js 服务端 HTML 强缓存问题排查与解决

问题现象与影响

某次线上更新后发现:HTML 页面内容未更新,用户浏览器反复刷新仍显示旧版本。经排查发现服务端对 HTML 文件设置了强缓存,导致浏览器直接从本地缓存加载 HTML,而未向服务器请求最新内容。

2.排查路径

基于请求链路,从浏览器缓存、CDN缓存、nginx 缓存、服务端缓存等多个维度进行排查。

2.1 客户端(浏览器)层面

例如通过 Service Worker 控制缓存策略

js 复制代码
// sw.js
self.addEventListener('fetch', event => {
  event.respondWith(
    caches.match(event.request).then(res => {
      return res || fetch(event.request);
    })
  );
});

基于此,可以通过 curl 请求页面,发现请求头仍然存在强缓存,说明浏览器未对 HTML 设置缓存

2.2 CDN 层面

因请求 HTML 的域名并非 CDN 的域名,因此 CDN 不会对该 HTML 文件进行缓存。

2.3 NGINX 层面

检查了 NGINX 配置,并确认了 NGINX 配置没有对 HTML 文件进行缓存。

2.4 服务端层面

在服务端中,可能在业务代码的中间件、响应头以及第三方代码模块中设置了强缓存。

最终根据响应头的标识,全局搜索,最终定位到是服务器 egg-static 插件配置问题,通过 egg-static 的源码我们发现,在返回数据时,会对 HTML 文件设置强缓存的请求头。

顺便一提: 在 Node 服务中,HTML 模版不应该转变成静态资源,而是应该使用 render 方法进行模版渲染。

3.解决方案

回归业务场景,egg-static 基于 koa-static-cache 实现,默认配置为:

js 复制代码
{
  maxAge: 31536000, // 1年缓存
  buffer: true,
  dynamic: true,
  preload: false
}

在 koa-static-cache 中,存在 files 配置,它是一个文件管理器对象,key 为文件名称,value 是文件制定配置 FileMeta,用于管理文件返回值的相关配置,其中 maxAge 配置用于指定缓存时间,当 maxAge 为 0 时,表示不缓存。

源码连接: github.com/eggjs/koa-s...

ts 复制代码
export interface FileMeta {
  maxAge?: number;
  cacheControl?: string;
  buffer?: Buffer;
  zipBuffer?: Buffer;
  type?: string;
  mime?: string;
  mtime?: Date;
  path?: string;
  md5?: string;
  length?: number;
}

在源码中,会先执行 loadFile 方法,根据文件名称从 files 中获取文件的配置,然后返回文件配置内容。(LoadFile --> 获取文件配置项 --> 根据配置返回文件内容)

基于此,恰好 koa-static-cache 暴露了 可以配置 files 对象的参数,当配置 HTML 文件的 maxAge 设置为 0 时,可去除强缓存。

最终修改后,我们通过 curl 请求页面,发现请求头已经没有强缓存了。

PS: 其实还有一个最简单的解决方案,即 [egg/koa-static-cache] (github.com/eggjs/koa-s...) 支持cache-control字段传递函数,这样可以根据文件名称自定义请求头参数,目前已提 [PR] (github.com/eggjs/koa-s...)

4.总结

通过以上排查,最终定位到是服务器 egg-static 插件配置问题,导致 HTML 文件被缓存。

基于此,可以通过 egg-static 中的 files 配置,对 HTML 文件进行缓存控制。

相关推荐
0思必得02 小时前
[Web自动化] Selenium处理动态网页
前端·爬虫·python·selenium·自动化
东东5163 小时前
智能社区管理系统的设计与实现ssm+vue
前端·javascript·vue.js·毕业设计·毕设
catino3 小时前
图片、文件的预览
前端·javascript
layman05285 小时前
webpack5 css-loader:从基础到原理
前端·css·webpack
半桔5 小时前
【前端小站】CSS 样式美学:从基础语法到界面精筑的实战宝典
前端·css·html
AI老李5 小时前
PostCSS完全指南:功能/配置/插件/SourceMap/AST/插件开发/自定义语法
前端·javascript·postcss
_OP_CHEN5 小时前
【前端开发之CSS】(一)初识 CSS:网页化妆术的终极指南,新手也能轻松拿捏页面美化!
前端·css·html·网页开发·样式表·界面美化
啊哈一半醒5 小时前
CSS 主流布局
前端·css·css布局·标准流 浮动 定位·flex grid 响应式布局
PHP武器库5 小时前
ULUI:不止于按钮和菜单,一个专注于“业务组件”的纯 CSS 框架
前端·css
电商API_180079052475 小时前
第三方淘宝商品详情 API 全维度调用指南:从技术对接到生产落地
java·大数据·前端·数据库·人工智能·网络爬虫