全部產品
Search
文件中心

:ALIYUN::ECS::Instance

更新時間:Dec 06, 2024

ALIYUN::ECS::Instance類型用於建立ECS執行個體。

重要

本資源已停止迭代更新,建議您使用 ALIYUN::ECS::InstanceGroup 資源。

文法

{
  "Type": "ALIYUN::ECS::Instance",
  "Properties": {
    "DedicatedHostId": String,
    "Period": Number,
    "AutoRenew": String,
    "RamRoleName": String,
    "IoOptimized": String,
    "InternetChargeType": String,
    "PrivateIpAddress": String,
    "KeyPairName": String,
    "SystemDiskDiskName": String,
    "PeriodUnit": String,
    "Description": String,
    "Tags": List,
    "HostName": String,
    "AutoRenewPeriod": Number,
    "ImageId": String,
    "ResourceGroupId": String,
    "InstanceChargeType": String,
    "VSwitchId": String,
    "Password": String,
    "PasswordInherit": Boolean,
    "InstanceType": String,
    "SystemDiskCategory": String,
    "UserData": String,
    "SystemDiskSize": Number,
    "ZoneId": String,
    "InternetMaxBandwidthOut": Integer,
    "VpcId": String,
    "SpotStrategy": String,
    "InstanceName": String,
    "DeletionProtection": Boolean,
    "DeploymentSetId": String,
    "SecurityGroupIds": List,
    "SecurityGroupId": String,
    "SecurityEnhancementStrategy": String,
    "SpotPriceLimit": String,
    "HpcClusterId": String,
    "AllocatePublicIP": Boolean,
    "SystemDiskDescription": String,
    "SystemDiskPerformanceLevel": String,
    "DiskMappings": List,
    "SpotInterruptionBehavior": String,
    "ZoneIds": List,
    "SpotDuration": Integer,
    "CreditSpecification": String,
    "PrivatePoolOptions": Map,
    "StorageSetId": String,
    "HttpTokens": String,
    "HttpEndpoint": String,
    "Tenancy": String,
    "StorageSetPartitionNumber": Integer,
    "DeploymentSetGroupNo": Integer,
    "Affinity": String,
    "UseAdditionalService": Boolean,
    "ImageFamily": String
  }
}

屬性

屬性名稱

類型

必須

允許更新

描述

約束

ResourceGroupId

String

資源群組ID。

SpotInterruptionBehavior

String

搶佔執行個體中斷模式。

目前僅支援Terminate(預設)直接釋放執行個體。

ZoneIds

List

可用性區域列表。

僅在控制台選取參數時生效。

SpotDuration

Integer

搶佔式執行個體的保留時間長度。

取值範圍:0~6。

單位:小時。

  • 取值為0,則為無保護期模式。

  • 保留時間長度2~6正在邀測中,如需開通請提交工單。

  • 預設值為1。

SecurityGroupIds

List

安全性群組ID列表。

SecurityGroupId和SecurityGroupIds僅能指定其中一個。

ImageId

String

鏡像ID。包括公用鏡像、自訂鏡像和雲市場鏡像。

支援通過模糊的方式指定公用鏡像ID,無需指定一個完整的公用鏡像ID。例如:

  • 指定ubuntu,最終會匹配ubuntu16_0402_64_20G_alibase_20170818.vhd。

  • 指定ubuntu_14,最終會匹配ubuntu_14_0405_64_20G_alibase_20170824.vhd。

  • 指定ubuntu*14*32,最終會匹配ubuntu_14_0405_32_40G_alibase_20170711.vhd。

  • 指定ubuntu_16_0402_32,最終會匹配ubuntu_16_0402_32_40G_alibase_20170711.vhd。

InstanceType

String

ECS執行個體規格。

關於ECS執行個體規格的更多資訊,請參見執行個體規格類型系列

SecurityGroupId

String

安全性群組ID。

SecurityGroupId和SecurityGroupIds僅能指定其中一個。

SecurityEnhancementStrategy

String

是否開啟安全強化。

取值:

  • Active:啟用安全強化,只對公用鏡像生效。

  • Deactive(預設值):不啟用安全強化,對所有鏡像類型生效。

Description

String

描述資訊。

長度為2~256個字元。

InstanceName

String

執行個體名稱。

長度為2~128個字元。必須以英文字母或漢字開頭,不能以http://https://開頭。可包含數字、半形冒號(:)、底線(_)或短劃線(-)。

