AWS :: RDS-使用对流层的多可用区

时间:2019-01-30 13:56:04

标签: python amazon-web-services amazon-cloudformation troposphere

当我在堆栈中运行它时,我正在使用Troposphere创建CloudFormation模板,它仅创建一个可用区。 我在每个子网中都有2个私有子网和1个可用区。 创建文件VPC, subnets, rounte internet gateway, EC2 instances and RDS instance时,除了它在RDS中为单个可用性区域创建的所有文件外,我都设置了MultiAZ = true,但仍然失败。

RDSdatabase = t.add_resource(
    rds.DBInstance(
        "RDSDatabase",
        DBName=Client+'RDSDatabase',
        AllocatedStorage=Ref(dballocatedstorage),
        DBInstanceClass=Ref(dbclass),
        Engine="MySQL",
        EngineVersion="5.5",
        MasterUsername=Ref(dbuser),
        MasterUserPassword=Ref(dbpassword),
        DBSubnetGroupName=Ref(mydbsubnetgroup),
        VPCSecurityGroups=[Ref(myvpcsecuritygroup)],
        MultiAZ=True,
        Tags=Tags(
            Application=ref_stack_name, Client=Client, Name=Client+'_RDS-Master_1'),
    ))

这是我的子网组---

mydbsubnetgroup = t.add_resource(
    rds.DBSubnetGroup(
    "MyDBSubnetGroup",
        DBSubnetGroupDescription="Subnets available for the RDS DB Instance",
        SubnetIds=[Ref(db_subnet_AZ_1),Ref(db_subnet_AZ_2)],
        Tags=Tags(Name=Join("-", [Ref("AWS::StackName"), "DBSubnetGroup"]),
      ),
    ))

1 个答案:

答案 0 :(得分:0)

我认为这主要是对MultiAZ所做的误解。单个RDS实例实际上只能位于单个可用性区域(和子网)中。 MultiAZ实际上并没有将该实例放入多个可用区中-它创建了一个备份实例,该实例与一个单独的可用区中的主实例保持同步(并且我并没有真正告诉您要提供哪个实例)如果主服务器以某种方式发生故障,则可以提高耐用性和正常运行时间。

请参阅:https://aws.amazon.com/rds/details/multi-az/