テンプレート名
ACS-ESS-LifeCycleAllocateEipAddressAndAttachToInstance:ライフサイクルフックを使用して EIP を作成し、インスタンスにアタッチ
テンプレートの説明
ライフサイクルフックを使用して、Elastic IP アドレス (EIP) を作成し、EIP を Elastic Compute Service (ECS) インスタンスに関連付けます。 このテンプレートは、スケールアウトイベントのみをサポートします。
テンプレートタイプ
自動
所有者
Alibaba Cloud
入力パラメーター
パラメーター | 説明 | タイプ | 必須 | デフォルト値 | 制限 |
internetChargeType | EIP の課金方法。 | String | いいえ | PayByBandwidth | |
bandwidth | EIP のピーク帯域幅。 | Number | いいえ | 5 | |
regionId | リージョン ID。 | String | いいえ | ${regionId} | |
instanceIds | ECS インスタンスの ID。 | List | いいえ | ['${instanceIds}'] | |
eipTags | EIP のタグ。 | Json | いいえ | [{'Key': 'oos_generate', 'Value': '{{ACS::ExecutionId}}'}] | |
ISP | EIP の回線タイプ。 | String | いいえ | BGP | |
lifecycleHookId | ライフサイクルフックの ID。 | String | いいえ | ${lifecycleHookId} | |
lifecycleActionToken | レート制御 | String | いいえ | ${lifecycleActionToken} | |
rateControl | レート制御設定。 | Json | いいえ | {'Mode': 'Concurrency', 'MaxErrors': 0, 'Concurrency': 5} | |
OOSAssumeRole | CloudOps Orchestration Service (OOS) によってアタッチされる Resource Access Management (RAM) ロール。 | String | いいえ | OOSServiceRole |
出力パラメーター
なし
テンプレートを実行するために必要なポリシー
{
"Version": "1",
"Statement": [
{
"Action": [
"ecs:AllocateEipAddress",
"ecs:AssociateEipAddress",
"ecs:DescribeEipAddresses",
"ecs:DescribeInstances",
"ecs:ReleaseEipAddress",
"ecs:UnassociateEipAddress"
],
"Resource": "*",
"Effect": "Allow"
},
{
"Action": [
"vpc:TagResources"
],
"Resource": "*",
"Effect": "Allow"
},
{
"Action": [
"ess:CompleteLifecycleAction"
],
"Resource": "*",
"Effect": "Allow"
}
]
}
詳細
ACS-ESS-LifeCycleAllocateEipAddressAndAttachToInstance
テンプレートコンテンツ
FormatVersion: OOS-2019-06-01
Description:
ja: ライフサイクルフックを使用して EIP を作成し、インスタンスにアタッチします。このテンプレートは、スケールアウトアクティビティのみをサポートします。
name-ja: ACS-ESS-LifeCycleAllocateEipAddressAndAttachToInstance
categories:
- elastic_manage
Parameters:
internetChargeType:
Label:
ja: EIP の課金方法
Description:
ja: 'EIP の課金方法。有効な値: PayByBandwidth (帯域幅課金) および PayByTraffic (トラフィック課金)。'
Type: String
AllowedValues:
- PayByBandwidth
- PayByTraffic
Default: PayByBandwidth
bandwidth:
Label:
ja: EIP のピーク帯域幅
Description:
ja: EIP のピーク帯域幅 (単位:Mbit/s)。
Type: Number
Default: 5
regionId:
Label:
ja: リージョン ID
Description:
ja: リージョン ID。Auto Scaling によって提供されるデフォルト値 ${regionId} を使用します。
Type: String
Default: '${regionId}'
instanceIds:
Label:
ja: ECS インスタンス ID
Description:
ja: ECS インスタンスの ID。Auto Scaling によって提供されるデフォルト値 ['${instanceIds}'] を使用します。
Type: List
Default:
- '${instanceIds}'
eipTags:
Label:
ja: EIP タグ
Description:
ja: 'EIP のタグ。形式: [{"Key":"test1","Value":"test1"},{"Key":"test2","Value":"test2"}, ...]'
Type: Json
Default: [{"Key":"oos_generate","Value":"{{ACS::ExecutionId}}"}]
ISP:
Label: EIP 回線タイプ
Description: 'EIP の回線タイプ。BGP: BGP (マルチ ISP)。BGP_PRO: BGP (マルチ ISP) Pro。BGP_International: BGP (国際)。'
Type: String
AllowedValues:
- BGP
- BGP_PRO
- BGP_International
Default: BGP
lifecycleHookId:
Label:
ja: ライフサイクルフック ID
Description:
ja: ライフサイクルフックの ID。Auto Scaling によって提供されるデフォルト値 ${lifecycleHookId} を使用します。
Type: String
Default: '${lifecycleHookId}'
lifecycleActionToken:
Label:
ja: ライフサイクルアクショントークン
Description:
ja: インスタンスに関連付けられた特定のスケーリングアクティビティのトークン。Auto Scaling によって提供されるデフォルト値 ${lifecycleActionToken} を使用します。
Type: String
Default: '${lifecycleActionToken}'
rateControl:
Label:
ja: レート制御
Type: Json
AssociationProperty: RateControl
Default:
Mode: Concurrency
MaxErrors: 0
Concurrency: 5
OOSAssumeRole:
Label:
ja: OOS の RAM ロール
Type: String
Default: OOSServiceRole
RamRole: '{{ OOSAssumeRole }}'
Tasks:
- Name: createEipAndAttachToInstance
Action: 'ACS::ECS::AllocateEipAddressAndAttachToInstance'
OnSuccess: CompleteLifecycleActionForContinue
OnError: CompleteLifecycleActionForAbandon
Description:
ja: EIP を作成し、インスタンスにアタッチします。
Properties:
regionId: '{{ regionId }}'
internetChargeType: '{{ internetChargeType }}'
bandwidth: '{{ bandwidth }}'
instanceId: '{{ ACS::TaskLoopItem }}'
tags: '{{ eipTags }}'
ISP: '{{ ISP }}'
Loop:
RateControl: '{{ rateControl }}'
Items: '{{ instanceIds }}'
- Name: CompleteLifecycleActionForContinue
Action: 'ACS::ExecuteAPI'
Description:
ja: ライフサイクルアクションを CONTINUE に設定します。
OnSuccess: 'ACS::END'
Properties:
Service: ESS
API: CompleteLifecycleAction
Parameters:
RegionId: '{{ regionId }}'
LifecycleHookId: '{{ lifecycleHookId }}'
LifecycleActionToken: '{{ lifecycleActionToken }}'
LifecycleActionResult: CONTINUE
- Name: CompleteLifecycleActionForAbandon
Action: 'ACS::ExecuteAPI'
Description:
ja: ライフサイクルアクションを ABANDON に設定します。
Properties:
Service: ESS
API: CompleteLifecycleAction
Parameters:
RegionId: '{{ regionId }}'
LifecycleHookId: '{{ lifecycleHookId }}'
LifecycleActionToken: '{{ lifecycleActionToken }}'
LifecycleActionResult: ABANDON