如果沒有指定該屬性,預設值為執行個體的InstanceId。

Password

String

ECS執行個體登入密碼。

長度為8~30個字元。必須同時包含大寫英文字母、小寫英文字母、數字和特殊字元中至少三種,支援特殊字元:( ) ' ~ ! @ # $ % ^ & * - + = | { } [ ] : ; < > , . ? / -。如果指定該屬性,請使用HTTPS協議調用API,以避免密碼泄露。

PasswordInherit

Boolean

是否使用鏡像預設的密碼。

取值:

  • true:使用。

  • false(預設值):不使用。

說明

使用該屬性時,Password必須為空白,同時您需要確保使用的鏡像已經設定了密碼。

HostName

String

雲端服務器的主機名稱。

最小長度為2個字元。半形句號(.)和短劃線(-)不能作為主機名稱的首尾字元,且不能連續使用。

  • Windows平台最大長度為15個字元,支援英文字母、數字或短劃線(-)。不支援半形句號(.),不能全是數字。

  • 其它(Linux等)平台最大長度為30個字元,以半形句號(.)間隔,每段可以由英文字母、數字和短劃線(-)組成。

AllocatePublicIP

Boolean

是否分配公網IP。

取值:

  • true(預設值):分配公網IP。

  • false:不分配公網IP。

說明

如果InternetMaxBandwidthOut取值大於0,則會分配公網IP。

PrivateIpAddress

String

在專用網路環境下,指定的內網IP。

IP地址不能與專用網路下的其它執行個體重複。

InternetChargeType

String

訪問公網計費方式。

取值:

  • PayByBandwidth:按固定頻寬計費。

  • PayByTraffic(預設值):按流量計費。

InternetMaxBandwidthOut

Integer

公網出頻寬最大值。

取值範圍:0~100。

預設值:0。

單位:Mbps。

IoOptimized

String

是否建立I/O最佳化執行個體。

取值:

  • none:不建立I/O最佳化執行個體。

  • optimized(預設值):建立I/O最佳化執行個體。

DiskMappings

List

需要掛載的資料盤。

最多支援16塊資料盤。

更多資訊,請參見DiskMappings文法DiskMappings屬性

SystemDiskCategory

String

系統硬碟類型。

取值:

  • cloud:普通雲端硬碟。

  • cloud_ssd:SSD雲端硬碟。

  • cloud_efficiency:高效雲端硬碟。

  • cloud_essd:ESSD雲端硬碟。

  • ephemeral_ssd:本地SSD盤。

已停售的執行個體規格且非I/O最佳化執行個體預設值為cloud,否則預設值為cloud_efficiency。

SystemDiskDescription

String

系統硬碟描述資訊。

SystemDiskDiskName

String

系統硬碟名稱。

長度為2~128個字元。必須以英文字母或漢字開頭,不能以http://https://開頭。可包含數字、半形冒號(:)、底線(_)和短劃線(-)。

SystemDiskSize

Number

系統硬碟大小。

取值範圍:20~500。

單位:GB。

如果使用自訂鏡像建立系統硬碟,需要保證系統硬碟大於自訂鏡像大小。

Tags

List

使用者自訂標籤。

最多支援20個標籤,格式:[{"Key": "tagKey", "Value": "tagValue"},{"Key": "tagKey2", "Value": "tagValue2"}]

更多資訊,請參見Tags文法Tags屬性

UserData

String

建立ECS執行個體時傳遞的使用者資料。

內容需要限制在16 KB以內,不需要使用Base64轉碼,特殊字元需要使用反斜線(\)轉義。

ZoneId

String

可用性區域ID。

HpcClusterId

String

執行個體所屬的HPC叢集ID。

VpcId

String

專用網路ID。

VSwitchId

String

交換器ID。

InstanceChargeType

String

ECS執行個體付費類型。

取值:

  • PrePaid:預付費。如果指定PrePaid,則必須確保餘額充足,否則會導致執行個體建立失敗。

  • PostPaid(預設值):隨用隨付。

Period

Number

付費周期。

當InstanceChargeType取值為PrePaid時,Period為必選屬性;當InstanceChargeType取值為PostPaid時,Period為可選屬性。

KeyPairName

String

ECS執行個體綁定的金鑰組名稱。

當執行個體類型為Windows時,請忽略該屬性;當執行個體類型為Linux時,密碼登入方式會被初始化為禁止。為提高執行個體安全性,建議您使用金鑰組的串連方式。

RamRoleName

String

