Creación de funciones de Lambda con Python - AWS Lambda

Creación de funciones de Lambda con Python

Puede ejecutar Python code en AWS Lambda. Lambda proporciona tiempos de ejecución para Python que ejecutan el código para procesar eventos. El código se ejecuta en un entorno que incluye el SDK para Python (Boto3), con credenciales de un rol de AWS Identity and Access Management (IAM) administrado por usted.

Lambda admite los siguientes entornos de ejecución de Python.

nota

El fin del soporte para el tiempo de ejecución de Python 2.7 comienza el 15 de julio de 2021. Para obtener más información, consulte Política de soporte del tiempo de ejecución.

Tiempos de ejecución de Python
Nombre Identifier AWS SDK para Python Sistema operativo

Python 3.8

python3.8

boto3-1.16.31 botocore-1.19.31

Amazon Linux 2

Python 3.7

python3.7

boto3-1.16.31 botocore-1.19.31

Amazon Linux

Python 3.6

python3.6

boto3-1.16.31 botocore-1.19.32

Amazon Linux

Python 2.7

python2.7

boto3-1.16.31 botocore-1.19.32

Amazon Linux

Para crear una función de Python

  1. Abra la consola de Lambda.

  2. Elija Create function (Crear función).

  3. Configure los siguientes ajustes:

    • Name (Nombre): my-function.

    • Runtime (Tiempo de ejecución): Python 3.8.

    • Role (Rol): Choose an existing role (Elija un rol existente).

    • Existing role (Rol existente): lambda-role.

  4. Elija Create function (Crear función).

  5. Para configurar un evento de prueba, seleccione Test (Prueba).

  6. Para Event name (Nombre de evento), escriba test.

  7. Seleccione Create (Crear).

  8. Para invocar la función, elija Test (Probar).

La consola crea una función de Lambda con un único archivo de origen denominado lambda_function. Puede editar este archivo y agregar más archivos en el editor de código integrado. Para guardar los cambios, elija Save. A continuación, para ejecutar el código, elija Test (Probar).

nota

La consola de Lambda utiliza AWS Cloud9 para proporcionar un entorno de desarrollo integrado en el navegador. También puede utilizar AWS Cloud9 para desarrollar funciones Lambda en su propio entorno. Para obtener más información, consulte Trabajar con funciones Lambda en la Guía del usuario de AWS Cloud9.

El archivo lambda_function exporta una función denominada lambda_handler que toma un objeto de evento y un objeto context. Esta es la función de controlador a la que llama Lambda cuando se invoca la función. El tiempo de ejecución de la función de Python obtiene los eventos de invocación de Lambda y se los pasa al controlador. En la configuración de función, el valor de controlador es lambda_function.lambda_handler.

Cada vez que guarde el código de la función, la consola de Lambda crea un paquete de implementación, que es un archivado mediante archivos .zip que contiene el código de la función. A medida que avanza su función de desarrollo, querrá almacenar su código de función en el control del código fuente, agregar bibliotecas y automatizar las implementaciones. Comience creando un paquete de implementación y actualizando el código en la línea de comandos.

nota

Para comenzar con el desarrollo de aplicaciones en su entorno local, implemente una de las aplicaciones de ejemplo disponibles en el repositorio de GitHub de esta guía.

Aplicaciones de Lambda de ejemplo en Python

  • blank-python:– una función de Python que muestra el uso del registro, las variables del entorno, el seguimiento de AWS X-Ray, las capas, las pruebas unitarias y el SDK de AWS.

El tiempo de ejecución de la función pasa un objeto context al controlador, además del evento de invocación. El objeto context contiene información adicional acerca de la invocación, la función y el entorno de ejecución. Más información disponible en las variables de entorno.

La función de Lambda incluye un grupo de registros de CloudWatch Logs. El tiempo de ejecución de la función envía detalles sobre cada invocación a CloudWatch Logs. Retransmite cualquier registro que genere la función durante la invocación. Si la función devuelve un error, Lambda formatea el error y se lo devuelve al invocador.