Список зон доступности в су bnet python boto3 - PullRequest
0 голосов
/ 21 января 2020

У меня есть скрипт, который создает AWS экземпляров и помещает их в su bnet и зону доступности.

Но зона доступности должна соответствовать su bnet, иначе вы получите ошибка, которая говорит:

 An error occurred (InvalidParameterValue) when calling the RunInstances operation: Value (us-east-1f) for parameter availabilityZone is invalid. Subnet 'subnet-87bd70ca' is in the availability zone us-east-1c

Это код, который у меня есть на данный момент:

import boto3
import objectpath
subnet_id = input("Enter the subnet id: ")
public_ip = input("Create a public ip (True|False): ")
private_ip = input("Enter the private IP address: ")
availability_zones = ec2_client.describe_availability_zones()
tree = objectpath.Tree(availability_zones)
availability_zones = set(tree.execute('$..ZoneName'))
availability_zones = list(availability_zones)
availability_zones = str(availability_zones).replace('[','').replace(']','').replace('\'','')
availability_zone = input("Enter the availability zone: ")
        instances = ec2_resource.create_instances(
        ImageId=image_id,
        InstanceType=instance_type,
        KeyName=key_name,
        MaxCount=max_count,
        MinCount=1,
        DryRun=False,
        DisableApiTermination=True,
        EbsOptimized=False,
        Placement={
            'AvailabilityZone': availability_zone,
            'Tenancy': tenancy,
        },
        InstanceInitiatedShutdownBehavior='stop',
        NetworkInterfaces=[
            {
                'AssociatePublicIpAddress': public_ip,
                'DeleteOnTermination': True,
                'DeviceIndex': 0,
                'PrivateIpAddress': private_ip,
                'SubnetId': subnet_id,
                'Groups': [
                    sg_id
                ]
            }
        ]
        )

Есть ли способ узнать, к какой доступной зоне принадлежит su bnet

Ответы [ 2 ]

1 голос
/ 21 января 2020

Если вы укажете su bnet, указывать зону доступности .

не нужно. Это потому, что в * su bnet существует только одна зона доступности. Следовательно, предоставление su bnet также сообщает EC2, какой AZ использовать.

0 голосов
/ 21 января 2020

Хотя у меня нет точного ответа, я думаю, вы могли бы найти функцию в boto, которая возвращает результаты, аналогичные aws ec2 describe-subnets, а затем создать функцию проверки из этого.

Вы должны Посмотрите в Terraform, это колесо, которое я заново изобрел, но не нужно.

HTH

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...