執行個體RAM角色名稱。

更多資訊,請參見CreateRoleListRoles

SpotPriceLimit

String

執行個體的每小時最高價格。

支援最多3位小數。當SpotStrategy取值為SpotWithPriceLimit時,該屬性生效。

SpotStrategy

String

隨用隨付執行個體的競價策略。

當InstanceChargeType取值為PostPaid時,SpotStrategy為必選屬性。

取值:

  • NoSpot(預設值):正常隨用隨付執行個體。

  • SpotWithPriceLimit:上限價格的競價執行個體。

  • SpotAsPriceGo:系統自動出價,最高不超過隨用隨付價格。

DedicatedHostId

String

ECS執行個體建立指定Dedicated Host上。

您可以通過調用DescribeDedicatedHosts介面查詢Dedicated HostID列表

。由於Dedicated Host不支援建立搶佔式執行個體,指定DedicatedHostId後,請求中的SpotStrategy和SpotPriceLimit設定將被自動忽略。

PeriodUnit

String

購買資源的時間長度。

取值:

  • Week:周。

  • Month(預設值):月。

AutoRenewPeriod

Number

每次自動續約的時間長度。

當AutoRenew取值為True時,AutoRenewPeriod為必選屬性。

取值:

  • 當PeriodUnit為Week時,AutoRenewPeriod取值為1、2、3。

  • 當PeriodUnit為Month時,AutoRenewPeriod取值為1、2、3、6、12。

AutoRenew

String

是否自動續約。

取值:

  • True:自動續約。

  • False(預設值):不自動續約。

當InstanceChargeType取值PrePaid時,AutoRenew為必選屬性。

DeletionProtection

Boolean

執行個體釋放保護屬性,指定是否支援通過控制台或DeleteInstance介面釋放執行個體。

取值:

  • true:開啟執行個體釋放保護。

  • false(預設):關閉執行個體釋放保護。

說明

該屬性僅適用於隨用隨付執行個體,且只能限制手動釋放操作,對系統釋放操作不生效。

DeploymentSetId

String

部署集ID。

SystemDiskPerformanceLevel

String

建立ESSD雲端硬碟作為系統硬碟使用時,設定雲端硬碟的效能等級。

取值:

  • PL0:單盤最高隨機讀寫IOPS為1萬。

  • PL1(預設值):單盤最高隨機讀寫IOPS為5萬。

  • PL2:單盤最高隨機讀寫IOPS為10萬。

  • PL3:單盤最高隨機讀寫IOPS為100萬。

關於如何選擇ESSD效能等級,請參見ESSD雲端硬碟

CreditSpecification

String

設定突發效能執行個體的運行模式。

取值:

PrivatePoolOptions

Map

執行個體啟動的私人池容量選項。

更多資訊,請參考PrivatePoolOptions屬性

StorageSetId

String

儲存集ID。

HttpTokens

String

訪問執行個體中繼資料時是否強制使用加固模式(IMDSv2)。

取值:

  • optional(預設值):不強制使用。

  • required:強制使用。設定該取值後,普通模式無法訪問執行個體中繼資料。

說明

有關訪問執行個體中繼資料的模式,請參見執行個體中繼資料訪問模式

HttpEndpoint

String

是否啟用執行個體中繼資料的訪問通道。

取值範圍:

  • enabled(預設值):啟用。

  • disabled:禁用。

說明

有關執行個體中繼資料的資訊,請參見ECS執行個體中繼資料概述

Tenancy

String

是否在Dedicated Host上建立執行個體。

取值:

  • default(預設值):建立非Dedicated Host執行個體。

  • host:建立Dedicated Host執行個體。若您不指定DedicatedHostId,則由阿里雲自動選擇Dedicated Host放置執行個體。

StorageSetPartitionNumber

Integer

儲存集中的最大分區數量。

取值範圍:大於等於2。

DeploymentSetGroupNo

Integer

如果您設定的部署集對應的策略為部署集組高可用策略(AvailabilityGroup),可以通過該參數指定執行個體在部署集中的分組號。

取值範圍:1~7。

Affinity

String

Dedicated Host執行個體是否與Dedicated Host關聯。

取值:

  • default(預設值):執行個體不與Dedicated Host關聯。已啟用節省停機模式的執行個體,停機後再次啟動時,若原Dedicated Host可用資源不足,則執行個體被放置在自動部署資源集區的其他Dedicated Host上。

  • host:執行個體與Dedicated Host關聯。已啟用節省停機模式的執行個體,停機後再次啟動時,仍放置在原Dedicated Host上。若原Dedicated Host可用資源不足,則執行個體重啟失敗。

