AutoScaling 生命周期的作用是什么

发布时间:2021-06-29 16:43:36 作者:Leah
来源:亿速云 阅读:263

这篇文章将为大家详细讲解有关AutoScaling 生命周期的作用是什么,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

LifecycleHook 介绍

LifecycleHook 使用场景

使用 LifecycleHook,可以在伸缩组发生伸缩活动时将正在扩张或即将释放的 ECS 实例挂起,执行用户自定义操作,可以更加灵活地管理 ECS 实例在伸缩组内的生命周期。几个简单的 LifecycleHook 应用场景:

针对上述第二种场景,如果可以确定每个请求的最长处理时间,可以调用 创建生命周期挂钩 接口创建生命周期挂钩,设置 LifecycleTransition 参数值为 SCALE_IN,设置 HeartbeatTimeout 为请求最长处理时间,不需要设置通知对象,当发生弹性收缩类型伸缩活动时,ECS 实例从 SLB 移除后会挂起一段时间(HeartbeatTimeout),等待请求处理完成。

LifecycleHook 工作方式

当伸缩组创建了 LifecycleHook,并发生 LifecycleHook 配置的伸缩活动类型(LifecycleTransition)时,那么伸缩活动呗挂起,用户可以在伸缩活动挂起这段时间内执行自定义操作,一直到 LifecycleHook 超时(HeartbeatTimeout),或者通过调用 CompleteLifecycleAction 接口提前终止伸缩活动挂起。

AutoScaling 生命周期的作用是什么

对于弹性扩张(SCALE_OUT)伸缩活动:

ECS 实例先进入 Pending(加入中)状态,当实例启动成功,并添加到 RDS 白名单(如果伸缩组设置了 RDS)以后,触发 LifecycleHook ,ECS 实例进入 Pending:Wait(加入中挂起)状态。如果LifecycleHook 配置了通知对象(MNS),则发送通知内容到 MNS,用户可通过 MNS控制台 的方式来消费 MNS 主题或者队列中的消息,也可以通过 OpenAPI 的方式消费,具体可参考 ESS 事件通知#消息接收 章节。当用户接收到 MNS 消息后可以执行自定义操作,例如在 ECS 实例上安装软件、部署服务等,执行完自定义操作以后,用户可以通过 CompleteLifecycleAction 接口提前结束挂起的伸缩活动,也可以等待 LifecycleHook 挂起超时。LifecycleHook 挂起结束后有两个执行方向,CONTINUE or ABANDON,对于弹性扩张伸缩活动,执行方向解释如下:

结束 LifecycleHook 挂起状态以后,如果伸缩组配置了负载均衡(SLB),那么将 ECS 实例挂载到 SLB 上以后,实例进入 Inservice(服务中)状态,此时弹性扩张伸缩活动结束。

对于弹性收缩(SCALE_IN)伸缩活动:

ECS 实例先进入 Terminating(移出中)状态,,将实例从 SLB 后端服务器移除以后(如果伸缩组配置了负载均衡(SLB)),触发 LifecycleHook ,ECS 实例进入 Terminating:Wait(移出中挂起)状态。如果 LifecycleHook 配置了通知对象(MNS),则发送通知内容到 MNS,用户可通过 MNS控制台 的方式来消费 MNS 主题或者队列中的消息,也可以通过 OpenAPI 的方式消费,具体可参考 ESS 事件通知#消息接收 章节。当用户接收到 MNS 消息后可以执行自定义操作,例如检测 ECS 接收到的请求是否处理完成、停止接收服务等,执行完自定义操作以后,用户可以通过 CompleteLifecycleAction 接口提前结束挂起的伸缩活动,也可以等待 LifecycleHook 挂起超时。LifecycleHook 挂起结束后有两个执行方向,CONTINUE or ABANDON,对于弹性收缩伸缩活动,执行方向解释如下:

结束 LifecycleHook 挂起状态以后,弹性伸缩服务会将 ECS 实例先从 RDS 白名单移除(如果伸缩组配置了 RDS),再将 ECS 实例停止(如果 ECS 实例是伸缩组弹出来的不是手动添加的),然后释放实例(如果 ECS 实例是伸缩组弹出来的不是手动添加的),并将实例从伸缩组中移出。

LifecycleHook 通知方式

如果生命周期挂钩配置了通知对象,那么当伸缩组发生伸缩活动触发 LifecycleHook 时,通知对象将接收到当前的伸缩活动详细信息,如果生命周期挂钩没有配置通知对象,那么当伸缩组发生伸缩活动触发 LifecycleHook 时不会发出任何通知信息。

生命周期挂钩目前支持以下两种通知方式:

关于 MNS 主题和队列的介绍,您可以参考 队列使用帮助、主题使用帮助 来了解主题、队列的创建,消息的接收方式,以及如何为主题设置订阅等。
需要注意的是,MNS 消息服务会收取相应的费用,具体的收费标准可参考 云产品定价#消息服务 进行详细了解。

LifecycleHook 通知内容

当伸缩组发生伸缩活动触发 LifecycleHook 时,如果生命周期挂钩配置了通知对象(目前只支持通知到 MNS),那么通知对象将收到关于此次伸缩活动的详细信息,通知内容如下:

