文档

CreateChangeSet - 创建更改集

更新时间:

为已创建的资源栈创建更改集。

接口说明

使用说明

当您需要更新正在运行的资源栈时,可以创建并执行更改集。关于更改集的更多信息,请参见概览

使用限制

  • 一个资源栈最多同时存在 20 个更改集。
  • 更改集只显示资源栈变化,不显示资源栈是否成功更新。
  • 更改集不检查是否将超出账号限制、是否将更新不支持更新的资源、是否权限不足而无法修改资源,所有这些都将导致资源栈更新失败。如果更新失败,ROS 将尝试将您的资源回滚到原始状态。

本文将提供一个示例,在杭州地域cn-hangzhou创建一个名为MyChangeSet的更改集,将 ID 为4a6c9851-3b0f-4f5f-b4ca-a14bf691****的资源栈的模板更新为{"ROSTemplateFormatVersion":"2015-09-01"}

调试

您可以在OpenAPI Explorer中直接运行该接口,免去您计算签名的困扰。运行成功后,OpenAPI Explorer可以自动生成SDK代码示例。

授权信息

下表是API对应的授权信息,可以在RAM权限策略语句的Action元素中使用,用来给RAM用户或RAM角色授予调用此API的权限。具体说明如下:

  • 操作:是指具体的权限点。
  • 访问级别:是指每个操作的访问级别,取值为写入(Write)、读取(Read)或列出(List)。
  • 资源类型:是指操作中支持授权的资源类型。具体说明如下:
    • 对于必选的资源类型,用背景高亮的方式表示。
    • 对于不支持资源级授权的操作,用全部资源表示。
  • 条件关键字:是指云产品自身定义的条件关键字。
  • 关联操作:是指成功执行操作所需要的其他权限。操作者必须同时具备关联操作的权限,操作才能成功。