UseAdditionalService

Boolean

是否使用阿里雲提供的虛擬機器系統配置(Windows:NTP、KMS;Linux:NTP、YUM)。

取值:

  • true

  • false

ImageFamily

String

鏡像族系名稱。

通過設定該參數來擷取當前鏡像族系內最新可用鏡像來建立執行個體。

  • 設定了參數ImageId,則不能設定該參數。

  • 未設定參數ImageId,但指定的LaunchTemplateIdLaunchTemplateName對應的啟動模板設定了ImageId,則不能設定該參數。

  • 未設定ImageId,且指定的LaunchTemplateIdLaunchTemplateName對應的啟動模板未設定ImageId,則可以設定該參數。

  • 未設定ImageId,且未設定LaunchTemplateIdLaunchTemplateName參數,則可以設定該參數。

說明

阿里雲官方鏡像關聯的鏡像族系資訊請參見公用鏡像概述

DiskMappings文法

"DiskMappings": [
  {
    "Category": String,
    "DiskName": String,
    "Description": String,
    "Device": String,
    "SnapshotId": String,
    "PerformanceLevel": String,
    "Size": String
  }
]

DiskMappings屬性

屬性名稱

類型

必須

允許更新

描述

約束

Size

String

資料盤大小。

取值範圍:20~500。

單位:GB。

Category

String

資料盤類型。

取值:

  • cloud:普通雲端硬碟。

  • cloud_ssd:SSD雲端硬碟。

  • cloud_essd:ESSD雲端硬碟。

  • cloud_efficiency:高效雲端硬碟。

  • ephemeral_ssd:本地SSD盤。

I/O最佳化執行個體的預設值為cloud_efficiency,非I/O最佳化執行個體的預設值為cloud。

如果自訂鏡像已包含了一個資料盤,那麼建立ECS執行個體時,若要在ROS模板中指定資料盤類型,可以將Category指定為需要的資料盤類型。例如:

{
  "ROSTemplateFormatVersion": "2015-09-01",
  "Resources": {
    "Instance": {
      "Type": "ALIYUN::ECS::Instance",
      "Properties": {
        "InstanceName": "rostest",
        "ImageId": "m-2ze5ysugu8ss7nxr****",
        "InstanceType": "ecs.g6e.large",
        "Password": "Ros1****",
        "IoOptimized": "optimized",
        "VSwitchId": "vsw-2zej7phc6euuelo8l****",
        "VpcId": "vpc-2zebbi27bn7w42n30****",
        "SecurityGroupId": "sg-2ze5bdyyg7sfrcv6****",
        "SystemDiskCategory": "cloud_essd",
        "DiskMappings": [
          {
            "Category": "cloud_essd",
            "Size": 40,
            "Device": "/dev/xvdb"
          }
        ]
      }
    }
  }
}
                                

DiskName

String

資料盤名稱。

長度為2~128個字元。必須以英文字母或漢字開頭,不能以http://https://開頭。可包含英文字母、漢字、數字、底線(_)、半形冒號(:)和短劃線(-)。

Description

String

描述資訊。

長度為2~256個字元,不能以http://https://開頭。

Device

String

掛載點。

PerformanceLevel

String

建立ESSD雲端硬碟作為資料盤使用時,設定雲端硬碟的效能等級。

取值:

  • PL1(預設值):單盤最高隨機讀寫IOPS為5萬。

  • PL2:單盤最高隨機讀寫IOPS為10萬。

  • PL3:單盤最高隨機讀寫IOPS為100萬。

關於如何選擇ESSD效能等級,請參見ESSD雲端硬碟

SnapshotId

String

資料盤使用的快照ID。

Tags文法

"Tags": [
  {
    "Value": String,
    "Key": String
  }
]

Tags屬性

屬性名稱

類型

必須

允許更新

描述

約束

Key

String

標籤鍵。

長度為1~128個字元,不能以aliyunacs:開頭,不能包含http://https://

Value

String

標籤值。

長度為0~128個字元,不能以aliyunacs:開頭,不能包含http://https://

PrivatePoolOptions文法

"PrivatePoolOptions": [
  {
    "Id": String,
    "MatchCriteria": String
  }
]

PrivatePoolOptions屬性

屬性名稱

類型

必須

允許更新

描述

約束

Id

String

