向自动扩缩组添加生命周期挂钩 - Amazon A EC2 uto Scaling

本文属于机器翻译版本。若本译文内容与英语原文存在差异,则一律以英文原文为准。

向自动扩缩组添加生命周期挂钩

要将 Auto Scaling 实例置于等待状态并对它们执行自定义操作,您可以向 Auto Scaling 组添加生命周期钩子。自定义操作将在实例启动时或其终止之前执行。实例将保持等待状态,直到您完成生命周期操作,或者直到超时时段结束。

从 AWS Management Console 创建 Auto Scaling 组后,您可以向其添加一个或多个生命周期钩子,最多可以添加 50 个生命周期钩子。您也可以使用 AWS CLI、AWS CloudFormation 或开发工具包在创建 Auto Scaling 组时向其添加生命周期钩子。

默认情况下,当您在控制台中添加生命周期钩子时,Amazon EC2 Auto Scaling 会向 Amazon EventBridge 发送生命周期事件通知。建议的最佳实践是使用 EventBridge 或用户数据脚本。要创建直接向 Amazon SNS 或 Amazon SQS 发送通知的生命周期钩子,您可以使用 put-lifecycle-hook 命令,如此主题中的示例所示。

添加生命周期钩子(控制台)

请按照以下步骤向您的自动扩缩组添加生命周期挂钩。要添加用于横向扩展(实例启动)和横向缩减(实例终止或返回至暖池)的生命周期挂钩,您必须创建两个单独的钩子。

做好准备向 Auto Scaling 组添加生命周期钩子 中所述,请在开始之前确认已设置自定义操作。

为横向扩展添加生命周期挂钩
  1. 访问 https://console.aws.amazon.com/ec2/,打开 Amazon EC2 控制台,然后从导航窗格中选择 Auto Scaling Groups(Auto Scaling 组)。

  2. 选中您的自动扩缩组旁边的复选框。这时将在页面底部打开一个拆分窗格。

  3. Instance management (实例管理) 选项卡的 Lifecycle hooks (生命周期挂钩) 中,选择 Create lifecycle hook (创建生命周期挂钩)

  4. 要为横向扩展(实例启动)定义生命周期挂钩,请执行以下操作:

    1. 对于 Lifecycle hook name (生命周期挂钩名称),请指定生命周期挂钩的名称。

    2. 对于生命周期转换,请选择实例启动

    3. 对于检测信号超时时间,请在钩子超时之前,指定实例在横向扩展时保持等待状态的时长(以秒为单位)。范围从 307200 秒。设置的超时时段越长,完成您的自定义操作的时间越长。如果您在超时时段结束之前完成操作,请发送 complete-lifecycle-action 命令,以允许实例继续到下一状态。

    4. 对于默认结果,指定在生命周期钩子超时结束或发生意外故障时要执行的操作。您可以选择继续放弃

      • 如果您选择继续,自动扩缩组可以继续执行任何其他生命周期挂钩,然后将实例投入使用。

      • 如果选择 放弃,自动扩缩组停止任何剩余操作并立即终止实例。

    5. (可选)对于通知元数据,请指定您希望在 Amazon EC2 Auto Scaling 向通知目标发送消息时包含的其他信息。

  5. 选择创建

为横向缩减添加生命周期挂钩
  1. 选择创建生命周期挂钩,以从为横向扩展创建生命周期挂钩而中断的地方继续操作。

  2. 要为横向缩减定义生命周期挂钩(实例终止或返回到暖池),请执行以下操作:

    1. 对于 Lifecycle hook name (生命周期挂钩名称),请指定生命周期挂钩的名称。

    2. 对于生命周期转换,请选择实例终止

    3. 对于检测信号超时时间,请在钩子超时之前,指定实例在横向扩展时保持等待状态的时长(以秒为单位)。我们建议您使用 30 秒到 120 秒的超时时间,具体取决于执行任何最终任务(如从 CloudWatch 提取 EC2 日志)需要的时间。

    4. 对于 Default result(默认结果),请指定超时结束或发生意外故障时 Auto Scaling 组执行的操作。ABANDON(放弃)和 CONTINUE(继续)都允许终止实例。

      • 如果您选择 CONTINUE(继续),Auto Scaling 组可以在终止之前继续执行任何剩余操作(如其他生命周期钩子)。

      • 如果选择 放弃,自动扩缩组将立即终止实例。

    5. (可选)对于通知元数据,请指定您希望在 Amazon EC2 Auto Scaling 向通知目标发送消息时包含的其他信息。

  3. 选择创建

添加生命周期钩子 (AWS CLI)

使用 put-lifecycle-hook 命令创建和更新生命周期钩子。

要执行扩展操作,请使用以下命令。

aws autoscaling put-lifecycle-hook --lifecycle-hook-name my-launch-hook \ --auto-scaling-group-name my-asg \ --lifecycle-transition autoscaling:EC2_INSTANCE_LAUNCHING

要执行缩减操作,请使用以下命令。

aws autoscaling put-lifecycle-hook --lifecycle-hook-name my-termination-hook \ --auto-scaling-group-name my-asg \ --lifecycle-transition autoscaling:EC2_INSTANCE_TERMINATING

要使用 Amazon SNS 或 Amazon SQS 接收通知,请添加 --notification-target-arn--role-arn 选项。

以下示例中创建了一个生命周期钩子,用于指定名为的 my-sns-topic 的 SNS 主题作为通知目标。

aws autoscaling put-lifecycle-hook --lifecycle-hook-name my-termination-hook \ --auto-scaling-group-name my-asg \ --lifecycle-transition autoscaling:EC2_INSTANCE_TERMINATING \ --notification-target-arn arn:aws:sns:region:123456789012:my-sns-topic \ --role-arn arn:aws:iam::123456789012:role/my-notification-role

该主题将使用以下键/值对接收测试通知。

"Event": "autoscaling:TEST_NOTIFICATION"

默认情况下,put-lifecycle-hook 命令会创建一个生命周期钩子,检测信号超时时间为 3600 秒(一小时)。

要更改现有生命周期钩子的检测信号超时时间,请添加 --heartbeat-timeout 选项,如以下示例所示。

aws autoscaling put-lifecycle-hook --lifecycle-hook-name my-termination-hook \ --auto-scaling-group-name my-asg --heartbeat-timeout 120

如果实例已处于等待状态,则可以通过记录检测信号、使用 record-lifecycle-action-heartbeat CLI 命令来防止生命周期钩子超时。这会将超时时间增加到您创建生命周期挂钩时指定的超时值。如果您在超时时段结束之前完成操作,可以发送 complete-lifecycle-action CLI 命令,以允许实例继续到下一状态。有关更多信息以及示例,请参阅 在自动扩缩组中完成生命周期操作