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请求,没有提到当前时间.这持续了大约四个小时,然后功能似乎被回收并再次开始"冷".
我对编程比较陌生,想知道是否有办法确保每次调用函数时都会更新基于时间的变量(启动和现在),无论是热调用还是冷调用.
你需要在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)
| 归档时间: |
|
| 查看次数: |
236 次 |
| 最近记录: |