私人池ID。即彈性保障服務ID或容量預定服務ID。

MatchCriteria

String

彈性保障服務或容量預定服務在生效後會產生私人池容量,供執行個體啟動時選擇。

取值:

  • Open:開放模式。將自動匹配開放類型的私人池容量。如果沒有合格私人池容量,則使用公用池資源啟動。該模式下無需設定PrivatePoolOptions.Id參數。

  • Target:指定模式。使用指定的私人池容量啟動執行個體,如果該私人池容量不可用,則執行個體會啟動失敗。該模式下必須指定私人池ID,即PrivatePoolOptions.Id參數為必填項。

  • None(預設值):不使用模式。執行個體啟動將不使用私人池容量。

以下任一情境,執行個體啟動的私人池容量選項只能取值None或不傳值。

  • 建立搶佔式執行個體。

  • 建立傳統網路類型的ECS執行個體。

  • 在Dedicated HostDDH上建立ECS執行個體。

傳回值

Fn::GetAtt

  • InstanceId:執行個體ID。由系統產生,執行個體的全域唯一標識。

  • PrivateIp:VPC類型執行個體的私網IP地址。

  • InnerIp:Classic類型執行個體的內網IP地址。

  • PublicIp:Classic類型執行個體的公網IP地址。

  • ZoneId:可用性區域ID。

  • HostName:雲端服務器的主機名稱。

  • PrimaryNetworkInterfaceId:主網卡ID。

  • SecurityGroupIds:已建立執行個體的安全性群組ID列表。

樣本

建立兩台ECS執行個體(OpsEcsInstance、ProdEcsInstance),並為ProdEcsInstance執行個體完成OpsEcsInstance免密登入操作。

如果您需要對ECS執行個體的Userdata指令碼執行結果進行訊息通知。更多資訊,請參見ALIYUN::ROS::WaitConditionHandleALIYUN::ROS::WaitCondition

ROSTemplateFormatVersion: '2015-09-01'
Description: Creates VPC ECS instance
Metadata: {}
Parameters:
  VpcId:
    AssociationProperty: ALIYUN::ECS::VPC::VPCId
    Type: String
    Description:
      en: Please search the ID starting with (vpc-xxx) from console-Virtual Private Cloud
      zh-cn: 現有專用網路的執行個體ID
    Label:
      en: VPC ID
      zh-cn: Virtual Private Cloud執行個體ID
  VSwitchZoneId:
    AssociationProperty: ALIYUN::ECS::Instance:ZoneId
    Type: String
    Description:
      zh-cn: 可用性區域ID。<br><b>註: <font color='blue'>選擇前請確認該可用性區域是否支援建立ECS資源的規格,建議與其他交換器可用性區域不同</font></b>
      en: Availability Zone ID.<br><b>note:<font color='blue'>before selecting, please confirm that the Availability Zone supports the specification of creating ECS resources,which is recommended to be different from other VSwitch Availability Zone</font></b>
    Label:
      zh-cn: 交換器可用性區域
      en: VSwitch Availability Zone
  VSwitchId:
    AssociationProperty: ALIYUN::ECS::VSwitch::VSwitchId
    AssociationPropertyMetadata:
      VpcId: ${VpcId}
      ZoneId: ${VSwitchZoneId}
    Type: String
    Description:
      en: Instance ID of existing business network switches, console-Virtual Private Cloud-VSwitches under query
      zh-cn: 現有業務網路交換器的執行個體ID
    Label:
      en: VSwitch ID
      zh-cn: 交換器執行個體ID
  SecurityGroupId:
    Type: String
    AssociationProperty: ALIYUN::ECS::SecurityGroup::SecurityGroupId
    AssociationPropertyMetadata:
      VpcId: ${VpcId}
    Description:
      en: Please search the business security group ID starting with(sg-xxx)from console-ECS-Network & Security
      zh-cn: 現有業務安全性群組的執行個體ID
    Label:
      en: Business Security Group ID
      zh-cn: 業務安全性群組ID
  InstanceType:
    Type: String
    Description:
      zh-cn: 填寫VSwitch可用性區域下可使用的規格。
      en: Fill in the specifications that can be used under the VSwitch availability zone.
    Label:
      zh-cn: 執行個體規格
      en: Instance Type
    AssociationProperty: ALIYUN::ECS::Instance::InstanceType
    AssociationPropertyMetadata:
      ZoneId: ${VSwitchZoneId}
  SystemDiskCategory:
    Type: String
    AssociationProperty: ALIYUN::ECS::Disk::SystemDiskCategory
    AssociationPropertyMetadata:
      ZoneId: ${VSwitchZoneId}
      InstanceType: ${InstanceType}
    Label:
      en: System Disk Type
      zh-cn: 系統硬碟類型
    Description:
      en: '<font color=''blue''><b>Optional values:</b></font><br>[cloud_efficiency: <font color=''green''>Efficient Cloud Disk</font>]<br>[cloud_ssd: <font color=''green''>SSD Cloud Disk</font>]<br>[cloud_essd: <font color=''green''>ESSD Cloud Disk</font>]<br>[cloud: <font color=''green''>Cloud Disk</font>]<br>[ephemeral_ssd: <font color=''green''>Local SSD Cloud Disk</font>]'
      zh-cn: '<font color=''blue''><b>可選值:</b></font><br>[cloud_efficiency: <font color=''green''>高效雲端硬碟</font>]<br>[cloud_ssd: <font color=''green''>SSD雲端硬碟</font>]<br>[cloud_essd: <font color=''green''>ESSD雲端硬碟</font>]<br>[cloud: <font color=''green''>普通雲端硬碟</font>]<br>[ephemeral_ssd: <font color=''green''>本地SSD盤</font>]'
  SystemDiskSize:
    Default: 40
    Type: Number
    Description:
      zh-cn: 系統硬碟大小, 取值範圍:[40, 500], 單位:GB。
      en: 'System disk size, range of values: 40-500, units: GB.'
    Label:
      zh-cn: 系統硬碟空間
      en: System Disk Space
