我有一个EC2实例A,不能重新启动,但问题是它会因维护而停机。我基本上使用我的代码创建此实例的AMI,如下所示:
import boto.ec2
import time
import sys
conn = boto.ec2.connect_to_region("ap-southeast-1")
image_id = conn.create_image(sys.argv[1], "nits", description="Testing", no_reboot=True, block_device_mapping=None, dry_run=False)
image = conn.get_all_images(image_ids=[image_id])[0]
while image.state != 'available':
time.sleep(10)
image.update()
print "The image is being Created, Please wait!! state:%s" % (image.state)
if image.state == 'available':
print "AMI CREATED SUCCESSFULLY with AMI id = %s" % image_id
else:
print "Something Went Wrong!!"
上面的脚本工作正常,并创建我作为系统参数提供的实例的AMI。我需要启动实例的完全相同的REPLICA" A" ,即需要启动的实例需要具有相同的VPC,sec组,密钥名称等。 我想我需要将实例A的详细信息存储在变量中,然后使用它们从AMI或类似的东西中启动一个新实例。
P.S:以下代码有助于获取实例A的详细信息:
reservations=conn.get_all_instances(sys.argv[1])
instances = [i for r in reservations for i in r.instances]
for i in instances:
print(i.__dict__)
答案 0 :(得分:0)
下面的代码将基本上采用你将提供实例id的系统的ami,然后它获取现有系统的详细信息,以及lauch新的副本系统
from boto.regioninfo import *
from boto.ec2.connection import EC2Connection
# Enter Instance ID here for which you want replication
instance_id = 'i-XXXXXXXX'
# AWS connect info
aws_access_key_id='########## AWS Access Key ############'
aws_secret_access_key='########### AWS Secret Key ############'
region_name='ap-southeast-1'
region_ec2_endpoint='ec2.ap-southeast-1.amazonaws.com'
# Connect EC2
aws_region = RegionInfo(name=region_name, endpoint=region_endpoint)
conn = EC2Connection(aws_access_key_id,aws_secret_access_key,region=aws_region)
# create ami
print "Step 1 : Creating ami"
ami_id = conn.create_image(instance_id,"testami",no_reboot=True)
ami_status = "Pending"
print "ami is being launched " + ami_id
# check_ami_status
image = conn.get_image(ami_id)
while image.state == "pending":
time.sleep(10)
image = conn.get_image(ami_id)
print "ami is in pending state, waiting for 10 sec before next check"
image = conn.get_image(ami_id)
print "Image is now " + image.state
reservations = conn.get_all_instances(instance_ids=[instance_id])
instances = [i for r in reservations for i in r.instances]
for i in instances:
key_name = i.key_name
security_group = []
for each in i.groups:
security_group.append(each.id)
instance_type = i.instance_type
subnet_name = i.subnet_id
vpc_id = i.vpc_id
reserve = conn.run_instances(image_id=ami_id,subnet_id=subnet_name ,key_name=key_name,instance_type=instance_type,security_group_ids =security_group)
print "new replica system id is " + reserve.instances[0].id