模板名稱
ACS-RDS-BulkyModifyDBInstanceDeletionProtection 批量開啟RDS執行個體保護
模板描述
批量開啟RDS執行個體保護
模板類型
自動化
所有者
Alibaba Cloud
輸入參數
參數名稱 | 描述 | 類型 | 是否必填 | 預設值 | 約束 |
OOSAssumeRole | OOS扮演的RAM角色 | String | 是 | ||
regionId | 地區ID | String | 否 | {{ ACS::RegionId }} | |
targets | 目標執行個體 | Json | 否 | {"Type": "ResourceIds", "ResourceIds": [], "RegionId": "{{ regionId }}"} | |
instanceIds | RDS執行個體Id列表 | List | 否 | [] | |
rateControl | 任務執行的並發比率 | Json | 否 | {"Mode": "Concurrency", "MaxErrors": 0, "Concurrency": 10} |
輸出參數
無
執行此模板需要的權限原則
{
"Version": "1",
"Statement": [
{
"Action": [
"rds:DescribeDBInstances",
"rds:ModifyDBInstanceDeletionProtection"
],
"Resource": "*",
"Effect": "Allow"
},
{
"Action": [
"oos:GetApplicationGroup"
],
"Resource": "*",
"Effect": "Allow"
}
]
}
詳情
ACS-RDS-BulkyModifyDBInstanceDeletionProtection詳情
模板內容
FormatVersion: OOS-2019-06-01
Description:
en: Bulky enable deletion protection for instances
zh-cn: 批量開啟RDS執行個體保護
name-en: ACS-RDS-BulkyModifyDBInstanceDeletionProtection
name-zh-cn: 批量開啟RDS執行個體保護
categories:
- security
- rds
Parameters:
regionId:
Type: String
Label:
en: RegionId
zh-cn: 地區ID
AssociationProperty: RegionId
Default: '{{ ACS::RegionId }}'
targets:
Type: Json
Label:
en: TargetInstance
zh-cn: 目標執行個體
AssociationProperty: Targets
AssociationPropertyMetadata:
ResourceType: ALIYUN::RDS::Instance
RegionId: regionId
Default:
Type: ResourceIds
ResourceIds: []
RegionId: '{{ regionId }}'
instanceIds:
Label:
en: InstanceIds
zh-cn: RDS執行個體Id列表
Type: List
Default: []
AssociationPropertyMetadata:
Visible:
Condition:
Fn::Equals:
- ${targets}
- {}
rateControl:
Label:
en: RateControl
zh-cn: 任務執行的並發比率
Type: Json
AssociationProperty: RateControl
Default:
Mode: Concurrency
MaxErrors: 0
Concurrency: 10
OOSAssumeRole:
Label:
en: OOSAssumeRole
zh-cn: OOS扮演的RAM角色
Type: String
RamRole: '{{ OOSAssumeRole }}'
Conditions:
instanceId:
Fn::Equals:
- '{{ instanceIds }}'
- []
Tasks:
- Name: getInstance
When: instanceId
Description:
en: Get the RDS instances
zh-cn: 擷取RDS執行個體
Action: ACS::SelectTargets
Properties:
ResourceType: ALIYUN::RDS::Instance
RegionId: '{{regionId}}'
Filters:
- '{{ targets }}'
Outputs:
instanceIds:
Type: List
ValueSelector: Instances.Instance[].InstanceId
- Name: enableDBInstanceDeletionProtection
Action: ACS::ExecuteApi
Description: '{"en":"Enables deletion protection for rds instance","zh-cn":"開啟執行個體釋放保護"}'
Properties:
Service: RDS
API: ModifyDBInstanceDeletionProtection
Parameters:
DBInstanceId: '{{ ACS::TaskLoopItem }}'
DeletionProtection: true
RegionId: '{{ regionId }}'
Loop:
Items:
Fn::If:
- Fn::Equals:
- '{{instanceIds}}'
- []
- '{{ getInstance.instanceIds }}'
- '{{ instanceIds}}'
RateControl: '{{ rateControl }}'
OnError: ACS::END
OnSuccess: ACS::NEXT
Metadata:
ALIYUN::OOS::Interface:
ParameterGroups:
- Parameters:
- regionId
- instanceIds
- targets
Label:
default:
zh-cn: 選擇執行個體
en: Select RDS Instances
- Parameters:
- rateControl
- OOSAssumeRole
Label:
default:
zh-cn: 進階選項
en: Control Options