Resources:
  OpsEcsInstance:
    Type: ALIYUN::ECS::Instance
    Properties:
      HostName: OpsEcsInstance
      UserData:
        Fn::Sub:
          - |
            #!/bin/bash
            RootPassword=${RootPassword}
            ProdIP=${ProdIP}
            SSHConfig() {
            echo '[ ! -f /root/.ssh/id_rsa.pub ] && ssh-keygen -t rsa -P "" -f ~/.ssh/id_rsa &>/dev/null' >> /tmp/auto_ssh.sh
            echo 'while read line;do' >> /tmp/auto_ssh.sh
            echo '        ip=`echo $line | cut -d " " -f1`' >> /tmp/auto_ssh.sh
            echo '        user_name=`echo $line | cut -d " " -f2`' >> /tmp/auto_ssh.sh
            echo '        pass_word=`echo $line | cut -d " " -f3`' >> /tmp/auto_ssh.sh
            echo 'expect <<EOF' >> /tmp/auto_ssh.sh
            echo '        spawn ssh-copy-id -i /root/.ssh/id_rsa.pub $user_name@$ip' >> /tmp/auto_ssh.sh
            echo '        expect {' >> /tmp/auto_ssh.sh
            echo '                  "yes/no" { send "yes\n";exp_continue}' >> /tmp/auto_ssh.sh
            echo '                  "password" { send "$pass_word\n"}' >> /tmp/auto_ssh.sh
            echo '        }' >> /tmp/auto_ssh.sh
            echo '        expect eof' >> /tmp/auto_ssh.sh
            echo 'EOF' >> /tmp/auto_ssh.sh
            echo 'done < /tmp/host_ip.txt' >> /tmp/auto_ssh.sh
            }
            SetHostsConfig() {
            echo "`ifconfig eth0 | awk '/inet /{print $2}'` root ${RootPassword}" >> /tmp/host_ip.txt
            echo "${ProdIP} root ${RootPassword}" >> /tmp/host_ip.txt
            sh /tmp/auto_ssh.sh
            }
            main() {
            yum install -y expect
            SSHConfig
            SetHostsConfig
            rm -rf /tmp/host_ip.txt
            }
            main
          - ProdIP:
              Fn::GetAtt:
                - ProdEcsInstance
                - PrivateIp
            RootPassword: Admin@123!
      VpcId:
        Ref: VpcId
      SecurityGroupId:
        Ref: SecurityGroupId
      VSwitchId:
        Ref: VSwitchId
      ImageId: centos_7
      AllocatePublicIP: false
      InstanceType:
        Ref: InstanceType
      SystemDiskSize: 40
      SystemDiskCategory:
        Ref: SystemDiskCategory
      Password: Admin@123!
  ProdEcsInstance:
    Type: ALIYUN::ECS::Instance
    Properties:
      HostName: ProdEcsInstance
      SystemDiskCategory:
        Ref: SystemDiskCategory
      VpcId:
        Ref: VpcId
      SecurityGroupId:
        Ref: SecurityGroupId
      SystemDiskSize: 40
      ImageId: centos_7
      VSwitchId:
        Ref: VSwitchId
      Password: Admin@123!
      InstanceType:
        Ref: InstanceType
      AllocatePublicIP: false
