Ведение журнала исключений среды выполнения AWS Lambda Python 3.7 - PullRequest
0 голосов
/ 02 января 2019

Необработанные исключения, возникающие при использовании среды выполнения Python 3.7, по-видимому, не регистрируются в CloudWatch, как в Python 3.6. Как вы можете настроить регистратор в Python 3.7 для сбора этой информации?

Также опубликовано на форуме AWS

Для копирования:

1. Создайте лямбда-функцию следующим образом:

import logging
logger = logging.getLogger()
logger.setLevel(logging.DEBUG)
def lambda_handler(event, context):
logger.info("This shows fine")
raise Exception("I failed")  

2. Запустите эту функцию, используя среду исполнения Python 3.6

START RequestId: a2b6038b-0e5f-11e9-9226-9dfc35a22dcc Version: $LATEST
[INFO]  2019-01-02T07:25:52.797Z    a2b6038b-0e5f-11e9-9226-9dfc35a22dcc //This shows fine
 I failed: Exception
Traceback (most recent call last):
File "/var/task/lambda_function.py", line 9, in lambda_handler
        raise Exception("I failed")
Exception: I failed

END RequestId: a2b6038b-0e5f-11e9-9226-9dfc35a22dcc
REPORT RequestId: a2b6038b-0e5f-11e9-9226-9dfc35a22dcc  Duration: 1.12 ms   Billed Duration: 100 ms     Memory Size: 128 MB Max Memory Used: 21 MB

2. Переключитесь на среду исполнения Python 3.7 и запустите снова ... без трассировки стека

    START RequestId: 3840aa8e-0e5d-11e9-bece-45a2022a53c6 Version: $LATEST
    [INFO]  2019-01-02T07:08:35.170Z    3840aa8e-0e5d-11e9-bece-45a2022a53c6    This shows fine

    END RequestId: 3840aa8e-0e5d-11e9-bece-45a2022a53c6
    REPORT RequestId: 3840aa8e-0e5d-11e9-bece-45a2022a53c6  Duration: 2.20 ms   Billed Duration: 100 ms     Memory Size: 128 MB Max Memory Used: 20 MB  

Ответы [ 3 ]

0 голосов
/ 03 января 2019

Да, я это заметил. Для преодоления использую декоратор.

def log_errors(func: Callable[[dict, dict], None]):
    def wrapper(*args, **kwargs):
        try:
            func(*args, **kwargs)
        except Exception as err:
            warning(traceback.format_exc())
            raise err

    return wrapper

Использование:

@log_errors
def handler(event, context):
...
0 голосов
/ 15 января 2019

Это ошибка в AWS Lambda.Я заметил это в середине декабря и подал вопрос;ответ включал следующее: «Я хотел бы сообщить вам, что это было определено как подлинная проблема, и в настоящее время команда Lambda работает над ее решением. Но, к сожалению, у меня нет ETA, когда эта проблема будет решена. "

Мое решение состояло в том, чтобы вернуться к среде выполнения python3.6, пока Amazon ее не исправит.

0 голосов
/ 02 января 2019

Это странно, потому что Exception - встроенная функция, которая должна работать как на 3,6, так и на 3,7.

В качестве обходного пути, я бы предложил сделать пользовательское исключение.Вот простой пример.

test.py

class Error(Exception):
    pass

class CustomException(Error):
    pass

raise CustomException("I failed")

Вот результат при запуске.

TK$ python3 test.py 

Traceback (most recent call last):
 File "test.py", line 7, in <module>
    raise CustomException("I failed")
__main__.CustomException: I failed
...