使用Count功能批量创建资源

简介: 本场景将以批量创建ECS实例和EIP,并为ECS实例绑定EIP为例,为您介绍如何使用Count功能。

使用Count功能批量创建资源

1. 编写ROS模板

背景说明

ALIYUN::VPC::EIP类型用于申请弹性公网IP(EIP)。如果需要申请多个弹性公网IP,则需要在模板中编写多个ALIYUN::VPC::EIP资源,这样模板会变得冗长。此时您可以使用Count功能批量创建资源。Count功能详情,请参见Count。此外,使用Count批量创建多组资源时可以通过为资源指定DependsOn并设置参数(ParallelCount)进行资源创建的并发控制。

编写ROS模版

您可以使用Count功能编写模板,创建以下资源:

1个VPC(专有网络)

1个vSwitch(交换机)

1个SecurityGroup(安全组)

4个ECS(按量付费的ECS)

4个EIP(弹性公网IP)

模板说明

当Count取值为4,会创建4个EIP资源。使用Count功能时,ParallelCount取值为2,此时会分两批创建4个EIP资源。通过ROS的预处理,会生成名为Eip[0]和Eip[1](第一批)、Eip[2]和Eip[3](第二批)的4个EIP资源。

当Count取值为4,ParallelCount取值为2,会创建4个EipBind资源,通过ALIYUN::Index伪参数逐一绑定ECS实例和EIP,此时会分两批创建4个EipBind资源。通过ROS的预处理,会生成名为EipBind[0]和EipBind[1](第一批)、EipBind[2]和EipBind[3](第二批)的4个资源。ALIYUN::Index在Count中使用,在预处理时会被替换为相应的数值。本示例中将逐一绑定ECS实例与EIP,即第1个实例绑定Eip[0]、第2个实例绑定Eip[1]、第3个实例绑定Eip[2]、第4个实例绑定Eip[3]。

当Count取值为4。将ALIYUN::ECS::InstanceGroup的MaxAmount指定为Count,取值为4,会创建4台ECS实例。

说明:请注意本模版创建的资源均属于付费云产品资源,请您体验完成后及时释放,避免造成资产浪费。