Outputs: {}                    
{
  "ROSTemplateFormatVersion": "2015-09-01",
  "Description": "Creates VPC ECS instance",
  "Metadata": {},
  "Parameters": {
    "VpcId": {
      "AssociationProperty": "ALIYUN::ECS::VPC::VPCId",
      "Type": "String",
      "Description": {
        "en": "Please search the ID starting with (vpc-xxx) from console-Virtual Private Cloud",
        "zh-cn": "現有專用網路的執行個體ID"
      },
      "Label": {
        "en": "VPC ID",
        "zh-cn": "Virtual Private Cloud執行個體ID"
      }
    },
    "VSwitchZoneId": {
      "AssociationProperty": "ALIYUN::ECS::Instance:ZoneId",
      "Type": "String",
      "Description": {
        "zh-cn": "可用性區域ID。<br><b>註: <font color='blue'>選擇前請確認該可用性區域是否支援建立ECS資源的規格,建議與其他交換器可用性區域不同</font></b>",
        "en": "Availability Zone ID.<br><b>note:<font color='blue'>before selecting, please confirm that the Availability Zone supports the specification of creating ECS resources,which is recommended to be different from other VSwitch Availability Zone</font></b>"
      },
      "Label": {
        "zh-cn": "交換器可用性區域",
        "en": "VSwitch Availability Zone"
      }
    },
    "VSwitchId": {
      "AssociationProperty": "ALIYUN::ECS::VSwitch::VSwitchId",
      "AssociationPropertyMetadata": {
        "VpcId": "${VpcId}",
        "ZoneId": "${VSwitchZoneId}"
      },
      "Type": "String",
      "Description": {
        "en": "Instance ID of existing business network switches, console-Virtual Private Cloud-VSwitches under query",
        "zh-cn": "現有業務網路交換器的執行個體ID"
      },
      "Label": {
        "en": "VSwitch ID",
        "zh-cn": "交換器執行個體ID"
      }
    },
    "SecurityGroupId": {
      "Type": "String",
      "AssociationProperty": "ALIYUN::ECS::SecurityGroup::SecurityGroupId",
      "AssociationPropertyMetadata": {
        "VpcId": "${VpcId}"
      },
      "Description": {
        "en": "Please search the business security group ID starting with(sg-xxx)from console-ECS-Network & Security",
        "zh-cn": "現有業務安全性群組的執行個體ID"
      },
      "Label": {
        "en": "Business Security Group ID",
        "zh-cn": "業務安全性群組ID"
      }
    },
    "InstanceType": {
      "Type": "String",
      "Description": {
        "zh-cn": "填寫VSwitch可用性區域下可使用的規格。",
        "en": "Fill in the specifications that can be used under the VSwitch availability zone."
      },
      "Label": {
        "zh-cn": "執行個體規格",
        "en": "Instance Type"
      },
      "AssociationProperty": "ALIYUN::ECS::Instance::InstanceType",
      "AssociationPropertyMetadata": {
        "ZoneId": "${VSwitchZoneId}"
      }
    },
    "SystemDiskCategory": {
      "Type": "String",
      "AssociationProperty": "ALIYUN::ECS::Disk::SystemDiskCategory",
      "AssociationPropertyMetadata": {
        "ZoneId": "${VSwitchZoneId}",
        "InstanceType": "${InstanceType}"
      },
      "Label": {
        "en": "System Disk Type",
        "zh-cn": "系統硬碟類型"
      },
      "Description": {
        "en": "<font color='blue'><b>Optional values:</b></font><br>[cloud_efficiency: <font color='green'>Efficient Cloud Disk</font>]<br>[cloud_ssd: <font color='green'>SSD Cloud Disk</font>]<br>[cloud_essd: <font color='green'>ESSD Cloud Disk</font>]<br>[cloud: <font color='green'>Cloud Disk</font>]<br>[ephemeral_ssd: <font color='green'>Local SSD Cloud Disk</font>]",
        "zh-cn": "<font color='blue'><b>可選值:</b></font><br>[cloud_efficiency: <font color='green'>高效雲端硬碟</font>]<br>[cloud_ssd: <font color='green'>SSD雲端硬碟</font>]<br>[cloud_essd: <font color='green'>ESSD雲端硬碟</font>]<br>[cloud: <font color='green'>普通雲端硬碟</font>]<br>[ephemeral_ssd: <font color='green'>本地SSD盤</font>]"
      }
    },
    "SystemDiskSize": {
      "Default": 40,
      "Type": "Number",
      "Description": {
        "zh-cn": "系統硬碟大小, 取值範圍:[40, 500], 單位:GB。",
        "en": "System disk size, range of values: 40-500, units: GB."
      },
      "Label": {
        "zh-cn": "系統硬碟空間",
        "en": "System Disk Space"
      }
    }
  },
  "Resources": {
    "OpsEcsInstance": {
      "Type": "ALIYUN::ECS::Instance",
      "Properties": {
        "HostName": "OpsEcsInstance",
        "UserData": {
          "Fn::Sub": [
            "#!/bin/bash\nRootPassword=${RootPassword}\nProdIP=${ProdIP}\nSSHConfig() {\necho '[ ! -f /root/.ssh/id_rsa.pub ] && ssh-keygen -t rsa -P \"\" -f ~/.ssh/id_rsa &>/dev/null' >> /tmp/auto_ssh.sh\necho 'while read line;do' >> /tmp/auto_ssh.sh\necho '        ip=`echo $line | cut -d \" \" -f1`' >> /tmp/auto_ssh.sh\necho '        user_name=`echo $line | cut -d \" \" -f2`' >> /tmp/auto_ssh.sh\necho '        pass_word=`echo $line | cut -d \" \" -f3`' >> /tmp/auto_ssh.sh\necho 'expect <<EOF' >> /tmp/auto_ssh.sh\necho '        spawn ssh-copy-id -i /root/.ssh/id_rsa.pub $user_name@$ip' >> /tmp/auto_ssh.sh\necho '        expect {' >> /tmp/auto_ssh.sh\necho '                  \"yes/no\" { send \"yes\\n\";exp_continue}' >> /tmp/auto_ssh.sh\necho '                  \"password\" { send \"$pass_word\\n\"}' >> /tmp/auto_ssh.sh\necho '        }' >> /tmp/auto_ssh.sh\necho '        expect eof' >> /tmp/auto_ssh.sh\necho 'EOF' >> /tmp/auto_ssh.sh\necho 'done < /tmp/host_ip.txt' >> /tmp/auto_ssh.sh\n}\nSetHostsConfig() {\necho \"`ifconfig eth0 | awk '/inet /{print $2}'` root ${RootPassword}\" >> /tmp/host_ip.txt\necho \"${ProdIP} root ${RootPassword}\" >> /tmp/host_ip.txt\nsh /tmp/auto_ssh.sh\n}\nmain() {\nyum install -y expect\nSSHConfig\nSetHostsConfig\nrm -rf /tmp/host_ip.txt\n}\nmain\n",
            {
              "ProdIP": {
                "Fn::GetAtt": [
                  "ProdEcsInstance",
                  "PrivateIp"
                ]
              },
              "RootPassword": "Admin@123!"
            }
          ]
        },
        "VpcId": {
          "Ref": "VpcId"
        },
        "SecurityGroupId": {
          "Ref": "SecurityGroupId"
        },
        "VSwitchId": {
          "Ref": "VSwitchId"
        },
        "ImageId": "centos_7",
        "AllocatePublicIP": false,
        "InstanceType": {
          "Ref": "InstanceType"
        },
        "SystemDiskSize": 40,
        "SystemDiskCategory": {
          "Ref": "SystemDiskCategory"
        },
        "Password": "Admin@123!"
      }
    },
    "ProdEcsInstance": {
      "Type": "ALIYUN::ECS::Instance",
      "Properties": {
        "HostName": "ProdEcsInstance",
        "SystemDiskCategory": {
          "Ref": "SystemDiskCategory"
        },
        "VpcId": {
          "Ref": "VpcId"
        },
        "SecurityGroupId": {
          "Ref": "SecurityGroupId"
        },
        "SystemDiskSize": 40,
        "ImageId": "centos_7",
        "VSwitchId": {
          "Ref": "VSwitchId"
        },
        "Password": "Admin@123!",
        "InstanceType": {
          "Ref": "InstanceType"
        },
        "AllocatePublicIP": false
      }
    }
  },
  "Outputs": {}
}