bri*_*ian 5 firebase firebase-hosting google-cloud-run
因此,我正在为 Web 应用程序试验 Firebase 托管和 Google Cloud Run。
我在 firebase 托管上部署了一个静态 SPA,以及一个重写规则,以将所有以 /api 开头的请求定向到我的 Google Cloud Run 服务。
我的 firebase.json 文件如下所示:
{
"hosting": {
"public": "dist",
"ignore": [
"firebase.json",
"**/.*",
"**/node_modules/**"
],
"rewrites": [
{
"source": "**/api/**",
"run": {
"serviceId": "myservice-api",
"region": "europe-west1"
}
},
{
"source": "**",
"destination": "/index.html"
}
]
}
}
Run Code Online (Sandbox Code Playgroud)
起初,似乎一切都按预期进行,所有 /api 请求都由我的 Google Cloud Run 服务处理。然而,我开始注意到一些请求的奇怪行为,因为服务器返回的响应完全不是我所期望的。进一步研究一下,我注意到这些请求没有显示在我的 Cloud Run 服务的日志中。
所以我检查了浏览器收到的响应标头,并注意到响应来自 Firebase 缓存而不是 Cloud Run 服务:
accept-ranges: bytes
access-control-allow-origin: *
content-length: 245
content-type: application/json
date: Wed, 06 Nov 2019 11:24:32 GMT
server: Google Frontend
status: 200
vary: x-fh-requested-host, accept-encoding
x-cache: HIT
x-cache-hits: 5
x-served-by: cache-cdg20776-CDG
Run Code Online (Sandbox Code Playgroud)
该文件指出:
但是,由于 Cloud Functions 和 Cloud Run 服务动态生成内容,因此给定 URL 的内容可能会因用户输入或用户身份等因素而异。考虑到这一点,由后端代码处理的请求默认不会缓存在 CDN 上。
因此,我希望任何发送到 /api 的请求都不会被缓存。我定义重写规则的方式是否有问题,或者我应该将此视为 Firebase Hosting 处理 Cloud Run 路由方式的问题?
更新
这是客户端请求的详细信息,如 Chrome 开发工具中所示:
Request URL: https://myproject.web.app/api/users/me
Request Method: GET
Headers:
:authority: myproject.web.app
:method: GET
:path: /api/users/me
:scheme: https
accept: application/json;charset=UTF-8
accept-encoding: gzip, deflate, br
accept-language: en-US,en;q=0.9,fr;q=0.8
authorization: Bearer xxx
cookie: G_ENABLED_IDPS=google; G_AUTHUSER_H=0
referer: https://myproject.web.app/auth/login/
sec-fetch-mode: cors
sec-fetch-site: same-origin
user-agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/77.0.3865.120 Safari/537.36
Run Code Online (Sandbox Code Playgroud)
请求返回 JSON 数据,以下是 Cloud Run 实际处理时后端返回的响应标头:
content-type: application/json
access-control-allow-origin: *
X-Cloud-Trace-Context: eeb4c0dbd22dd46f3c42fbe0b85b6420;o=1
Date: Wed, 06 Nov 2019 11:24:26 GMT
Server: Google Frontend
Content-Length: 240
Run Code Online (Sandbox Code Playgroud)
因此,服务器没有设置特定的标头来指示应缓存响应。
我找到了解决方案......我在标题中添加了 Cache-Control 属性并添加了两个“no-cache”和“no-store”值
例如:
"headers": [
{ "source":"**/user/**", "headers": [{"key": "Cache-Control", "value": "no-cache, no-store"}] }
]
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
590 次 |
最近记录: |