[英]How to Launch a exact same replica of a EC2 instance in VPC from the AMI of a previous EC2 instance
我有一个不能重新启动的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。 我需要启动实例“ A”的完全相同的副本,即需要启动的实例必须具有相同的VPC,秒组,键名等。我在想我需要存储实例A的详细信息在变量中,然后使用它们从AMI或类似的东西启动新实例。
PS:以下代码有助于获取实例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__)
下面的代码将基本上获取您要为其提供实例ID的系统的名称,然后获取现有系统的详细信息以及新的副本系统
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
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.