3

我在启用了 Cloud CDN 的 Google Cloud HTTP(S) 负载平衡器后面有一个后端 GCS 存储桶。

我正在尝试根据响应标头回答这些问题:

  • 此响应是从 CDN 提供的吗
  • 如果是,哪个位置/地区
  • 这是缓存命中/未命中吗

这是响应标头。基于cache-control,理论上,这应该被缓存。但是,我没有看到可以验证 CDN 正常工作的迹象。同样,所有其他标头x-goog-*似乎Server: UploadServer都来自 GCS 服务器,而不是 CDN。

accept-ranges: bytes
age: 551
alt-svc: clear
cache-control: public, max-age=3600
content-length: 298303
content-type: image/jpeg
date: Wed, 05 Aug 2020 23:07:33 GMT
etag: "f0b6c60f635c784dd7f34ab9c1527867"
expires: Thu, 06 Aug 2020 00:07:33 GMT
last-modified: Wed, 05 Aug 2020 23:07:16 GMT
server: UploadServer
status: 200
X-DNS-Prefetch-Control: off
x-goog-generation: 1596668836233926
x-goog-hash: crc32c=rD4sZw==
x-goog-hash: md5=8LbGD2NceE3X80q5wVJ4Zw==
x-goog-metageneration: 1
x-goog-storage-class: STANDARD
x-goog-stored-content-encoding: identity
x-goog-stored-content-length: 298303
x-guploader-uploadid: AAANsUktJ98kPCHjiR2oBi6N-[...]

例如,Cloudflare 提供以下响应标头:

  • 请求在哪里送达: cf-ray: 5be4505beb76bca2-SEA
  • 缓存状态是什么:cf-cache-status: REVALIDATED
  • 我的请求是直接点击 CDN 还是我的后端server: cloudflare
4

2 回答 2

5

现在{cdn_cache_status}您可以在响应中设置一个新变量:https ://cloud.google.com/load-balancing/docs/custom-headers#variables

使用 gcloud SDK v309.0.0 或更高版本:

➜  gcloud beta compute backend-services update my-backend --global \
--enable-cdn \
--custom-response-header='Cache-Status: {cdn_cache_status}' \
--custom-response-header='Cache-ID: {cdn_cache_id}'

示例输出:

< HTTP/2 200
< content-type: text/plain; charset=utf-8
< date: Mon, 14 Sep 2020 21:40:05 GMT
< server: Google Frontend
< content-length: 1098
< via: 1.1 google
< cache-control: public, max-age=10
< age: 2
< x-frame-options: DENY
< cache-status: hit
于 2020-09-14T21:40:35.197 回答
3

目前,您无法仅通过查看客户端的标题来回答上述问题。

请求是否由缓存提供的一种指示是标头age,Cloud CDN 将在响应中附加该标头。

如果您在 HTTP 负载均衡器级别启用了缓存日志记录,则可以从日志中获取上述所有信息。

更具体地说,来自文件:

httpRequest.cacheHit这表明请求是否从缓存中提供。 jsonPayload.cacheId这是提供缓存响应的位置和缓存实例。

有关上述内容的更多详细信息,请参见此处1

于 2020-08-06T07:50:25.057 回答