在代码中考虑Lambda热启动?

App*_*ins 1 python amazon-web-services aws-lambda

背景: 我每隔15分钟调用一个特定的Lambda函数来启动我的EC2实例.这通过查询标记的值来工作,如果该值与当前时间匹配,则将实例添加到要启动的实例列表中.

问题:然而,该功能仅在每四个小时工作一次,因为它经常被调用而保持"温暖".虽然函数是热的,但我在当前时间所拥有的变量 - 调用的时间 - 在温暖的环境中保持不变,并且永远不会更新到当前的,实际的,真正实际的实时时间.见下面的代码.

# This lambda script start EC2 instances

import boto3
import logging
from datetime import datetime, time

ec = boto3.resource('ec2')

startup = datetime.now().strftime('%H%M')
now = int(startup)
minutes = [now-5,now-4,now-3,now-2,now-1,now]
logger = logging.getLogger()
logger.setLevel(logging.ERROR)

print 'The current time is: %s' % (startup)

def lambda_handler(event, context):
    for min in minutes:
        wave = ec.instances.filter(
            Filters=[
                {'Name': 'instance-state-name', 'Values': ['stopped']},
                {'Name': 'tag:Autostop', 'Values': ['%d' % (min)]}
            ]
        )
        for i in wave:
            iid = (i.instance_id)
            for t in i.tags:
                if t['Key'] == 'Autostop':
                    start_value = t['Value']
                    print 'Instance %s should be started at %s UTC' % (iid, start_value)
                    try:
                        print 'Starting %s' % (iid)
                        i.start()
                    except:
                        print 'ERROR -- Error starting instance %s' % (iid)
                        pass
Run Code Online (Sandbox Code Playgroud)

在我的CloudWatch日志中,我看到每四个小时出现一个新的日志流,初始日志条目包含第15行的输出(当前时间是:X)但是日志流中的每个后续条目都只是START和END请求,没有提到当前时间.这持续了大约四个小时,然后功能似乎被回收并再次开始"冷".

我对编程比较陌生,想知道是否有办法确保每次调用函数时都会更新基于时间的变量(启动现在),无论是热调用还是冷调用.

hel*_*bye 5

你需要在lambda_handler函数中移动变量

def lambda_handler(event, context):
    startup = datetime.now().strftime('%H%M')
    now = int(startup)
    minutes = [now-5,now-4,now-3,now-2,now-1,now]
    for min in minutes:
        [...]
Run Code Online (Sandbox Code Playgroud)