最近开始从头学习Lambda 在AWS里面的自动化运用。我的操作主要是基于Python 3.7的版本,AWS的Python模块叫做Boto。具体的语法和概念都不赘述了,直接来看具体的例子。

首先来看看第一个简单的操作,如何创建一个新的EC2实例。

第一步,创建一个新的lambda函数,选择 author from scratch,这里他默认会自动创建一个IAM的role,并赋予访问cloudwatch log的权限

Lambda,AWS和Python的自动化管理操作 - 创建新的EC2 实例_第1张图片

默认的权限显示如下
Lambda,AWS和Python的自动化管理操作 - 创建新的EC2 实例_第2张图片

这里我们需要授予创建EC2的权限 ,因此需要修改对应的JSON。我们可以在IAM的role里面找到这个默认创建的Role,在默认的权限上面添加对 ec2:runinstances 访问就可以了。当然我们也可以一开始就手动创建一个新的role。

Lambda,AWS和Python的自动化管理操作 - 创建新的EC2 实例_第3张图片

下面是更新之后的权限图
Lambda,AWS和Python的自动化管理操作 - 创建新的EC2 实例_第4张图片

接下来是Lambda函数。Lambda函数都是靠事件来触发的,因此传入参数里面有event和context。

函数里面首先是导入模块
接下来传入几个环境变量,这几个环境变量是直接在函数下面的表格里面自定义的
然后在lambda_handler这个入口函数里面,直接创建一个新的EC2实例,传入参数。注意这个函数有2个形式参数event和context,这个是函数自带的,这里我们用不上,但是仍然需要写上

Lambda,AWS和Python的自动化管理操作 - 创建新的EC2 实例_第5张图片

这几个环境变量分别代表 AMI的代码,实例类型,Key pair的名字和 subnet的子网代码

Lambda,AWS和Python的自动化管理操作 - 创建新的EC2 实例_第6张图片

点击test,会提醒配置test的事件,这里我们不需要传入任何参数,因此选择最简单的hello world模板,传入一个空的参数就行了

Lambda,AWS和Python的自动化管理操作 - 创建新的EC2 实例_第7张图片

保存之后再次点击test, 会显示成功执行

Lambda,AWS和Python的自动化管理操作 - 创建新的EC2 实例_第8张图片

查看一下EC2实例 ,的确一个新的实例已经创建了!
Lambda,AWS和Python的自动化管理操作 - 创建新的EC2 实例

这个例子创建成功了,但是我已经发现在控制台里面输入脚本不那么方便了。豆子写Python更习惯在windows下使用Pycharm,那么如何在Pycharm里面使用boto3呢?

首先需要安装boto3

pip install boto3

然后还需要安装一个工具叫做 pyboto3, 这是因为默认情况下Pycharm没法自动为boto3 进行autocomplete,安装pyboto3之后就可以提示函数了,不过目前只支持boto3.client的使用。

pip install pyboto3

最后打开Pycharm的设置,添加Project Interpreter

Lambda,AWS和Python的自动化管理操作 - 创建新的EC2 实例_第9张图片

为了访问我的aws账户,我还需要配置credential。下载安装
AWS CLI。然后在cmd里面输入

aws configure

根据提示填写对应的信息。

配置完成之后,下面简单的测试一下是否工作。

Lambda,AWS和Python的自动化管理操作 - 创建新的EC2 实例_第10张图片

执行一下

import boto3

def getEC2():

    ec2=boto3.client('ec2')
    """ :type : pyboto3.ec2 """
    instance=ec2.describe_instances()
    print(instance)

if __name__ == '__main__':
    getEC2()

获取到我刚刚创建的EC2 信息。

Lambda,AWS和Python的自动化管理操作 - 创建新的EC2 实例