Lambda,AWS和Python的自动化管理操作(1)

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

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

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

Lambda,AWS和Python的自动化管理操作(1)

默认的权限显示如下
Lambda,AWS和Python的自动化管理操作(1)

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

Lambda,AWS和Python的自动化管理操作(1)

下面是更新之后的权限图
Lambda,AWS和Python的自动化管理操作(1)

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

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

Lambda,AWS和Python的自动化管理操作(1)

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

Lambda,AWS和Python的自动化管理操作(1)

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

Lambda,AWS和Python的自动化管理操作(1)

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

Lambda,AWS和Python的自动化管理操作(1)

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

猜你喜欢

转载自blog.51cto.com/beanxyz/2438381