AWS CloudFormation の Fn:: Sub 組み込み関数を Fn::FindInMap、Fn::ImportValue、またはその他のサポートされている関数と併用したいと考えています。
簡単な説明
Fn:: Sub 組み込み関数を使用して、サポートされている関数を代入したり、入力文字列の変数を指定した値に置き換えたりできます。
サポートされている関数の値を代入するには、次に示すような名前と値を指定した変数マップを使用する必要があります。
JSON:
{ "Fn::Sub" : [ String, { Var1Name: Var1Value, Var2Name: Var2Value } ] }
YAML:
!Sub
- String
- Var1Name: Var1Value
Var2Name: Var2Value
解決策
Ref 関数での Fn:: Sub の使用
次の例では、マッピングを使用して Domain 変数を Ref 関数の結果の値に置き換えています。
JSON:
{
"Parameters": {
"RootDomainName": {
"Type": "String",
"Default": "example123.com"
}
},
"Resources": {
"DNS": {
"Type": "AWS::Route53::HostedZone",
"Properties": {
"Name": {
"Fn::Sub": [
"www.${Domain}",
{
"Domain": {
"Ref": "RootDomainName"
}
}
]
}
}
}
}
}
YAML:
Parameters:
RootDomainName:
Type: String
Default: example123.com
Resources:
DNS:
Type: 'AWS::Route53::HostedZone'
Properties:
Name: !Sub
- 'www.${Domain}'
- Domain: !Ref RootDomainName
**Fn:: Subと Fn:: FindInMap 関数の併用 **
次の例では、マッピングを使用して log\ _group\ _name 変数を Fn:: FindInMap 関数の結果の値に置き換えています。
JSON:
{
"Mappings": {
"LogGroupMapping": {
"Test": {
"Name": "test_log_group"
},
"Prod": {
"Name": "prod_log_group"
}
}
},
"Resources": {
"myLogGroup": {
"Type": "AWS::Logs::LogGroup",
"Properties": {
"LogGroupName": {
"Fn::Sub": [
"cloud_watch_${log_group_name}",
{
"log_group_name": {
"Fn::FindInMap": [
"LogGroupMapping",
"Test",
"Name"
]
}
}
]
}
}
}
}
}
YAML:
Mappings:
LogGroupMapping:
Test:
Name: test_log_group
Prod:
Name: prod_log_group
Resources:
myLogGroup:
Type: 'AWS::Logs::LogGroup'
Properties:
LogGroupName: !Sub
- 'cloud_watch_${log_group_name}'
- log_group_name: !FindInMap
- LogGroupMapping
- Test
- Name
Fn:: Sub と Fn:: ImportValue 関数の併用
次の例では、マッピングを使用して Domain 変数を Fn::ImportValue 関数の結果の値に置き換えています。
注:ドメイン名は、別の CloudFormation スタックによって エクスポートされたアウトプットの名前です。
JSON:
{
"Resources": {
"DNS": {
"Type": "AWS::Route53::HostedZone",
"Properties": {
"Name": {
"Fn::Sub": [
"www.${Domain}",
{
"Domain": {
"Fn::ImportValue": "DomainName"
}
}
]
}
}
}
}
}
YAML:
Resources:
DNS:
Type: 'AWS::Route53::HostedZone'
Properties:
Name: !Sub
- 'www.${Domain}'
- Domain: !ImportValue DomainName