操作访问级别资源类型条件关键字关联操作
ros:CreateChangeSetWrite
  • Stack
    acs:ros:{#regionId}:{#accountId}:stack/{#StackId}

请求参数

名称类型必填描述示例值
StackIdstring

创建更改集的资源栈的 ID。ROS 通过将此资源栈的信息与您提交的信息(例如:修改后的模板或不同的参数输入值)进行比较来生成更改集。

说明 该参数仅在更改集类型为 UPDATE 或 IMPORT 时生效。
4a6c9851-3b0f-4f5f-b4ca-a14bf691****
StackPolicyURLstring

包含资源栈策略的文件的位置。URL 必须指向位于 Web 服务器(HTTP 或 HTTPS)或阿里云 OSS 存储空间(例如:oss://ros/stack-policy/demo、oss://ros/stack-policy/demo?RegionId=cn-hangzhou)的策略,策略文件长为 16384 个字节。

说明 OSS 地域如未指定,默认与接口参数 RegionId 相同。

您仅能指定 StackPolicyBody 或 StackPolicyURL 其中一个参数。
URL 的最大长度为 1350 个字节。

当更改集类型为 CREATE 时,您可以指定 StackPolicyBody 或 StackPolicyURL 参数,但不能同时指定。当更改集类型为 UPDATE 时,您仅能指定以下参数之一:

  • StackPolicyBody
  • StackPolicyURL
  • StackPolicyDuringUpdateBody
  • StackPolicyDuringUpdateURL
oss://ros/stack-policy/demo
StackPolicyBodystring

资源栈策略的结构,长度为 1~16,384 个字节。当更改集类型为 CREATE 时,您仅能指定 StackPolicyBody 或 StackPolicyURL 其中一个参数。 当更改集类型为 UPDATE 时,您仅能指定以下参数之一:

  • StackPolicyBody
  • StackPolicyURL
  • StackPolicyDuringUpdateBody
  • StackPolicyDuringUpdateURL
{"Statement":[{"Effect":"Allow","Action":"Update:*","Principal":"*","Resource":"*"}]}
StackNamestring

创建更改集的资源栈的名称。
长度不超过 255 个字符。必须以数字或英文字母开头,可包含数字、英文字母、短划线(-)和下划线(_)。

说明 该参数仅在更改集类型为 CREATE 或 IMPORT 时生效。
MyStack
UsePreviousParametersboolean

对于未传递的参数,是否使用上次传递的值。取值:

  • true
  • false(默认值)
说明 该参数仅在更改集类型为 UPDATE 或 IMPORT 时生效。
true
ChangeSetTypestring

更改集的类型。取值:

  • CREATE:为新资源栈创建更改集。
  • UPDATE(默认值):为现有资源栈创建更改集。
  • IMPORT:为新资源栈或现有资源栈创建更改集导入非 ROS 托管资源。

当为新资源栈创建更改集时,ROS 会创建具有唯一资源栈 ID 的资源栈,资源栈将处于 REVIEW_IN_PROGRESS 状态,直到您执行更改集。
禁止使用 UPDATE 类型为新资源栈创建更改集,或使用 CREATE 类型为现有资源栈创建更改集。

UPDATE
Descriptionstring

更改集的描述。最大长度为 1024 个字节。

It is a demo.
RegionIdstring

更改集所属的地域 ID。您可以调用 DescribeRegions 查看最新的阿里云地域列表。

cn-hangzhou
ClientTokenstring

保证请求的幂等性。该参数值由客户端生成,并且必须全局唯一。
长度不超过 64 个字符。可包含英文字母、数字、短划线(-)和下划线(_)。
更多详情,请参见如何保证幂等性

123e4567-e89b-12d3-a456-42665544****
TemplateURLstring

包含模板主体的文件的位置。URL 必须指向位于 Web 服务器(HTTP 或 HTTPS)或阿里云 OSS 存储空间(例如:oss://ros/template/demo、oss://ros/template/demo?RegionId=cn-hangzhou)中的模板,模板最大值为 524,288 个字节。

说明 如果 OSS 地域未指定,默认与接口参数 RegionId 相同。

您仅能指定 TemplateBody、TemplateURL 或 TemplateId 其中一个参数。

URL 最大长度为 1024 个字节。

oss://ros/template/demo
StackPolicyDuringUpdateURLstring

更新资源栈策略的文件的位置。URL 必须指向位于 Web 服务器(HTTP 或 HTTPS)或阿里云 OSS 存储空间(例如:oss://ros/stack-policy/demo、oss://ros/stack-policy/demo?RegionId=cn-hangzhou)中的策略,策略文件最长为 16,384 个字节。

说明 OSS 地域如未指定,默认与接口参数 RegionId 相同。

URL 最大长度为 1350 个字节。
如果要更新受保护的资源,请在更新期间指定临时覆盖资源栈策略。如果未指定资源栈策略,则将使用与资源栈关联的当前策略。该参数仅在更改集类型为 UPDATE 时生效。您仅能指定以下参数之一:

  • StackPolicyBody
  • StackPolicyURL
  • StackPolicyDuringUpdateBody
  • StackPolicyDuringUpdateURL
oss://ros/stack-policy/demo
TemplateBodystring

模板主体的结构。长度为 1~524,288 个字节。如果长度较大,则建议通过 HTTP POST+Body Param 的方式,将参数放在请求体中进行传递,避免因 URL 过长而导致请求失败。

说明 您必须且仅能指定 TemplateBody、TemplateURL 或 TemplateId 其中一个参数。
{"ROSTemplateFormatVersion":"2015-09-01"}
TimeoutInMinuteslong

资源栈状态变为 CREATE_FAILED 或 UPDATE_FAILED 之前可以经过的时间量。
当更改集类型为 CREATE 时,该参数为必选参数;当更改集类型为 UPDATE 时,该参数为可选参数。

  • 单位:分钟。

  • 取值范围:10~1440。

  • 默认值:60。

12
DisableRollbackboolean

当创建资源栈失败时,是否禁用回滚策略。
取值:

  • true:禁用回滚,即在创建资源栈失败时不进行回滚。

  • false(默认值):不禁用回滚,即在创建资源栈失败时进行回滚。

说明 该参数仅在更改集类型为 CREATE 或 IMPORT 时生效。
false
ChangeSetNamestring

更改集的名称。
长度不超过 255 个字符。必须以数字或英文字母开头,可包含数字、英文字母、短划线(-)和下划线(_)。

说明 更改集名称在与指定资源栈关联的所有更改集中必须是唯一的。
MyChangeSet
StackPolicyDuringUpdateBodystring

临时覆盖资源栈策略的结构。长度为 1~16,384 个字节。
如果要更新受保护资源,请在此更新期间指定临时覆盖资源栈策略,如未指定,则将使用与资源栈关联的当前策略。
该参数仅在更改集类型为 UPDATE 时生效,您仅能指定以下参数之一:

  • StackPolicyBody
  • StackPolicyURL
  • StackPolicyDuringUpdateBody
  • StackPolicyDuringUpdateURL
{"Statement":[{"Effect":"Allow","Action":"Update:*","Principal":"*","Resource":"*"}]}
RamRoleNamestring

RAM 角色名称。ROS 会扮演该角色创建资源栈,使用角色的凭证代表用户进行接口调用。
ROS 始终将此角色用于资源栈上将进行的操作。只要用户有权在资源栈上进行操作,即使用户无权使用角色,ROS 也会使用此角色,确保角色授予最少的权限。
如果用户未指定该值,ROS 将使用以前与资源栈关联的角色。如果没有可用角色,ROS 将使用从您的用户凭证中生成的临时凭证。
RAM 角色名称最大长度为 64 个字节。

test-role
ReplacementOptionstring

如果资源的属性发生了变化,且变化的属性不支持修改更新(资源物理 ID 不变),是否使用替换更新(删除资源,重新创建,资源物理 ID 会发生变化)。取值:

  • Enabled:允许替换更新。
  • Disabled(默认):不允许替换更新。
说明 修改更新的优先级高于替换更新。该参数仅在更改集类型为 UPDATE 时生效。
Disabled
TemplateIdstring

模板 ID。支持共享模板和私有模板。

您仅能指定 TemplateBody、TemplateURL 或 TemplateId 其中一个参数。

5ecd1e10-b0e9-4389-a565-e4c15efc****
TemplateVersionstring

模板版本。

说明 该参数仅在指定 TemplateId 时生效。
v1
Parametersobject []

模板中已定义的参数。

ParameterKeystring

模板中已定义的参数的名称。如果未指定特定参数的名称和取值,则 ROS 将使用模板中指定的默认值。N 的最大值为 200。

说明 Parameters 为可选参数。若指定了 Parameters,则 Parameters.N.ParameterKey 为必选参数。
Amount
ParameterValuestring

模板中已定义的参数的取值。N 的最大值为 200。

说明 Parameters 为可选参数。若指定了 Parameters,则 Parameters.N.ParameterValue 为必选参数。
12
NotificationURLsarray

接收资源栈事件的回调地址列表。

string

接收资源栈事件的回调地址。取值:

  • HTTP POST URL
    每个 URL 最大长度为 1024 个字节。

  • eventbridge
    资源栈状态变更会通知到事件总线(EventBridge)服务。您可以登录事件总线控制台 ,在左侧导航栏单击事件总线,查看事件信息。

说明 当前支持华东 1(杭州)、华东 2(上海)、华北 2(北京)、中国(香港)、华北 3(张家口)五个地域。

N 最大值为 5。资源栈的状态发生变化时,会进行通知。当资源栈启用回滚时,CREATE_FAILED(创建失败)和 UPDATE_FAILED(更新失败)不会通知,而 CREATE_ROLLBACK(创建失败回滚)和 ROLLBACK(更新失败回滚)会进行通知。IN_PROGRESS 状态不会通知。
无论资源栈是否定义了 Outputs 都会进行通知。通知内容示例如下:

{
   "Outputs": [
       {
           "Description": "No description given",
           "OutputKey": "InstanceId",
           "OutputValue": "i-xxx"
       }
   ],
   "StackId": "80bd6b6c-e888-4573-ae3b-93d29113****",
   "StackName": "test-notification-url",
   "Status": "CREATE_COMPLETE"
}
http://example.com/ros-notify
ResourcesToImportobject []

待导入资源列表。

ResourceIdentifierstring

字符串到字符串的键值映射。取值是 JSON 格式的字符串,用来标识要导入的资源。
键是资源的标识符属性(例如:ALIYUN::ECS::VPC 资源的 VpcId),值是属性的取值(例如:vpc-2zevx9ios****)。资源的键可以通过 GetTemplateSummary 接口获取。

说明 该参数仅在更改集类型为 IMPORT 时生效。ResourcesToImport 为可选参数。若指定了 ResourcesToImport,则 ResourcesToImport.N.ResourceIdentifier 为必选参数。
{"VpcId": "vpc-2zevx9ios******"}
LogicalResourceIdstring

资源逻辑 ID,即模板中资源的名称。

说明 该参数仅在更改集类型为 IMPORT 时生效。ResourcesToImport 为可选参数。若指定了 ResourcesToImport,则 ResourcesToImport.N.LogicalResourceId 为必选参数。
Vpc
ResourceTypestring

资源的类型,需要与模板中定义的类型一致。

说明 该参数仅在更改集类型为 IMPORT 时生效。ResourcesToImport 为可选参数。若指定了 ResourcesToImport,则 ResourcesToImport.N.ResourceType 为必选参数。
ALIYUN::ECS::VPC
TemplateScratchIdstring

场景模板 ID。

4a6c9851-3b0f-4f5f-b4ca-a14bf691****
Parallelismlong

资源最大并发数。默认为空,用户可以输入大于等于零的整数。设置资源最大并发数后,将与资源栈进行关联,影响资源栈的后续操作。

该参数仅在更改集类型为 CREATE 或 UPDATE 时生效,取值:

  • 当更改集类型为 CREATE 时

    • 设置为大于零的整数:使用整数值。
    • 设置为零或者不设置:对于 ROS 类型资源栈不限制,Terraform 类型资源栈使用 Terraform 默认值(通常为 10)。
  • 当更改集类型为 UPDATE 时

    • 设置为大于零的整数:使用整数值。
    • 设置为零:对于 ROS 类型资源栈不限制,Terraform 类型资源栈使用 Terraform 默认值(通常为 10)。
    • 不设置:使用上次操作时设置的值。如果上次操作时未设置该参数,对于 ROS 类型资源栈不限制,Terraform 类型资源栈使用 Terraform 默认值(通常为 10)。
1

关于公共请求参数的详情,请参见公共参数

返回参数

名称类型描述示例值
object
ChangeSetIdstring

更改集 ID。

e85abe0c-6528-43fb-ae93-fdf8de22****
RequestIdstring

请求 ID。

B288A0BE-D927-4888-B0F7-B35EF84B6E6F
StackIdstring

资源栈 ID。

4a6c9851-3b0f-4f5f-b4ca-a14bf691****

示例

正常返回示例

JSON格式

{
  "ChangeSetId": "e85abe0c-6528-43fb-ae93-fdf8de22****",
  "RequestId": "B288A0BE-D927-4888-B0F7-B35EF84B6E6F",
  "StackId": "4a6c9851-3b0f-4f5f-b4ca-a14bf691****"
}

错误码

访问错误中心查看更多错误码。

变更历史

变更时间变更内容概要操作
2024-01-11API 内部配置变更,不影响调用看变更集
变更项变更内容
API 内部配置变更,不影响调用
2023-08-15API 内部配置变更,不影响调用看变更集
变更项变更内容
API 内部配置变更,不影响调用
HttpCode错误码错误信息描述
400CircularDependencyCircular Dependency Found: {reason}.模板包含循环引用。reason 为具体原因。
400InvalidSchema{reason}.模板格式不正确。reason 为具体原因。
400InvalidTemplateAttributeThe Referenced Attribute ({resource} {name}) is incorrect.模板包含不正确的资源属性(输出)引用。resource 为资源名,name 为属性名。
400InvalidTemplatePropertyTypeThe specified value type of ({resource} {section}) is incorrect.模板资源定义中的字段类型不正确。resource 为资源名,section 为字段名。
400InvalidTemplateReferenceThe specified reference "{name}" (in {referencer}) is incorrect.模板包含不正确的引用。name 为引用名,referencer 为引用者。
400InvalidTemplateSectionThe template section is invalid: {section}.模板包含无效的字段。section 为字段名。
400InvalidTemplateVersionThe template version is invalid: {reason}.模板版本不正确。reason 为具体原因。
400StackPolicyValidationFailedAction denied by stack policy: {reason}.未通过资源栈策略校验。reason 为具体原因。
400StackValidationFailed{reason}.资源栈校验失败。reason 为具体原因。
400UnknownUserParameterThe Parameter ({name}) was not defined in template.传递的参数在模板中未定义。name 为参数名。
400UserParameterMissingThe Parameter {name} was not provided.参数在模板中已定义,但未传递值。name 为参数名。
404StackNotFoundThe Stack ({name}) could not be found.资源栈不存在。name 为资源栈名称或 ID。
409ActionInProgressStack {name} already has an action ({action}) in progress.资源栈在变更中。name 为资源栈名称或 ID,action 为具体的变更操作。
409ChangeSetExistsThe ChangeSet ({name}) of Stack ({stack}) already exists.同名更改集已存在。name 为更改集名,stack 为关联的资源栈名称或 ID。
409StackExistsThe Stack ({name}) already exists.同名资源栈已存在。name 为资源栈名称。
404TemplateNotFoundThe Tempalte ({ ID }) could not be found.模板不存在。ID 为模板 ID。
404TemplateNotFoundThe Template { ID } with version { version } could not be found.模板或指定版本不存在。ID 为模板 ID,version 为模板版本。
  • 本页导读 (1)
文档反馈