首页 > 解决方案 > 如何动态获取 Cloud Formation 中的 AWS 可用区?

问题描述

最近我开始探索 AWS CloudFormation。我对使用 Fn::GetAZs 动态获取可用区有疑问吗?我希望可用区不被硬编码。YAML 格式的代码如下:-

AWSTemplateFormatVersion: 2010-09-09
Description: Hardcoded Value of Availability zone
Parameters: 
 MyKeyName:
  Description: Arshan Select the key Name from the boelow 
  Type: AWS::EC2::KeyPair::KeyName
 MyZone:
  Description: Select the MyAZone
  Type: String
  Default: us-east-1
  AllowedValues:
  - us-east-1
  - us-east-2
Resources:
 DevEC2Instance:
  Type: AWS::EC2::Instance
  Properties:
   InstanceType: t2.micro
   ImageId: ami-04aa88aebb9fefd83
   KeyName: !Ref MyKeyName 
   SecurityGroup: !Ref SSHSecurityGroup
   AvailabilityZone: !Ref MyZone
 SSHSecurityGroup:
  Type: AWS::EC2::SecurityGroup 
  Properties: 
   GroupDescription: My Sg
   SecurityIngress:
    IpProtocol: tcp
    ToPort: 22
    FromPort: 22
    Cidr: 0.0.0.0/0
   SecurityEgress:
    IpProtocol: tcp 
    ToPort: 8080
    FromPort: 8080
    Cidr: 0.0.0.0/0

标签: amazon-web-servicesamazon-s3amazon-ec2aws-lambdaamazon-cloudformation

解决方案


如果您想Fn::GetAZs在 Parameter 中使用MyZone来定义允许的 AZ,那么您不能这样做。CloudFormation不支持这样的事情。您MyZone必须对要允许的可用区进行硬编码。

Fn::GetAZs稍后可以在您的资源中使用,但不能在MyZone参数中使用。


推荐阅读