- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我已将 AWS CloudFront 设置为提供静态内容和来自同一域的 API 服务器。这意味着我有两种行为,一种从 /api
为 API 网关提供服务,另一种为所有其他路径从 S3 提供内容。
问题是我不希望 CF 缓存来自 API 服务器的任何内容。我惊讶地发现似乎没有一个“主设置”来完全禁用缓存行为;相反,文档提到在源上使用 Cache-control: no-cache
或在 CF 行为中打开“基于所有 header 的缓存”。
但是,这些解决方案都不能完全满足我的要求,即不缓存并传递所有 header 。如果我将 Cache-control: no-cache
添加到我的源中,CF 似乎会尊重这一点,但仍然存在 CF 设置的问题。 CF 有一个设置“基于 header 缓存:全部/无/白名单”。文档说要禁用缓存,应该使用“全部”,这是有道理的(尽管与实际设置相比有点模糊:禁用缓存:开/关)。但是,一旦我将此设置设置为“全部”,整个行为就会被禁用,我的 API 请求将根本不会到达 API 网关,而是默认用于非 API 请求的 S3 行为。我找不到对此的任何解释,就像整个行为失败或在没有解释的情况下被禁用。
另一个问题是,“缓存基于”中不存在的 header 不仅会被排除在缓存之外(我无论如何都不想要),而且还会在之前从请求中删除已转发。这对于缓存按预期工作可能是有意义的,但由于我不想要任何缓存,因此必须确保将我使用过的所有 header 列入白名单是非常令人沮丧的。依赖“全部”比必须确保白名单始终是最新的要好得多。
所以:
1) 是否有更好、更清晰的方法来完全禁用 CloudFront 发行版的一个路径的缓存?理想情况下,它甚至不应该依赖于设置某些 header 的源,它应该完全禁用在配置的路径中缓存请求的任何尝试。
2) 当我在“基于 header 的缓存”框中选择“全部”时,为什么我的整个 API 网关目标被禁用?这里发生了什么?
最佳答案
刚刚遇到了同样的问题,最终联系了 AWS 帮助人员解决该问题。
根据AWS同事的说法,“Cache based on headers = All”在API网关上不起作用的原因是,“Host” header 的转发使其不适用。
它对我们有用的方式是将 API 网关行为的 TTL 设置为零(对于最大值和最小值)。
关于caching - 如何正确禁用 API 请求的 CloudFront 缓存,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52704816/
我已经为我们的 Cloudfront 分配设置了一个备用域名,这样我们就可以从 oursite.com 提供服务。我们想禁用 ourdistid.cloudfront.net,这样我们的站点只能从一个
假设一个域名为 www.example.com 的网站托管在网站托管商(而非亚马逊)的 LAMP 服务器上。该域由 Route53 管理。 是否有可能以某种方式保留 LAMP 网络服务器上的所有设置并
我在使Cloudfront具有多个来源的工作时遇到麻烦。 我有两个起源: 起源1 小路: 默认 (*) 起源: Custom-example1.com/p 起源2 小路: ns/ 起源: Custom
TLDR:我们必须通过为来自 Lambda 函数的响应创建新的缓存行为来欺骗 CloudFront 307 重定向缓存。 你不会相信我们离实现这一目标有多近。我们在最后一步卡得太厉害了。 商业案例:
How do you set a default root object for subdirectories for a statically hosted website on Cloudfron
有人知道如何使使用友好 url 的自定义来源的根文档无效吗? 例如:example.com ? 通过 AWS Create Invalidation 对话框请求的正确对象路径是什么? 文档仅引用实际文
我正在使用带有自定义源的 CloudFront,并希望将来自 Web 应用程序的某些请求重定向到 CloudFront(客户端使用直接 URL,不能更改为基于 CloudFront 的 URL)。为了
我正在尝试在 AWS CloudFront 上上传公钥。我按如下方式生成 key ssh-keygen -t ecdsa -b 521 我也试过 ssh-keygen -b 4096 当我通过控制台上
我在 wordpress 重定向中的重定向导致域更改时遇到了一些问题。 例子:网站 - noncdn.somedomain.comCDN 网址 - www.domain.com 当我打开没有尾部斜杠的
在 CloudFront 行为设置中,“全部”是将所有请求 header 转发到源吗? Values That You Specify When You Create or Update a Dist
我们的应用程序中使用的图像是从 Amazon CloudFront 呈现的。 修改现有图像时,它不会立即反射(reflect)图像更改,因为 CloudFront 需要大约 24 小时才能更新。 作为
我想设置亚马逊云端,但是 Assets 需要在 http 和 https 上都可用。 我也想使用多个 cname。例如xyz0.cloudfront.netxyz1.cloudfront.netxyz
路径模式属性的文档并不完全详尽。 The pattern to which this cache behavior applies. For example, you can specify imag
我浏览了文档并进行了大量搜索。这些是我知道我可以使用 CloudFront 创建的签名 url 做的事情: 使用固定策略设置时间限制 监控该项目被查看的次数 我还可以为我的签名 URL 设置命中限制吗
cloudfront 是否支持 TLSv1.3 我没有看到任何文档说它在 cloudfront 和自定义来源之间支持?我强烈要求使用 TLSv1.3 最佳答案 CloudFront 现在支持 TLS
我最近才在阅读 Varnish Cache 的功能,以帮助优化我的 PHP 网站的性能。我读到了一个名为 Edge Side Includes 的功能,它似乎让我可以选择构建可以缓存在组件级别的 ht
我是部署静态站点的新手。搜索了大约一段时间的解决方案,根据我遇到的问题,我没有找到任何有用的信息。 宗旨 :我想在 CloudFront 上运行我生成的 Nuxt.js 静态站点。 问题 : 跑命令n
我正在使用 Amazon CloudFront 传送一些 HDS 文件。我有一个原始服务器,它检查 HTTP HEADER REFERER,如果不允许,它会阻止它。 问题是云前端正在删除引用 head
我正在使用 lambda@edge 通过 cloudfront 重定向我的网站。 我已将版本化 lambda arn 附加到我的云前端缓存行为及其所有 4 个事件。 当我访问我的云端端点时,它会显示
有没有办法让 Amazon CloudFront 失效(通过管理控制台),使所有匹配模式的文件失效?例如图像/*.png 语境 - 我在我的网站上为图像设置了缓存控制,但错误地在 Apache 的缓存
我是一名优秀的程序员,十分优秀!