{
  "ROSTemplateFormatVersion": "2015-09-01",
  "Parameters": {
    "Count": {
      "Type": "Number",
      "Default": 4
    },
    "ZoneId": {
      "Type": "String"
    },
    "InstanceType": {
      "Type": "String",
      "Default": "ecs.c6.large"
    },
    "Password": {
      "Type": "String",
      "Default": "Abc1****",
      "NoEcho": true
    },
    "ParallelCount": {
      "Type": "Number",
      "Default": 2
    },
    "SystemDiskCategory": {
      "Type": "String"
    }
  },
  "Metadata": {
    "ALIYUN::ROS::Interface": {
      "ParameterGroups": [
        {
          "Parameters": [
            "Count",
            "ZoneId",
            "InstanceType",
            "Password",
            "ParallelCount",
            "SystemDiskCategory"
          ],
          "Label": {
            "default": {
              "zh-cn": "基础配置",
              "en": "Basic Configuration"
            }
          }
        }
      ],
      "TemplateTags": [
        "acs:example:云起实验室:使用Count功能批量创建资源"
      ]
    }
  },
  "Resources": {
    "Vpc": {
      "Type": "ALIYUN::ECS::VPC",
      "Properties": {
        "CidrBlock": "10.0.0.0/8",
        "VpcName": "test-resource-count"
      }
    },
    "VSwitch": {
      "Type": "ALIYUN::ECS::VSwitch",
      "Properties": {
        "CidrBlock": "10.0.10.0/24",
        "ZoneId": {
          "Ref": "ZoneId"
        },
        "VpcId": {
          "Ref": "Vpc"
        }
      }
    },
    "SecurityGroup": {
      "Type": "ALIYUN::ECS::SecurityGroup",
      "Properties": {
        "SecurityGroupName": "test-resource-count",
        "VpcId": {
          "Ref": "Vpc"
        }
      }
    },
    "Eip": {
      "Type": "ALIYUN::VPC::EIP",
      "Count": {
        "Ref": "Count"
      },
      "DependsOn": {
        "Fn::Select": [
          {
            "Fn::Calculate": [
              "1-{0}//{1}",
              0,
              [
                {
                  "Fn::Min": [
                    {
                      "Ref": "ALIYUN::Index"
                    },
                    {
                      "Ref": "ParallelCount"
                    }
                  ]
                },
                {
                  "Ref": "ParallelCount"
                }
              ]
            ]
          },
          [
            {
              "Fn::Replace": [
                {
                  "index": {
                    "Fn::Calculate": [
                      "{0}-{1}",
                      0,
                      [
                        {
                          "Ref": "ALIYUN::Index"
                        },
                        {
                          "Ref": "ParallelCount"
                        }
                      ]
                    ]
                  }
                },
                "Eip[index]"
              ]
            }
          ]
        ]
      },
      "Properties": {
        "Bandwidth": 5
      }
    },
    "Servers": {
      "Type": "ALIYUN::ECS::InstanceGroup",
      "Properties": {
        "ImageId": "centos_7",
        "InstanceType": {
          "Ref": "InstanceType"
        },
        "VpcId": {
          "Ref": "Vpc"
        },
        "VSwitchId": {
          "Ref": "VSwitch"
        },
        "SecurityGroupId": {
          "Ref": "SecurityGroup"
        },
        "Password": {
          "Ref": "Password"
        },
        "AllocatePublicIP": false,
        "MaxAmount": {
          "Ref": "Count"
        },
        "SystemDiskCategory": {
          "Ref": "SystemDiskCategory"
        }
      }
    },
    "EipBind": {
      "Type": "ALIYUN::VPC::EIPAssociation",
      "Count": {
        "Ref": "Count"
      },
      "DependsOn": {
        "Fn::Select": [
          {
            "Fn::Calculate": [
              "1-{0}//{1}",
              0,
              [
                {
                  "Fn::Min": [
                    {
                      "Ref": "ALIYUN::Index"
                    },
                    {
                      "Ref": "ParallelCount"
                    }
                  ]
                },
                {
                  "Ref": "ParallelCount"
                }
              ]
            ]
          },
          [
            {
              "Fn::Replace": [
                {
                  "index": {
                    "Fn::Calculate": [
                      "{0}-{1}",
                      0,
                      [
                        {
                          "Ref": "ALIYUN::Index"
                        },
                        {
                          "Ref": "ParallelCount"
                        }
                      ]
                    ]
                  }
                },
                "EipBind[index]"
              ]
            }
          ]
        ]
      },
      "Properties": {
        "InstanceId": {
          "Fn::Select": [
            {
              "Ref": "ALIYUN::Index"
            },
            {
              "Fn::GetAtt": [
                "Servers",
                "InstanceIds"
              ]
            }
          ]
        },
        "AllocationId": {
          "Fn::Select": [
            {
              "Ref": "ALIYUN::Index"
            },
            {
              "Ref": "Eip"
            }
          ]
        }
      }
    }
  },
  "Outputs": {
    "InstanceIds": {
      "Value": {
        "Fn::GetAtt": [
          "Servers",
          "InstanceIds"
        ]
      }
    },
    "AllocationIds": {
      "Value": {
        "Ref": "Eip"
      }
    },
    "EipAddresses": {
      "Value": {
        "Fn::GetAtt": [
          "Eip",
          "EipAddress"
        ]
      }
    }
  }
}

2. 创建资源栈

以下操作需登录阿里云账号,在资源编排控制台完成以下操作流程。

访问资源编排控制台

1. 进入资源编排控制台

访问资源栈页面

2. 在资源编排控制台左侧导航栏中单机资源栈。

选择资源创建地域

3. 在页面左上角的地域下拉列表,选择资源栈的所在地域(例如:华北2:北京)。

创建资源栈

4. 在资源栈列表页面,单击创建资源栈,然后在下拉列表中选择使用新资源(标准)

输入模板

5. 在选择模板页面,选择已有模板:选择输入模板方式,然后将上述示例模板内容复制到模板内容输入框内。然后单击下一步

模板参数配置

6. 在配置模板参数页面,配置资源栈名称及其余参数,然后单击下一步

资源栈参数说明

参数

说明

ZoneId

专有网络下的交换机可用区ID。

InstanceType

ECS实例的规格。

请选用有效的实例规格。更多信息,请参见实例规格族

SystemDiskCategory

ECS系统盘的类型。取值:

  • cloud_efficiency:高效云盘。
  • cloud_ssd:SSD云盘。
  • cloud_essd:ESSD云盘。
  • cloud:普通云盘。
  • ephemeral_ssd:本地SSD盘。

更多信息,请参见云盘概述

Password

ECS实例的密码。

Count

创建ECS与EIP的个数

ParallelCount

每批并发处理资源的数量

资源栈信息配置

配置项

说明

资源栈策略

取值:

  • 无资源栈策略:不设置资源栈策略。
  • 输入资源栈策略:上传文件或在文本框手动输入资源栈策略。

关于资源栈策略的更多信息,请参见资源栈策略

失败时回滚

取值:

  • 已启用:创建资源栈失败时,启用回滚策略。
  • 已禁用:创建资源栈失败时,禁用回滚策略。

超时设置

如果所有资源的创建或更新没有在该时间内完成,系统将自动回滚到创建或更新之前的状态。

取值范围:10~1440。

