[英]How to use Mappings in AWS CloudFormation templates in nested stacks
让我们考虑在同一 AWS CloudFormation 模板中使用以下Mappings
和FindInMap
。 他们会工作的。
Now, consider the VpcIds
under Mappings
are in the master.yaml
template, and I am trying to create the EgressOnlyInternetGateway
resource from the nested.yaml
template using those Mappings
located in the master.yaml
template.
我怎样才能做到这一点?
# master.yaml
Mappings:
VpcIds:
us-east-1:
"123456789012": "vpc-00011122233344455"
"234567890123": "vpc-11122233344455566"
us-west-1:
"123456789012": "vpc-22233344455566677"
"234567890123": "vpc-33344455566677788"
# nested.yaml
Resources:
EgressOnlyInternetGateway:
Type: AWS::EC2::EgressOnlyInternetGateway
Properties:
VpcId: !FindInMap [VpcIds, !Ref "AWS::Region", !Ref "AWS::AccountId"]
更新:我正在尝试使用MyTestMasterStack
中定义的映射参数在MyTestNestedStack
( MyTestNestedStack.yaml
)中创建资源MyTestNestedSg
,如下所示。 我收到错误:针对MyTestNestedStack
Parameter values specified for a template which does not require them
。
我该如何解决这个问题?
请注意, MyTestMasterSg
MyTestMasterStack
为了完整性。
# MyTestMasterStack.yaml
Mappings:
VpcIds:
us-east-1:
"123456789012": "vpc-00011122233344455"
"234567890123": "vpc-11122233344455566"
Resources:
MyTestNestedStack:
Type: AWS::CloudFormation::Stack
Properties:
Parameters:
VpcId: !FindInMap [VpcIds, !Ref "AWS::Region", !Ref "AWS::AccountId"]
TemplateURL: "https://s3.amazonaws.com/my_template_bucket_name/MyTestNestedStack.yaml"
TimeoutInMinutes: 60
MyTestMasterSg:
Type: AWS::EC2::SecurityGroup
Properties:
VpcId: "vpc-017a12485ad93e94a"
GroupDescription: Testing resource creation wtih Mappings from the parent Stack
GroupName: MyTestMasterSg
SecurityGroupIngress:
- CidrIp: 10.1.0.0/16
FromPort: 80
IpProtocol: tcp
ToPort: 80
# MyTestNestedStack.yaml
Resources:
MyTestNestedSg:
Type: AWS::EC2::SecurityGroup
Properties:
VpcId: !Ref VpcId
GroupDescription: Testing resource creation wtih Mappings from the parent Stack
GroupName: MyTestNestedSg
SecurityGroupIngress:
- CidrIp: 10.1.0.0/16
FromPort: 8080
IpProtocol: tcp
ToPort: 8080
你不能这样做。 您必须通过参数将解析的映射值传递到您的AWS::CloudFormation::Stack
资源。
嵌套堆栈应该是自给自足的,它们无权访问父堆栈的参数、映射或资源。 它们只能处理您通过AWS::CloudFormation::Stack
资源的Parameters
明确传递的数据。
所以在父堆栈中你必须这样做:
MyNestedStack:
Type: AWS::CloudFormation::Stack
Properties:
Parameters:
VpcId : !FindInMap [VpcIds, !Ref "AWS::Region", !Ref "AWS::AccountId"]
TemplateURL: String
更新
您的MyTestNestedStack.yaml
缺少Paramters
:
Parameters:
VpcId:
Type: AWS::EC2::VPC::Id
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.