关于boto3中run_instances和volume的问题

问题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
  1. 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。

你可能感兴趣的:(关于boto3中run_instances和volume的问题)