1

我有一个 ECS 集群,其中有一个服务正在运行我定义的任务。它只是一个简单的烧瓶服务器,因为我正在学习如何使用 ECS。现在我正在尝试了解如何更新我的应用程序并使其无缝部署。

  1. 我从烧瓶服务器返回开始Hello, World! (rev=1)
  2. 我修改我的app.py本地说Hello, World! (rev=2)
  3. 我重建 docker 映像,并推送到 ECR
  4. 由于我的图像仍然命名为image_name:latest,我可以简单地更新服务并强制执行新部署:aws ecs update-service --force-new-deployment --cluster hello-cluster --service hello-service
  5. 我的最小百分比设置为 100,最大值设置为 200%(使用滚动更新),所以我假设在关闭旧的 EC2 实例时应该设置一个新的 EC2 实例。我观察到(不断刷新 ELB HTTP 端点)是 rev=? 在消息中来回交替:(rev=1)然后(rev=2)没有失败(循环,不是随机)。
  6. 然后过了一点点(可能是 30 秒?)翻转停止并出现新消息:Hello, World! (rev=2)
  7. 在整个过程中,我注意到没有更多的 EC2 实例被启动。所以这一切一定是在同一个实例上发生的。

这里发生了什么?这是在 ECS 中更新应用程序的正确方法吗?

4

1 回答 1

2

这是正常行为,它与您配置最小和最大健康百分比的方式有关。

100% 的最低健康百分比意味着每时每刻都必须至少有 1 个任务正在运行(对于应该运行 1 个任务实例的服务)。最大健康百分比为 200% 意味着您不允许同时运行超过 2 个任务(同样对于应该运行 1 个任务实例的服务)。这意味着在服务更新期间,ECS 将首先启动一个新任务(达到最大值 200% 并避免低于 100%),当这个新任务被认为是健康的时,它将删除旧任务(回到 100%)。这解释了为什么两个任务在短时间内同时运行(并且是负载平衡的)。

这种配置确保了最大的可用性。如果您想避免这种情况,并且可以允许少量停机,您可以将最小值配置为 0%,将最大值配置为 100%。

关于您的 EC2 实例:它们代表您的“集群”=您的服务用于启动任务的硬件。上述过程发生在这个“固定”硬件上。

于 2019-04-20T19:57:54.497 回答