单位:分钟。

删除保护

防止资源栈被意外删除。取值:

  • 已启用:启用删除保护。
  • 已禁用:禁用删除保护。

RAM角色

您可以创建可信实体为资源编排服务的RAM角色,然后根据ROS模板中资源所需最小权限为RAM角色授权。

标签

由一对键值对组成,方便您对资源栈进行分类。

您可以单击添加,然后在编辑标签绑定对话框设置标签键标签值,最后单击确定

资源组

您可以选择资源栈所在的资源组。如果不指定资源组,资源栈将加入默认资源组。

关于如何创建资源组,请参见创建资源组

创建资源栈

7. 在检查并确认页面,单击创建。

3. 查看资源栈

本步骤将指导您在完成创建资源栈操作后,如何查询资源栈详情。

1. 进入资源编排控制台

2. 在左侧导航栏单击资源栈

3. 在页面左上角的地域下拉列表,选择资源栈的所在地域。

4. 在资源栈列表页面,找到需要查看的资源栈,单击资源栈名称列的资源栈ID

查看资源栈资源

5. 单击资源页签,查看资源栈创建涉及到的资源。

说明:本场景创建的云产品资源涉及扣费,体验完成后为避免资产浪费,请您及时释放。您可以点击资源列表下的EcsInstance栏中的ECS实例ID,即可跳转至ECS控制台查看本次创建的ECS资源信息。

4. 释放资源栈

本步骤将指导您如何释放通过资源编排控制台创建资源内容。

进入资源栈列表

1. 在资源栈列表页面,找到您创建的资源栈,单击操作列下的删除。

选择资源栈删除方式并删除

2. 在删除资源栈对话框中,删除方式选择释放资源,单击确定。

实验链接:https://developer.aliyun.com/adc/scenario/c98b50eb66ab4e03b5df44d13150cb0c

相关实践学习
2分钟自动化部署人生模拟器
本场景将带你借助云效流水线Flow实现人生模拟器小游戏的自动化部署
7天玩转云服务器
云服务器ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,可降低 IT 成本,提升运维效率。本课程手把手带你了解ECS、掌握基本操作、动手实操快照管理、镜像管理等。了解产品详情: https://www.aliyun.com/product/ecs
相关文章
|
30天前
|
Windows
该文件没有与之关联的应用来执行该操作。请安装应用,若已经安装应用,请在“默认应用设置“页面中创建关联
【10月更文挑战第22天】当你遇到“该文件没有与之关联的应用来执行该操作”的提示时,通常是因为文件类型未关联应用或文件损坏。解决方法包括:1. 确定文件类型并安装合适的应用程序,如Microsoft Office、Adobe Acrobat Reader等;2. 如果已安装应用,进入系统设置关联文件类型;3. 检查文件完整性,重新下载或验证文件格式。
1005 1
|
5月前
|
SQL XML JSON
技术心得:查询重置功能的实现
技术心得:查询重置功能的实现
37 0
UE4 更新资源时修改导入设置
UE4 更新资源时修改导入设置
110 0
UE4 更新资源时修改导入设置
|
6月前
|
JSON 数据中心 数据格式
Terraform 系列 - 批量创建资源时如何根据某个字段判断是否创建
Terraform 系列 - 批量创建资源时如何根据某个字段判断是否创建
|
设计模式 Java API
使用Spring框架创建一个RESTful API,实现学生信息的管理,包括资源的创建、读取、更新和删除。
在当今的Web应用程序开发中,RESTful API(Representational State Transferful Application Programming Interface)变得越来越重要。Spring框架提供了强大的工具和功能,以便轻松创建、读取、更新和删除(CRUD)资源。在这篇文章中,我们将深入探讨如何使用Spring框架创建一个RESTful API,并通过一个完整的示例演示。
343 0
|
BI 数据处理 开发工具
【批量创建,删除工作表】
【批量创建,删除工作表】
流程定义查询和删除
流程定义查询流程定义查询和删除
【TP5】不重复添加数据(案例:专题下的视频管理)
【TP5】不重复添加数据(案例:专题下的视频管理)
197 0
【TP5】不重复添加数据(案例:专题下的视频管理)
|
API
自定义资源粒度RAM权限测试
问题: 1.资源组 和 资源策略里面的资源不是一个概念 2.测试全局的全称策略资源粒度的授权
210 0
自定义资源粒度RAM权限测试
|
弹性计算 运维 监控
基于标签(TAG)批量管理资源
如何基于标签实现批量管理资源的实践?比如:基于标签中指定环境(key=env)为预发(value=pre)加应用名称(key=appname, value=alipay)的资源来批量启动;批量安装插件;批量启动机器;批量更换操作系统;批量升级带宽;批量删除资源等等。
2273 0
基于标签(TAG)批量管理资源