当您的应用服务器托管在不同的云服务上时,如何安全地从 Firebase 托管上的 CDN 缓存中受益

如何解决当您的应用服务器托管在不同的云服务上时,如何安全地从 Firebase 托管上的 CDN 缓存中受益

我已经长期缓存我的静态资产,例如:css、图像、js 文件等。由于这些文件在我的构建过程中都获得了 content-hash id,这就是我的处理方式他们缓存:

// STATIC FILES LIKE IMAGES,FONTS,CSS AND JS

Cache-Control: "public,max-age=31536000"

这样我的客户端和 CDN 缓存都长达一年,这很棒。它工作正常。

但我的网络应用程序是一个单页 React 应用程序,所以每当我更新它时,我的用户从我的应用程序获得的唯一 index.html 文件会自动变得陈旧和无用,因为它指向旧的静态 JS 文件,现已全部更新。

所以基本上我不能让他们得到一个过时的 index.html

我还想从该文件的 CDN 缓存中获益。这就是它可能变得棘手的时候。

现在,为了安全起见,这是我正在做的:

// For index.html

Cache-Control: "no-cache,no-store,must-revalidate"

我想把它改成:

// FOR index.html

Cache-Control: "max-age=0,s-maxage=86400,must-revalidate"

这样我就可以获得 1 天的 CDN 缓存,这很好。但我仍然不想冒险提供过时的 index.html

Firebase Hosting 对此的评价如下:

任何请求的静态内容都会自动缓存在 CDN 上。如果您重新部署网站的内容,Firebase 托管会自动清除 CDN 中所有缓存的静态内容,直到下一个请求。

enter image description here

但问题是我的服务器托管在 Cloud Run 上。 Firebase 托管基本上是 rewrites 对它的每个请求。类似的东西:

firebase.json

"rewrites": [
  {
    "source": "**","run": {
      "serviceId": "server","region": "uscentral-1"
    }
  }
]

因此,每当我更新应用程序时,我都会将其重新部署到 Cloud Run,但不会运行新的 firebase deploy --only hosting 命令。因为在 Cloud Run 代码的新部署之间,我的 firebase.json 文件中没有任何内容发生变化。


问题

在这种情况下添加 s-maxage=86400 标头是否安全?

假设在 Cloud Run 上进行新部署不会触发 CDN 缓存的清除。我能做些什么来触发它吗?像一些 firebase deploy --only hosting:clear-cdn 命令?

因为即使我再次运行 firebase deploy --only hosting,我也不确定缓存的文件是否会被清除,因为我的 Firebase Hosting /public 文件夹始终是一个空文件夹。因此 Firebase 托管可能会“感觉”没有任何变化。

解决方法

经过一天的测试,结果如下:

如果您设置了允许共享 (CDN) 缓存的 Cache-Control 标头,例如 publicno-cache,您的响应将在客户端浏览器和 CDN 缓存中缓存。

  • 当您重新部署到 Cloud Run 时,它会自动清除您的 CDN 缓存吗?

没有。当您更新应用文件并将其重新部署到 Cloud Run 时,CDN 上的这些缓存文件将是陈旧的,并且不会从 CDN 中自动清除。因此,即使就 Firebase 托管而言没有任何变化,您也需要再次运行 firebase deploy --only hosting。这将使 CDN 清除您所有的缓存文件,新请求将立即开始获取新数据。

  • 我不确定缓存文件是否会被清除,因为我的 Firebase Hosting /public 文件夹始终是一个空文件夹。因此,Firebase 托管可能会“感觉”没有任何变化。

即使您的 Firebase Hosting public 文件夹中没有任何内容发生变化(在我的情况下它是一个空文件夹)并且您的 firebase.json 中没有任何内容发生变化,它仍然会创建一个新的 Firebase Hosting 版本并且它将从 CDN 中清除您的缓存文件,如 doc 所说:

任何请求的静态内容都会自动缓存在 CDN 上。如果您重新部署网站的内容,Firebase 托管会自动清除 CDN 中所有缓存的静态内容,直到下一个请求。

注意动态内容

例如,如果您有要通过管理 UI 编辑的动态内容。请注意,CDN 缓存将保留该内容的陈旧缓存,直到过期。

例如:CDN 缓存 /blog/some-posts-maxage of 1 day。即使您动态更改帖子的内容,CDN 也会将 CDN 保留一整天,直到它过期并再次被请求。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


依赖报错 idea导入项目后依赖报错,解决方案:https://blog.csdn.net/weixin_42420249/article/details/81191861 依赖版本报错:更换其他版本 无法下载依赖可参考:https://blog.csdn.net/weixin_42628809/a
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下 2021-12-03 13:33:33.927 ERROR 7228 [ main] o.s.b.d.LoggingFailureAnalysisReporter : *************************** APPL
错误1:gradle项目控制台输出为乱码 # 解决方案:https://blog.csdn.net/weixin_43501566/article/details/112482302 # 在gradle-wrapper.properties 添加以下内容 org.gradle.jvmargs=-Df
错误还原:在查询的过程中,传入的workType为0时,该条件不起作用 <select id="xxx"> SELECT di.id, di.name, di.work_type, di.updated... <where> <if test=&qu
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct redisServer’没有名为‘server_cpulist’的成员 redisSetCpuAffinity(server.server_cpulist); ^ server.c: 在函数‘hasActiveC
解决方案1 1、改项目中.idea/workspace.xml配置文件,增加dynamic.classpath参数 2、搜索PropertiesComponent,添加如下 <property name="dynamic.classpath" value="tru
删除根组件app.vue中的默认代码后报错:Module Error (from ./node_modules/eslint-loader/index.js): 解决方案:关闭ESlint代码检测,在项目根目录创建vue.config.js,在文件中添加 module.exports = { lin
查看spark默认的python版本 [root@master day27]# pyspark /home/software/spark-2.3.4-bin-hadoop2.7/conf/spark-env.sh: line 2: /usr/local/hadoop/bin/hadoop: No s
使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams['font.sans-serif'] = ['SimHei'] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -> systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping("/hires") public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate<String
使用vite构建项目报错 C:\Users\ychen\work>npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-