{
  "content": {
    "defaultResult": "CONTINUE",
    "instanceIds": [
      "i-xxxxxxxxxx1",
      "i-xxxxxxxxxx2",
      "i-xxxxxxxxxx3",
      "i-xxxxxxxxxx4",
      "i-xxxxxxxxxx5"
    ],
    "lifecycleActionToken": "C8BEAE68-CB77-4E60-986D-1E8BBF1A6B99",
    "lifecycleHookId": "ash-wxxxxxxxxxxx",
    "lifecycleHookName": "SCALE_IN_TEST",
    "lifecycleTransition": "SCALE_IN",
    "notificationMetadata": "测试 SCALE_IN HOOK",
    "requestId": "XXXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXX",
    "scalingActivityId": "asa-xxxxxxxxxxxxxxxx",
    "scalingGroupId": "asg-xxxxxxxxxxxxxxxxx",
    "scalingGroupName": "test-hook",
    "scalingRuleId": "asr-xxxxxxxxxxxx",
    "scheduledTaskId": "xxxxxxxxxxxxxx"
  },
  "product": "ESS",
  "regionId": "cn-shenzhen",
  "resourceArn": "acs:ess:cn-shenzhen:111111111111111:scalingGroup/asg-xxxxxxxxxxxxx",
  "time": "2018-06-21T03:07:57.641Z",
  "userId": "111111111111111"
}

上述内容中:

MNS 队列或主题内容的消费方式,推荐参考 MNS 官方给出的 长轮训最佳实践 文档,使用长轮询的方式来消费队列或主题收到的消息内容。

最佳实践

创建 LifecycleHook 通知对象

在创建 LifecycleHook 时,可以配置通知对象,也可以不配置通知对象,如果需要配置通知对象,需要先创建好通知对象,再创建 LifecycleHook。关于通知对象(MNS 主题、队列)的创建方式,可以参考 ESS 事件通知#创建 MNS 队列 章节 和 ESS 事件通知#创建 MNS 主题 章节。

创建 LifecycleHook

LifecycleHook 的创建,可以通过 ESS控制台 完成,也可以通过调用 CreateLifecycleHook 接口完成。通过接口创建 LifecycleHook,可基于 CreateLifecycleHook 文档,参考 ESS 事件通知#创建事件通知(OpenAPI) 章节实现。通过 ESS控制台 创建 LifecycleHook 过程如下:

登录 ESS控制台,进入生命周期挂钩列表页,点击创建生命周期挂钩按钮,弹出创建界面如下图所示:

AutoScaling 生命周期的作用是什么

按提示名称,通知标识,选择伸缩活动类型、执行策略和通知方式,点击确定,如下图所示:

AutoScaling 生命周期的作用是什么

上图中,创建了两个 LifecycleHook,一个伸缩活动扩张类型的 LifecycleHook,一个伸缩活动收缩类型的 LifecycleHook。

触发 LifecycleHook

本章以触发弹性收缩活动为例,展示 LifecycleHook 工作过程。触发伸缩活动的方式,可参考 ESS 事件通知#创建事件通知(OpenAPI) 章节完成。

首先触发减少1台实例的伸缩活动,如下图所示:

AutoScaling 生命周期的作用是什么

查看伸缩组 ECS 实例列表页,如下图所示:

AutoScaling 生命周期的作用是什么

从上图看出,此时有一台 ECS 实例处于挂起状态,由于弹性收缩类型的 LifecycleHook 设置了通知对象,可以登录 MNS控制台 查看通知结果,消息查看方式可参考 ESS 事件通知#MNS 队列消息接收) 章节。

接收到 LifecycleHook 发送的通知内容以后,提取 lifecycleActionToken 、lifecycleHookId 参数,然后通过调用 CompleteLifecycleAction 接口提前结束 LifecycleHook 挂起状态,调用方式如下:

public class LifecycleHookTest {
    public static final String REGION_ID = "cn-hangzhou";

    public static final String AK        = "xxx";

    public static final String AKS       = "xxx";

    public static void main(String[] args) throws ClientException, Exception {
        IClientProfile clientProfile = DefaultProfile.getProfile(REGION_ID, AK, AKS);
        final IAcsClient client = new DefaultAcsClient(clientProfile);
        completeLifecycleAction(client);
    }

    private static String completeLifecycleAction(IAcsClient client) throws ClientException {
        CompleteLifecycleActionRequest request = new CompleteLifecycleActionRequest();
        request.setLifecycleHookId("ash-xxxxxxxxxxxxx");
        request.setLifecycleActionToken("xxxxxxxxxxxxxxx");
        request.setLifecycleActionResult("CONTINUE");
        CompleteLifecycleActionResponse response = client.getAcsResponse(request);
        return response.getRequestId();
    }
}

使用上述代码中,需补充个人 AK 信息,以及 LifecycleActionToken 和 LifecycleHookId 参数。

LifecycleHook 挂起状态结束以后,ECS 实例被停止(伸缩组创建的实例),然后释放(伸缩组创建的实例)并移出伸缩组。

需要注意,如果 LifecycleHook 配置的通知对象被删除,那么当前的 LifecycleHook 将不再生效。如果伸缩活动触发 LifecycleHook 被挂起,想要延长伸缩活动被挂起的时间,可以通过调用 RecordLifecycleActionHeartbeat 延长挂起时间。

关于AutoScaling 生命周期的作用是什么就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

推荐阅读:
  1. vue生命周期的作用是什么
  2. react生命周期是什么

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

autoscaling

上一篇:Python 中怎么利用GUI实现一个拖放功能

下一篇:PHP中怎么获取类和对象的属性字段

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》