更新时间:2022-02-22 GMT+08:00

修改弹性伸缩组

功能介绍

修改一个指定弹性伸缩组中的信息。

  • 更换伸缩组的伸缩配置,伸缩组中已经存在的使用之前伸缩配置创建的云服务器不受影响。
  • 伸缩组为没有正在进行的伸缩活动时,可以修改伸缩组的子网、可用区配置。
  • 当伸缩组的期望实例数改变时,会触发伸缩活动加入或移出实例。期望实例数必须大于或等于最小实例数,必须小于或等于最大实例数。

URI

PUT /autoscaling-api/v1/{project_id}/scaling_group/{scaling_group_id}

表1 参数说明

参数

是否必选

参数类型

描述

project_id

String

项目ID

scaling_group_id

String

伸缩组ID

请求消息

  • 请求参数
    表2 请求参数

    参数

    是否必选

    参数类型

    描述

    scaling_group_name

    String

    伸缩组名称(1-64个字符),只能包含中文、字母、数字、下划线或中划线。

    desire_instance_number

    Integer

    期望实例数量。

    最小实例数≤期望实例数≤最大实例数。

    min_instance_number

    Integer

    最小实例数量。

    max_instance_number

    Integer

    最大实例数量,大于等于最小实例数。

    cool_down_time

    Integer

    冷却时间,取值范围0-86400,默认为300,单位是秒。

    available_zones

    Array

    可用区信息。弹性伸缩活动中自动添加的云服务器会被创建在指定的可用区中。如果没有指定可用区,会由系统自动指定可用区。

    仅当伸缩组中无伸缩活动时,才可以修改可用区配置。

    networks

    Array

    网络信息,最多支持选择5个子网,传入的第一个子网默认作为云服务器的主网卡。数据结构信息请参考表4

    仅当同时满足以下条件时,才可以修改:

    • 伸缩组中无伸缩活动
    • 实例数为0
    • 伸缩组为非启用状态

    security_groups

    Array

    安全组信息,仅支持选择1个安全组。数据结构信息请参考表5

    当伸缩配置和伸缩组同时指定安全组时,将以伸缩配置中的安全组为准;当伸缩配置和伸缩组都没有指定安全组时,将使用默认安全组。为了使用灵活性更高,推荐在伸缩配置中指定安全组。仅当同时满足以下条件时,才可以修改:

    • 伸缩组中无伸缩活动
    • 实例数为0
    • 伸缩组为非启用状态

    lbaas_listeners

    Array

    弹性负载均衡器(增强型)信息,最多支持绑定6个负载均衡。列表数据结构请参考表3

    health_periodic_audit_method

    String

    伸缩组实例健康检查方式:ELB_AUDIT和NOVA_AUDIT。当伸缩组设置负载均衡时,默认为ELB_AUDIT;否则默认为NOVA_AUDIT。

    • ELB_AUDIT:负载均衡健康检查方式,在有监听器的伸缩组中有效。
    • NOVA_AUDIT:云服务器健康检查方式,是弹性伸缩自带的健康检查方式。

    health_periodic_audit_time

    Integer

    伸缩组实例健康检查周期(分钟):1、5、15、60、180。

    若设置为0,可以实现10秒级健康检查。

    instance_terminate_policy

    String

    伸缩组实例移除策略:

    • OLD_CONFIG_OLD_INSTANCE(默认):从“较早创建的配置”创建的实例中选择较早创建的实例进行优先移除。
    • OLD_CONFIG_NEW_INSTANCE:从“较早创建的配置”创建的实例中选择较晚创建的实例进行优先移除。
    • OLD_INSTANCE:较早创建的实例被优先移除。
    • NEW_INSTANCE:较晚创建的实例将被优先移除。

    health_periodic_audit_grace_period

    Integer

    伸缩组实例健康状况检查宽限期,取值范围0-86400,单位是秒,默认为600。

    当实例加入伸缩组并且进入已启用状态后,健康状况检查宽限期才会启动,伸缩组会等健康状况检查宽限期结束后才检查实例的运行状况。

    当伸缩组实例健康检查方式为ELB_AUDIT时,该参数生效。

    scaling_configuration_id

    String

    伸缩配置ID,通过查询弹性伸缩配置列表接口获取,请参考查询弹性伸缩配置列表

    notifications

    Array

    通知方式:

    EMAIL为发送邮件通知。

    该通知方式已经被废除,建议给弹性伸缩组配置通知功能。请参考通知

    delete_publicip

    Boolean

    配置删除云服务器是否删除云服务器绑定的弹性IP。如果选择不删除,则系统仅做解绑定操作,保留弹性IP资源。

    • true:删除云服务器时会同时删除绑定在云服务器上的弹性IP。当弹性IP的计费方式为包年包月时,不会被删除。
    • false:删除云服务器时,仅解绑定在云服务器上的弹性IP,不删除弹性IP。

    delete_volume

    Boolean

    配置删除云服务器时是否删除云服务器绑定的数据盘。取值为true或false,默认为false。

    • true:删除云服务器时,会同时删除绑定在云服务器上的数据盘。当数据盘的计费方式为包年包月时,不会被删除。
    • false:删除云服务器时,仅解绑定在云服务器上的数据盘,不删除数据盘。

    multi_az_priority_policy

    String

    伸缩组扩缩容时目标AZ选择的优先级策略:

    • EQUILIBRIUM_DISTRIBUTE(默认):均衡分布,虚拟机扩缩容时优先保证available_zones列表中各AZ下虚拟机数量均衡,当无法在目标AZ下完成虚拟机扩容时,按照PICK_FIRST原则选择其他可用AZ。
    • PICK_FIRST:选择优先,虚拟机扩缩容时目标AZ的选择按照available_zones列表的顺序进行优先级排序。
    表3 lbaas_listeners字段数据结构说明

    参数

    是否必选

    参数类型

    描述

    pool_id

    String

    后端云服务器组ID。

    仅当同时满足以下条件时,才可以修改:

    • 伸缩组中无伸缩活动
    • 实例数为0
    • 伸缩组为非启用状态

    protocol_port

    Integer

    后端协议号,指后端云服务器监听的端口,取值范围[1, 65535]。

    weight

    Integer

    权重,指后端云服务器经分发得到的请求数量的比例,取值范围[0, 100]。

    表4 networks字段数据结构说明

    参数

    是否必选

    参数类型

    描述

    id

    String

    网络ID

    表5 security_groups字段数据结构说明

    参数

    是否必选

    参数类型

    描述

    id

    String

    安全组ID。

  • 请求样例
    本示例展示了修改ID为a8327883-6b07-4497-9c61-68d03ee193a1的伸缩组,修改其名称、伸缩配置、期望实例数、最小实例数、最大实例数和冷却时间等参数。
    PUT https://{Endpoint}/autoscaling-api/v1/{project_id}/scaling_group/a8327883-6b07-4497-9c61-68d03ee193a1
    
    {
        "scaling_group_name": "group_1",
        "scaling_configuration_id": "f8327883-6a07-4497-9a61-68c03e8e72a2",
        "desire_instance_number": 1,
        "min_instance_number": 1,
        "max_instance_number": 3,
        "cool_down_time": 200,
        "multi_az_priority_policy": "PICK_FIRST"
    }

