问题1:run_instances的一些问题
这是一个boto3的run_instances()的请求,用来申请一台ec2。
import base64
import boto3
client = boto3.client('ec2')
# a 是一个shell脚本,使用api不需要base64。
a = """#!/bin/bash
touch /zxc.txt"""
# b是size
b = 20
args = {
'BlockDeviceMappings': [
{
'DeviceName': '/dev/sda1',
'Ebs': {
'DeleteOnTermination': True,
'VolumeSize': b,
},
},
],
'ImageId': 'ami-0b6c87788365803c7',
'InstanceType': 't2.micro',
'KeyName': 'fastone-deploy',
'MaxCount': 1,
'MinCount': 1,
'UserData': a,
'NetworkInterfaces': [
{
'AssociatePublicIpAddress': True,
'DeviceIndex': 0,
'Groups': ['sg-4096c929'],
'SubnetId': 'subnet-996587e2',
}
],
}
response = client.run_instances(**args)
print response
- userdata(用户数据)问题: 是个str,里面要写shell脚本,使用api不需要base64, 必须以
#!/bin/bash
开头,一定要 换行
如果这里要用yaml传参数,这里的shell应该写成下面这样:
userData: |
#/bin/bash
touch /zxc.txt
|
是换行,最后的效果是这样的:
2.ebs的问题,如果要自定义ebs的大小,DeviceName
应该把值设置成 /dev/sda1
,不然只会是一个8g的默认卷和另外的一个你设置的ebs卷,并且你设置的ebs是没有文件系统的。
3.networkInterfaces问题
AssociatePublicIpAddress
这个参数选项是为了让ec2有公有ip,方便从外网链接查看ec2信息。
Group
是security_group_id,SubnetId
是子网id,首先要保证sg的入站和出站都设置好,其次,子网必须是在sg下面的。最重要的是,千万不要在networkInterface的外层设置sg和subnet,因为和network同级的参数也有sg和subnet,会产生冲突。
问题二create_volume的问题
这里是boto3的create_volume的代码,作用是创建一个新的ebs卷。
import boto3
client = boto3.client('ec2')
response = client.create_volume(
AvailabilityZone='cn-northwest-1b',
Encrypted=False,
Size=8,
VolumeType='gp2',
DryRun=False,
)
print response
这里唯一的坑就是AvailabilityZone
可用区,它并不是北京和宁夏这种region,而是每个region下的可用区(上图是宁夏的b区,因为需要绑定的ec2在b区),并且可用区之间是不可attach的,比如a区的ebs卷是不能attach在b区的ec2上的,除非你把a区的ebs快照存在s3上,并且在b区再创建一个ebs卷,而且不同region无法attach,只能手动复制。
还有就是使用attach_volume这个api时,额外绑定的ebs是没有文件系统的,需要添加一些额外操作,去把ebs卷装上文件系统,并且mountpoint,需要挂载到根目录。
至于如何挂载请看linux挂载文件系统,mount,/etc/fstab。