3

我将 CloudFront 分配指向我的 BackboneJS 应用程序。这包括 index.html、master.css、master.js。

脚步:

  1. 将 ?v=ID 附加到 index.html 中的 css 和 js 链接
  2. 将 index.html、css、js 文件部署到源服务器。
  3. 使 index.html 文件无效@CloudFront
  4. 等待 CF 从服务器获取新的 index.html 文件并加载新版本的资产。

当我部署时,我可以通过在索引文件中应用一个新的查询字符串来破坏 master.css 和 master.js 缓存。不幸的是,必须手动使 index.html 文件缓存失效——亚马逊称这个过程可能需要 10-15 分钟。

有什么提示可以立即将 index.html 文件更改为 CF 上的最新版本?

谢谢!

4

2 回答 2

0

根据个人经验,我可以告诉您 CloudFront 失效不会花费那么长时间。因为您的用户可能会长时间打开您的页面,所以无论如何您都需要处理同时运行的应用程序的多个版本。

这是一个使用 AWS CLI 使失效并等待失效传播的 Bash 脚本:

# Invalidates the CloudFront cache,
# waits for invalidation to be propagated.
function invalidate_cache() {
  local invalidation
  local invalidation_id
  local distribution_id=$1
  local status=""

  invalidation=$(aws cloudfront create-invalidation --distribution-id "$distribution_id" --paths '/*')
  invalidation_id=$(jq -r .Invalidation.Id <<< "$invalidation")

  while [[ $status != "Completed" ]]; do
    echo "Waiting for CloudFront invalidation to complete..."
    sleep 1
    status=$(aws cloudfront get-invalidation --distribution-id "$distribution_id" --id "$invalidation_id"| jq -r .Invalidation.Status)
  done
}

如果出于某种原因您总是想确保index.html它是新鲜的,那么只需让 CloudFront 根本不缓存它。您可以创建特定的 CloudFront 行为/index.html并将生存时间覆盖为零。

于 2018-11-16T15:38:33.057 回答
0

使云端缓存失效不是一个耗时的过程。不需要太长时间。不过,您可以有多种方法来监视失效状态。

一旦云端使缓存失效,您还可以使用 lambda 函数更新下游组件/系统。

话虽如此,如果需要实时更新 index.html,您可以选择不将其包含在云端缓存中。您可能希望在 cloudfront 的行为设置中进行设置。TTL 可以设置为 0。

于 2018-11-20T08:28:30.237 回答