响应消息

  • 响应参数
    表6 响应参数

    参数

    参数类型

    描述

    scaling_group_id

    String

    伸缩组ID。

  • 响应样例
    {
        "scaling_group_id": "a8327883-6b07-4497-9c61-68d03ee193a1"
    }

返回值

  • 正常

    200

  • 异常

    返回值

    说明

    400 Bad Request

    服务器未能处理请求。

    401 Unauthorized

    被请求的页面需要用户名和密码。

    403 Forbidden

    对被请求的页面访问禁止。

    404 Not Found

    服务器无法找到被请求的页面。

    405 Method Not Allowed

    请求中指定的方法不被允许。

    406 Not Acceptable

    服务器生成的响应无法被客户端所接受。

    407 Proxy Authentication Required

    用户必须首先使用代理服务器进行验证,这样请求才会被处理。

    408 Request Timeout

    请求超出了服务器的等待时间。

    409 Conflict

    由于冲突,请求无法被完成。

    500 Internal Server Error

    请求未完成。服务异常。

    501 Not Implemented

    请求未完成。服务器不支持所请求的功能。

    502 Bad Gateway

    请求未完成。服务器从上游服务器收到一个无效的响应。

    503 Service Unavailable

    请求未完成。系统暂时异常。

    504 Gateway Timeout

    网关超时。

错误码

请参考错误码