添加生命周期钩子 - Amazon EC2 Auto Scaling
Amazon Web Services 文档中描述的 Amazon Web Services 服务或功能可能因区域而异。要查看适用于中国区域的差异,请参阅 中国的 Amazon Web Services 服务入门 (PDF)

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

添加生命周期钩子

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

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

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

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

按照以下步骤将生命周期挂钩添加到您的 Auto Scaling 群组。要添加用于扩展(启动实例)和向内扩展(实例终止或返回到温池)的生命周期挂钩,您必须创建两个单独的挂钩。

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

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

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

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

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

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

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

    3. 对于 Heartbeat 超时,指定实例在挂接超时之前向外扩展时保持等待状态的时间(以秒为单位)。范围从 307200 秒。设置较长的超时时间可以让您的自定义操作有更多时间完成。然后,如果您在超时期限结束之前完成,请发送complete-lifecycle-action命令以允许实例进入下一个状态。

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

      • 如果您选择 “继续”,Auto Scaling 组可以继续处理任何其他生命周期挂钩,然后将该实例投入使用。

      • 如果您选择放弃,Auto Scaling 组将停止所有剩余的操作并立即终止实例。

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

  5. 选择创建

添加生命周期挂钩以进行缩放
  1. 创建用于横向扩展的生命周期挂钩后,选择 “创建生命周期挂钩”,继续从上次中断的地方继续。

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

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

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

    3. 对于 Heartbeat 超时,指定实例在挂接超时之前向外扩展时保持等待状态的时间(以秒为单位)。我们建议将超时时间缩短30120几秒,具体取决于执行任何最终任务(例如从中提取 EC2 日志)所需的时间 CloudWatch。

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

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

      • 如果您选择 “放弃”,Auto Scaling 组会立即终止该实例。

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

  3. 选择创建

添加生命周期钩子 (Amazon 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-heartbeatCLI 命令记录心跳来防止生命周期挂钩超时。这会将超时时间增加到您创建生命周期挂钩时指定的超时值。如果您在超时期限结束之前完成,则可以发送 complete-lifecycle-actionCLI 命令以允许实例进入下一个状态。有关更多信息以及示例,请参阅 完成生命周期操作