Лямбда + питон + код выхода

1

Я столкнулся с проблемой простой лямбда-функции AWS, написанной на Python.

Когда я запускаю свою функцию Lambda, мой код работает должным образом, результат правильный, но он все еще заканчивается кодом ошибки (код выхода): "Process exited before completing request", это приводит к тому, что Lambda запускается 3 раза (асинхронно)).

Есть ли у вас лучшие практики для управления кодом выхода для Lambda?

#!/usr/bin/python

import boto3
import sys
import tweepy
import datetime

session = boto3

# Init s3 client
s3 = session.resource('s3')

def get_data_and_push(s3_bucket, s3_key, user):
    # Retrieve CSV file
    try:
        dest = s3.Object(s3_bucket, s3_key)
        dest.download_file(tmpfile)
    except Exception, e:
        print 'An error occured while trying to download CSV file'
        print 'This exception has been thrown :'
        print e
        sys.exit(1)

    # Authenticate to Twitter
    try:
        auth = tweepy.OAuthHandler(t_consumer_key, t_consumer_secret)
        auth.set_access_token(t_access_token_key, t_access_token_secret)
        api = tweepy.API(auth)
    except Exception, e:
        print 'Cannot authenticate to Twitter.'
        print 'This exception has been thrown :'
        print e
        sys.exit(2)

    data = api.get_user(user)
    print 'User : ' + data.screen_name
    print 'Followers : ' + str(data.followers_count)
    print 'Friends : ' + str(data.friends_count)
    print '-----------'

    # Get today date
    today = datetime.datetime.now().strftime("%Y-%m-%d")

    # Write result
    try:
        # Write result at the end of the file
        file = open(tmpfile, 'a')
        file.write(today + ',' + str(data.followers_count) + ',' + str(data.friends_count)+ '\n')
        file.close()
    except Exception, e:
        print 'Unable to write in temp file'
        print 'This exception has been thrown :'
        print e
        sys.exit(5)

    # Upload final file
    try:
        # Push file to S3
        dest.upload_file(tmpfile)
    except Exception, e:
        print 'An error occured while trying to upload CSV file'
        print 'This exception has been thrown :'
        print e
        sys.exit(6)

def main(event, context):
    for user in userlist:
        get_data_and_push(bucket, 'export_' + user + '.csv', user)
    sys.exit(0)

Спасибо за вашу помощь,

Теги:
amazon-web-services
aws-lambda

1 ответ

4
Лучший ответ

короткий

Да, удалите sys.exit(0) в конце вашего кода, который должен это сделать :-)


дольше

Выполняя sys.exit(0) вы фактически прекратите процесс, выполняющий ваш код в функции лямбда. И этого не ожидает исполнитель.

Я предполагаю, что обработчик Lambda Function фактически запускается из рамки AWS. Следовательно, вы уже находитесь в процессе python, и ваш обработчик называется где-то в коде AWS. Поэтому, если вы выходите из процесса, вы на самом деле сокращаете рамки AWS, которые не могут справиться с разрешением выполнения Lambda.

  • 0
    Работает! спасибо @ Леопольд

Ещё вопросы

Сообщество Overcoder
Наверх
Меню