Lambda DG
Lambda DG
Lambda DG
Amazon's trademarks and trade dress may not be used in connection with any product or service that is not Amazon's,
in any manner that is likely to cause confusion among customers, or in any manner that disparages or discredits
Amazon. All other trademarks not owned by Amazon are the property of their respective owners, who may or may not
be affiliated with, connected to, or sponsored by Amazon.
AWS Lambda Guía para desarrolladores
Table of Contents
¿Qué es AWS Lambda? ...................................................................................................................... 1
¿Cuándo debo usar AWS Lambda? .............................................................................................. 1
¿Es la primera vez que usa AWS Lambda? ................................................................................... 2
Introducción ....................................................................................................................................... 3
Crear una función ....................................................................................................................... 3
Uso del diseñador .............................................................................................................. 4
Invocar la función de Lambda .............................................................................................. 4
Eliminar recursos ................................................................................................................ 6
Editor de código ......................................................................................................................... 7
Uso de archivos y carpetas .................................................................................................. 7
Trabajar con código ............................................................................................................ 9
Trabajar en modo de pantalla completa ............................................................................... 12
Trabajar con preferencias ................................................................................................... 12
AWS CLI ................................................................................................................................. 13
Requisitos previos ............................................................................................................. 13
Creación del rol de ejecución ............................................................................................. 13
Creación de la función ....................................................................................................... 15
Listado de las funciones Lambda de su cuenta ..................................................................... 17
Recuperar una función Lambda. ......................................................................................... 17
Eliminar recursos .............................................................................................................. 18
Conceptos ............................................................................................................................... 18
Función ........................................................................................................................... 18
Qualifier ........................................................................................................................... 18
Tiempo de ejecución ......................................................................................................... 19
Evento ............................................................................................................................. 19
Simultaneidad ................................................................................................................... 19
Trigger ............................................................................................................................ 20
Características .......................................................................................................................... 20
Modelo de programación .................................................................................................... 20
Paquete de implementación ............................................................................................... 22
Capas ............................................................................................................................. 22
Escalado ......................................................................................................................... 22
Controles de simultaneidad ................................................................................................ 23
Invocación asincrónica ....................................................................................................... 25
Mapeos de origen de eventos ............................................................................................ 26
Destinos .......................................................................................................................... 27
Proyectos de funciones ...................................................................................................... 28
Plantillas de aplicaciones ................................................................................................... 29
Herramientas ............................................................................................................................ 29
AWS Command Line Interface ............................................................................................ 29
Modelo de aplicación sin servidor de AWS ........................................................................... 29
CLI de SAM ..................................................................................................................... 30
Herramientas para crear código .......................................................................................... 30
Cuotas .................................................................................................................................... 31
Permisos ......................................................................................................................................... 33
Rol de ejecución ....................................................................................................................... 33
Creación de un rol de ejecución en la consola de IAM ............................................................ 35
Administración de roles con la API de IAM ........................................................................... 35
Políticas administradas para características de Lambda .......................................................... 36
Políticas basadas en recursos .................................................................................................... 37
Concesión de acceso a las funciones a los servicios de AWS .................................................. 39
Concesión de acceso a las funciones a otras cuentas ............................................................ 39
Concesión de acceso a las capas a otras cuentas ................................................................. 41
Limpieza de políticas basadas en recursos ........................................................................... 41
iii
AWS Lambda Guía para desarrolladores
iv
AWS Lambda Guía para desarrolladores
v
AWS Lambda Guía para desarrolladores
vi
AWS Lambda Guía para desarrolladores
vii
AWS Lambda Guía para desarrolladores
viii
AWS Lambda Guía para desarrolladores
ix
AWS Lambda Guía para desarrolladores
x
AWS Lambda Guía para desarrolladores
xi
AWS Lambda Guía para desarrolladores
xii
AWS Lambda Guía para desarrolladores
¿Cuándo debo usar AWS Lambda?
Puede utilizar AWS Lambda para ejecutar código como respuesta a eventos, por ejemplo, cambios en
los datos de un bucket de Amazon S3 o de una tabla de Amazon DynamoDB; para ejecutar código como
respuesta a solicitudes HTTP utilizando Amazon API Gateway; o invocar código utilizando las llamadas a
las API realizadas a través de los SDK de AWS. Con estas funciones, puede utilizar Lambda para crear
fácilmente disparadores de procesamiento de datos para servicios de AWS como Amazon S3 y Amazon
DynamoDB, procesar datos de streaming almacenados en Kinesis o crear un backend propio que opere
con el nivel de seguridad, desempeño y escala de AWS.
También puede crear aplicaciones sin servidor compuestas por funciones activadas por eventos
e implementarlas automáticamente utilizando CodePipeline y AWS CodeBuild. Para obtener más
información, consulte Aplicaciones de AWS Lambda (p. 144).
Cuando se utiliza AWS Lambda, solo es necesario preocuparse por el código. AWS Lambda administra
la flota de computación, que ofrece una combinación equilibrada de memoria, CPU, red y otros recursos.
Esto es a cambio de flexibilidad, lo que significa que no se puede iniciar sesión en instancias de
computación ni personalizar el sistema operativo ni los tiempos de ejecución proporcionado. Estas
restricciones permiten que AWS Lambda realice actividades operativas y administrativas en su nombre,
como son el aprovisionamiento de capacidad, la monitorización del estado de la flota, la aplicación de
parches de seguridad, la implementación del código, y la monitorización y el registro de las funciones de
Lambda.
Si necesita administrar sus propios recursos informáticos, Amazon Web Services también ofrece otros
servicios informáticos para satisfacer sus necesidades.
• El servicio Amazon Elastic Compute Cloud (Amazon EC2) ofrece flexibilidad y una amplia variedad de
tipos de instancias de EC2 para elegir. Ofrece la posibilidad de personalizar los sistemas operativos,
la pila completa de software y la configuración de red y de seguridad, pero el usuario es responsable
de aprovisionar la capacidad, monitorizar el estado y el desempeño de la flota y utilizar las zonas de
disponibilidad para aumentar la tolerancia a errores.
• Elastic Beanstalk ofrece un servicio fácil de utilizar para implementar y escalar aplicaciones en Amazon
EC2, en el que se mantiene la propiedad y el control total sobre las instancias EC2 subyacentes.
1
AWS Lambda Guía para desarrolladores
¿Es la primera vez que usa AWS Lambda?
Lambda es un servicio de alta disponibilidad. Para obtener más información, consulte el Acuerdo de nivel
de servicios de AWS Lambda.
1. Lea la información general del producto y vea el vídeo introductorio para conocer los ejemplos de casos
de uso. Estos recursos están disponibles en la página web deAWS Lambda .
2. Realice el ejercicio de introducción basado en la consola. El ejercicio ofrece instrucciones para crear
y probar su primera función de Lambda mediante la consola. También obtendrá información sobre
el modelo de programación y otros conceptos de Lambda. Para obtener más información, consulte
Introducción a AWS Lambda (p. 3).
3. Lea la sección Implementación de aplicaciones con AWS Lambda (p. 144) de esta guía. Esta sección
presenta varios componentes de AWS Lambda con los que va a trabajar para crear una experiencia
integral.
Además del ejercicio de introducción, puede examinar distintos casos de uso, cada uno de los cuales
dispone de un tutorial que presenta un escenario de ejemplo. Puede realizar tutoriales específicos acordes
con las necesidades de su aplicación (por ejemplo, si desea que la invocación de la función de Lambda
sea controlada por eventos o bajo demanda). Para obtener más información, consulte Utilización de AWS
Lambda con otros servicios (p. 163).
2
AWS Lambda Guía para desarrolladores
Crear una función
Para poder utilizar Lambda y otros servicios de AWS, necesita disponer de una cuenta de AWS.
Si no dispone de una cuenta, visite aws.amazon.com y, a continuación, elija Create an AWS
Account (Crear una cuenta de AWS). Para obtener instrucciones detalladas, consulte Creación y
activación de una cuenta de AWS.
Como práctica recomendada, también debe crear un usuario de AWS Identity and Access
Management (IAM) con permisos de administrador y utilizarlo para todo el trabajo que no requiera
el uso de credenciales raíz. Cree una contraseña para el acceso a la consola y claves de acceso
para utilizar herramientas de línea de comandos. Consulte Creación del primer grupo y usuario
administrador de IAM en la Guía del usuario de IAM para obtener instrucciones.
Puede crear funciones en la consola de Lambda, con un conjunto de herramientas IDE, con herramientas
de línea de comandos o con SDK. La consola de Lambda proporciona un editor de código (p. 7) para
lenguajes no compilados que permite modificar y probar el código con rapidez. La AWS CLI (p. 13)
ofrece acceso directo a la API de Lambda para la configuración avanzada y casos de uso de
automatización.
Temas
• Creación de una función Lambda con la consola (p. 3)
• Creación de funciones mediante el editor de la consola de AWS Lambda (p. 7)
• Uso de AWS Lambda con AWS Command Line Interface (p. 13)
• Conceptos de AWS Lambda (p. 18)
• Características de AWS Lambda (p. 20)
• Herramientas para usar AWS Lambda (p. 29)
• Cuotas de AWS Lambda (p. 31)
3
AWS Lambda Guía para desarrolladores
Uso del diseñador
Lambda crea una función de Node.js y un rol de ejecución que concede a la función permiso para cargar
registros. Lambda asume el rol de ejecución cuando se invoca la función y lo utiliza para crear credenciales
para el SDK de AWS y para leer datos de los orígenes de eventos.
Elija my-función en el diseñador para volver al código y la configuración de la función. Para los lenguajes
de scripting, Lambda incluye código de muestra que devuelve una respuesta de operación correcta. Puede
editar el código de la función con el editor AWS Cloud9 integrado, siempre y cuando el código fuente no
supere el límite de 3 MB.
{
"key3": "value3",
"key2": "value2",
"key1": "value1"
4
AWS Lambda Guía para desarrolladores
Invocar la función de Lambda
Si lo desea, puede modificar las claves y los valores en el código JSON de muestra, pero no cambie
la estructura del evento. Si realiza alguna modificación en las claves o los valores, debe actualizar el
código de muestra según sea necesario.
3. Elija Create (Crear) y después Test (Prueba). Cada usuario puede crear hasta 10 eventos de prueba
por función. Dichos eventos de prueba no están disponibles para otros usuarios.
4. AWS Lambda ejecuta la función en su nombre. El handler de la función de Lambda recibe el evento
de muestra y, a continuación, lo procesa.
5. Si la ejecución se realiza correctamente, puede ver los resultados en la consola.
Tenga en cuenta que el enlace Click here (Haga clic aquí) muestra los registros en la consola de
CloudWatch. A continuación, la función añade registros a Amazon CloudWatch en el grupo de
registros correspondiente a la función de Lambda.
6. Ejecute la función de Lambda varias veces para recopilar algunas métricas que podrá ver en el
siguiente paso.
7. En las pestañas situadas cerca de la parte superior de la página, elija Monitoring (Monitorización).
Esta página muestra gráficos de las métricas que Lambda envía a CloudWatch.
5
AWS Lambda Guía para desarrolladores
Eliminar recursos
Para obtener más información acerca de estos gráficos, consulte Monitorización de funciones en la
consola de AWS Lambda (p. 464).
Eliminar recursos
Si ha terminado de trabajar con la función de ejemplo, elimínela. También puede eliminar el rol de
ejecución creado por la consola y el grupo de registro que almacena los registros de la función.
1. Abra la Log groups page (Página del grupo de registros) de la consola de Amazon CloudWatch.
2. Elija el grupo de registros de la función (/aws/lambda/my-function).
3. Elija Actions (Acciones) y, a continuación, elija Delete log group (Eliminar grupo de registro).
4. Elija Yes, Delete (Sí, eliminar).
6
AWS Lambda Guía para desarrolladores
Editor de código
Puede automatizar la creación y limpieza de funciones, roles y grupos de registro con AWS
CloudFormation y la AWS CLI. Para obtener información sobre aplicaciones de ejemplo totalmente
funcionales, consulte Aplicaciones de muestra de Lambda (p. 315).
Para obtener una lista de lo que hacen los comandos, consulte la Referencia de comandos del menú en la
Guía del usuario de AWS Cloud9. Tenga en cuenta que algunos de los comandos que se indican en dicha
referencia no están disponibles en el editor de código.
Temas
• Uso de archivos y carpetas (p. 7)
• Trabajar con código (p. 9)
• Trabajar en modo de pantalla completa (p. 12)
• Trabajar con preferencias (p. 12)
7
AWS Lambda Guía para desarrolladores
Uso de archivos y carpetas
Para mostrar u ocultar la ventana Environment, elija el botón Environment. Si la ventana Environment no
está visible, elija Window, Environment en la barra de menús.
Para abrir un único archivo y mostrar su contenido en el panel de edición, haga doble clic en el archivo en
la ventana Environment.
Para abrir varios archivos y mostrar su contenido en el panel de edición, elija los archivos en la ventana
Environment. Haga clic con el botón derecho en la selección y elija Open.
• En la ventana Environment, haga clic con el botón derecho en la carpeta en la que desee almacenar
el nuevo archivo y, a continuación, elija New File. Escriba el nombre y la extensión del archivo y, a
continuación, pulse Enter.
• Elija File, New File en la barra de menús. Cuando esté listo para guardar el archivo, elija File, Save o
File, Save As en la barra de menús. A continuación, use el cuadro de diálogo Save As que aparece para
asignar un nombre al archivo y elegir dónde debe almacenarse.
• En la barra de botones de la pestaña del panel de edición, elija el botón + y, a continuación, elija New
File. Cuando esté listo para guardar el archivo, elija File, Save o File, Save As en la barra de menús. A
continuación, use el cuadro de diálogo Save As que aparece para asignar un nombre al archivo y elegir
dónde debe almacenarse.
8
AWS Lambda Guía para desarrolladores
Trabajar con código
Para crear una nueva carpeta, haga clic con el botón derecho en la carpeta en la ventana Environment
donde desee almacenar la nueva carpeta y, a continuación, elija New Folder. Escriba el nombre de la
carpeta y pulse Enter.
Para guardar un archivo, con el archivo abierto y su contenido visible en el panel de edición, seleccione
File, Save en la barra de menús.
Para cambiar el nombre de un archivo o carpeta, haga clic con el botón derecho en el archivo o carpeta en
la ventana Environment. Escriba el nuevo nombre y pulse Enter.
Para eliminar archivos o carpetas, seleccione los archivos o carpetas en la ventana Environment. Haga clic
con el botón derecho en la selección y elija Delete. A continuación, confirme la eliminación eligiendo Yes
(para una única selección) o Yes to All.
Para cortar, copiar, pegar o duplicar archivos o carpetas, seleccione los archivos o carpetas en la ventana
Environment. Haga clic con el botón derecho en la selección y, a continuación, elija Cut, Copy, Paste o
Duplicate, respectivamente.
Para contraer carpetas, elija el icono del engranaje en la ventana Environment y, a continuación, elija
Collapse All Folders.
Para mostrar u ocultar archivos, elija el icono del engranaje en la ventana Environment y, a continuación,
elija Show Hidden Files.
9
AWS Lambda Guía para desarrolladores
Trabajar con código
Para mostrar el contenido de un archivo abierto, lleve a cabo alguna de las siguientes operaciones:
Para cerrar varios archivos abiertos, elija el menú desplegable de la barra de botones de la pestaña y, a
continuación, elija Close All Tabs in All Panes o Close All But Current Tab según sea necesario.
10
AWS Lambda Guía para desarrolladores
Trabajar con código
Para crear un nuevo archivo, elija el botón + de la barra de botones de la pestaña y, a continuación, elija
New File. Cuando esté listo para guardar el archivo, elija File, Save o File, Save As en la barra de menús.
A continuación, use el cuadro de diálogo Save As que aparece para asignar un nombre al archivo y elegir
dónde debe almacenarse.
Para moverse rápidamente a una línea del archivo activo, elija el selector de líneas, escriba el número de
línea al que desea ir y, a continuación, pulse Enter.
Para cambiar el esquema de color del código en el archivo activo, elija el selector de esquemas de color
del código y, a continuación, elija el nuevo código esquema de color.
Para cambiar en el archivo activo si se utilizan tabuladores o espacios suaves, el tamaño del tabulador o si
desea convertir espacios en tabuladores, elija el selector de espacios y tabuladores y, a continuación, elija
la nueva configuración.
11
AWS Lambda Guía para desarrolladores
Trabajar en modo de pantalla completa
Para cambiar si se muestran u ocultan los caracteres invisibles o el margen interno, el emparejamiento
automático de corchetes o comillas, el ajuste de las líneas o el tamaño de la fuente para todos los archivos,
elija el icono de engranaje y, a continuación, elija la nueva configuración.
Para ampliar el editor de código hasta los bordes de la ventana del navegador web, seleccione el botón
Toggle fullscreen en la barra de menús.
Para restablecer el editor de código a su tamaño original, seleccione de nuevo el botón Toggle fullscreen.
En modo de pantalla completa, se muestran opciones adicionales en la barra de menús: Save (Guardar) y
Test (Prueba). Elija Save para guardar el código de la función. Elija Test o Configure Events para crear o
editar los eventos de prueba de la función.
12
AWS Lambda Guía para desarrolladores
AWS CLI
Para cambiar la configuración del editor de código, elija el icono de engranaje Preferences de la barra de
menús.
Para obtener una lista de lo que hacen las opciones, consulte las siguientes referencias en la Guía del
usuario de AWS Cloud9.
Tenga en cuenta que algunas de las opciones que se indican en estas referencias no están disponibles en
el editor de código.
Requisitos previos
En este tutorial, se le presuponen algunos conocimientos sobre las operaciones básicas de Lambda y la
consola de Lambda. Si aún no lo ha hecho, siga las instrucciones que se indican en Introducción a AWS
Lambda (p. 3) para crear la primera función de Lambda.
Para seguir los procedimientos de esta guía, necesitará un shell o un terminal de línea de comando donde
pueda ejecutar los comandos. Los comandos aparecen en listas y van precedidos del símbolo del sistema
($) y del nombre del directorio actual, si es aplicable:
Para los comandos largos, se utiliza un carácter de escape (\) para dividir un comando en varias líneas.
En Linux y macOS, use su administrador de shell y paquetes preferido. En Windows 10, puede instalar
Windows Subsystem para Linux para obtener una versión de Ubuntu y Bash integrada con Windows.
Este tutorial utiliza la AWS Command Line Interface (AWS CLI) para llamar a las operaciones de la API
de servicio. Para instalar la AWS CLI, consulte Instalación de la CLI de AWS en la AWS Command Line
Interface Guía del usuario.
13
AWS Lambda Guía para desarrolladores
Creación del rol de ejecución
Example trust-policy.json
{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Principal": {
"Service": "lambda.amazonaws.com"
},
"Action": "sts:AssumeRole"
}
]
}
También puede especificar la política de confianza insertada. Los requisitos de las cuotas de escape en la
cadena JSON varía según el shell.
Para añadir permisos al rol, use el comando attach-policy-to-role. Empiece añadiendo la política
administrada AWSLambdaBasicExecutionRole.
14
AWS Lambda Guía para desarrolladores
Creación de la función
Creación de la función
En el siguiente ejemplo, se registran los valores de las variables de entorno y el objeto de evento.
Example index.js
3. Cree una función de Lambda con el comando create-function. Reemplace el texto resaltado en el
ARN de rol por su ID de cuenta.
Para obtener los registros de una invocación desde la línea de comandos, utilice la opción --log-type.
La respuesta incluye un campo LogResult que contiene hasta 4 KB de registros con codificación base64
a partir de la invocación.
15
AWS Lambda Guía para desarrolladores
Creación de la función
La utilidad base64 está disponible en Linux, MacOS y Ubuntu en Windows. Para el sistema operativo
macOS, el comando es base64 -D.
Para obtener eventos de registro completos desde la línea de comandos, puede incluir el nombre del
flujo de registros en la salida de la función, como se muestra en el ejemplo anterior. El siguiente script de
ejemplo invoca una función denominada my-function y descarga los últimos cinco eventos de registro.
#!/bin/bash
aws lambda invoke --function-name my-function --payload '{"key": "value"}' out
sed -i'' -e 's/"//g' out
sleep 15
aws logs get-log-events --log-group-name /aws/lambda/my-function --log-stream-name $(cat
out) --limit 5
El script utiliza sed para eliminar las comillas del archivo de salida y permanece inactivo durante
15 segundos para dar tiempo a que los registros estén disponibles. La salida incluye la respuesta de
Lambda y la salida del comando get-log-events.
$ ./get-logs.sh
{
"StatusCode": 200,
"ExecutedVersion": "$LATEST"
}
{
"events": [
{
"timestamp": 1559763003171,
"message": "START RequestId: 4ce9340a-b765-490f-ad8a-02ab3415e2bf Version:
$LATEST\n",
"ingestionTime": 1559763003309
},
{
"timestamp": 1559763003173,
"message": "2019-06-05T19:30:03.173Z\t4ce9340a-b765-490f-ad8a-02ab3415e2bf
\tINFO\tENVIRONMENT VARIABLES\r{\r \"AWS_LAMBDA_FUNCTION_VERSION\": \"$LATEST\",\r ...",
"ingestionTime": 1559763018353
},
{
"timestamp": 1559763003173,
"message": "2019-06-05T19:30:03.173Z\t4ce9340a-b765-490f-ad8a-02ab3415e2bf
\tINFO\tEVENT\r{\r \"key\": \"value\"\r}\n",
"ingestionTime": 1559763018353
},
{
"timestamp": 1559763003218,
"message": "END RequestId: 4ce9340a-b765-490f-ad8a-02ab3415e2bf\n",
"ingestionTime": 1559763018353
},
{
"timestamp": 1559763003218,
"message": "REPORT RequestId: 4ce9340a-b765-490f-ad8a-02ab3415e2bf\tDuration:
26.73 ms\tBilled Duration: 100 ms \tMemory Size: 128 MB\tMax Memory Used: 75 MB\t\n",
16
AWS Lambda Guía para desarrolladores
Listado de las funciones Lambda de su cuenta
"ingestionTime": 1559763018353
}
],
"nextForwardToken": "f/34783877304859518393868359594929986069206639495374241795",
"nextBackwardToken": "b/34783877303811383369537420289090800615709599058929582080"
}
Como respuesta, Lambda devuelve una lista de hasta 10 funciones. Si hay más funciones, NextToken
proporciona un marcador que puede utilizar en la siguiente solicitud list-functions. El siguiente
comando list-functions de la AWS CLI es un ejemplo de uso del parámetro --starting-token.
17
AWS Lambda Guía para desarrolladores
Eliminar recursos
},
"RevisionId": "88ebe1e1-bfdf-4dc3-84de-3017268fa1ff",
...
},
"Code": {
"RepositoryType": "S3",
"Location": "https://awslambda-us-east-2-tasks.s3.us-east-2.amazonaws.com/
snapshots/123456789012/my-function-4203078a-b7c9-4f35-..."
}
}
Eliminar recursos
Ejecute el siguiente comando delete-function para eliminar la función my-function.
Borre el rol de IAM que creó en la consola de IAM. Para obtener información acerca de cómo eliminar un
rol, consulte Eliminación de roles o perfiles de instancia en la Guía del usuario de IAM.
Conceptos
• Función (p. 18)
• Qualifier (p. 18)
• Tiempo de ejecución (p. 19)
• Evento (p. 19)
• Simultaneidad (p. 19)
• Trigger (p. 20)
Función
Una función es un recurso que puede invocar para ejecutar el código en AWS Lambda. Una función
tiene código que procesa eventos y un elemento de tiempo de ejecución que transfiere las solicitudes y
las respuestas entre Lambda y el código de la función. Debe proporcionar el código y puede utilizar los
runtimes proporcionados o crear los suyos propios.
Para obtener más información, consulte Administración de funciones de AWS Lambda (p. 53).
Qualifier
Al invocar o ver una función, puede incluir un calificador para especificar una versión o alias. Una versión
es una instantánea inmutable del código y la configuración de una función que tiene un calificador
numérico. Por ejemplo, my-function:1. Un alias dirige a una versión que se puede actualizar para
asignar a una versión diferente o dividir el tráfico entre dos versiones. Por ejemplo, my-function:BLUE.
18
AWS Lambda Guía para desarrolladores
Tiempo de ejecución
Puede usar versiones y alias al mismo tiempo para proporcionar una interfaz estable para que los clientes
invoquen su función.
Para obtener más información, consulte Versiones de funciones de AWS Lambda (p. 70).
Tiempo de ejecución
Los runtimes de Lambda permiten la ejecución de funciones en distintos lenguajes en el mismo entorno
de ejecución básico. Puede configurar la función para utilizar un tiempo de ejecución que se ajuste a su
lenguaje de programación. El runtime se encuentra entre el servicio Lambda y el código de su función,
y retransmite eventos de invocación, información de contexto y respuestas entre los dos. Puede utilizar
tiempos de ejecución proporcionados por Lambda, o bien crear los suyos propios.
Para obtener más información, consulte Tiempos de ejecución de AWS Lambda. (p. 130).
Evento
Un evento es un documento con formato JSON que contiene datos para que una función los procese. El
tiempo de ejecución de Lambda convierte el evento en un objeto y lo pasa al código de la función. Cuando
se invoca una función, se determina la estructura y el contenido del evento.
{
"TemperatureK": 281,
"WindKmh": -3,
"HumidityPct": 0.55,
"PressureHPa": 1020
}
Cuando un servicio de AWS invoca una función, el servicio define la forma del evento.
{
"Records": [
{
"Sns": {
"Timestamp": "2019-01-02T12:45:07.000Z",
"Signature": "tcc6faL2yUC6dgZdmrwh1Y4cGa/ebXEkAi6RibDsvpi+tE/1+82j...65r==",
"MessageId": "95df01b4-ee98-5cb9-9903-4c221d41eb5e",
"Message": "Hello from SNS!",
...
Para obtener más información sobre los eventos de los servicios de AWS, consulte Utilización de AWS
Lambda con otros servicios (p. 163).
Simultaneidad
La simultaneidad es el número de solicitudes que la función atiende en un momento dado. Cuando se
invoca la función, Lambda aprovisiona una instancia para procesar el evento. Cuando el código de la
función termina de ejecutarse, puede encargarse de otra solicitud. Si la función se invoca de nuevo
mientras se sigue procesando una solicitud, se aprovisiona otra instancia, lo que aumenta la simultaneidad
de la función.
La simultaneidad está sujeta a cuotas en el nivel de región. También puede configurar funciones
individuales para limitar su simultaneidad o para garantizar que puedan alcanzar un nivel específico de
19
AWS Lambda Guía para desarrolladores
Trigger
simultaneidad. Para obtener más información, consulte Administración de la simultaneidad para una
función de Lambda (p. 62).
Trigger
Un desencadenador es un recurso o configuración que invoca una función Lambda. Entre estos se
incluyen servicios de AWS que se hayan configurado para invocar una función, aplicaciones que usted
desarrolle y mapeos de orígenes de eventos. Un mapeo de origen de eventos es un recurso de Lambda
que lee elementos de un flujo o una cola e invoca una función.
Para obtener más información, consulte Invocación de funciones de AWS Lambda (p. 99) y Utilización
de AWS Lambda con otros servicios (p. 163).
Características
• Modelo de programación (p. 20)
• Paquete de implementación (p. 22)
• Capas (p. 22)
• Escalado (p. 22)
• Controles de simultaneidad (p. 23)
• Invocación asincrónica (p. 25)
• Mapeos de origen de eventos (p. 26)
• Destinos (p. 27)
• Proyectos de funciones (p. 28)
• Plantillas de aplicaciones (p. 29)
Modelo de programación
Los detalles del proceso de creación varían de unos tiempos de ejecución a otros, pero todos comparten
un modelo de programación común que define la interfaz entre el código y el código de tiempo
de ejecución. Puede indicar al runtime qué método debe ejecutar definiendo un controlador en la
configuración de la función; el runtime ejecutará dicho método. El runtime se pasa en forma de objetos al
controlador que contiene el evento de invocación y el contexto, como el nombre de la función y el ID de la
solicitud.
Cuando el controlador termina de procesar el primer evento, el runtime le envía otro. La clase de la
función permanece en la memoria, por lo que se pueden reutilizar los clientes y las variables declarados
fuera del método del controlador en código de inicialización. Para ahorrar tiempo de procesamiento en
eventos posteriores, cree recursos reutilizables como clientes AWS SDK durante la inicialización. Una vez
inicializada, cada instancia de su función puede procesar miles de solicitudes.
La inicialización se factura como parte de la duración de la primera invocación procesada por una instancia
de su función. Cuando se habilita el seguimiento de X-Ray (p. 311), el tiempo de ejecución registra
subsegmentos separados para la inicialización y la ejecución.
20
AWS Lambda Guía para desarrolladores
Modelo de programación
La función también tiene acceso al almacenamiento local en el directorio /tmp. Las instancias de su
función que están atendiendo solicitudes permanecen activas durante unas horas antes de reciclarse.
El runtime captura la salida de registro de la función y la envía a Amazon CloudWatch Logs. Además de
registrar la salida de su función, el tiempo de ejecución también registra las entradas cuando se inicia y
finaliza la ejecución. Esto incluye un registro de informe con el ID de solicitud, la duración facturada, la
duración de inicialización y otros detalles. Si la función genera un error, el runtime devuelve ese error al
invocador.
Note
El registro está sujeto a los límites de CloudWatch Logs. Los datos de registro se pueden perder
debido a una limitación controlada o, en algunos casos, cuando se detiene una instancia de su
función.
Para obtener una introducción práctica sobre estos conceptos en su lenguaje de programación preferido,
consulte los siguientes capítulos.
Lambda escala la función ejecutando instancias adicionales a medida que aumenta la demanda y
deteniendo instancias a medida que disminuye la demanda. A menos que se indique lo contrario, las
21
AWS Lambda Guía para desarrolladores
Paquete de implementación
Paquete de implementación
El código de la función se compone de scripts o programas compilados y sus dependencias. Al crear
funciones en la consola de Lambda o con un conjunto de herramientas, el cliente crea un archivo ZIP del
código denominado “paquete de implementación”. A continuación, el cliente envía el paquete al servicio
Lambda. Al administrar funciones con la API de Lambda, con las herramientas de línea de comandos
o con los SDK, debe crear el paquete de implementación. También es necesario crear un paquete de
implementación manualmente para lenguajes compilados y para añadir dependencias a la función.
Si desea obtener instrucciones específicas del lenguaje, consulte los temas siguientes.
Capas
Las capas de Lambda son un mecanismo de distribución para bibliotecas, runtimes personalizados y otras
dependencias de la función. Las capas le permiten administrar su código de función en desarrollo con
independencia del código invariable y los recursos que utiliza. Puede configurar la función para utilizar las
capas que cree, las capas que proporciona AWS, o las capas de otros clientes de AWS.
Para obtener más información, consulte Capas de AWS Lambda (p. 76).
Escalado
Lambda administra la infraestructura que ejecuta el código, escalándola automáticamente en respuesta a
las solicitudes entrantes. Cuando la función se invoca a mayor velocidad de la que una sola instancia de su
función puede procesar eventos, Lambda amplía la capacidad ejecutando instancias adicionales. Cuando
el tráfico disminuye, las instancias inactivas se bloquean o detienen. Solo paga por el tiempo que la función
inicia o procesa eventos.
22
AWS Lambda Guía para desarrolladores
Controles de simultaneidad
Para obtener más información, consulte Escalado de funciones de AWS Lambda (p. 114).
Controles de simultaneidad
Utilice la configuración de simultaneidad para asegurarse de que sus aplicaciones de producción tengan
alta disponibilidad y capacidad de respuesta. Para evitar que una función utilice demasiada simultaneidad
y para reservar una parte de la simultaneidad disponible de su cuenta para una función, utilice la
simultaneidad reservada. La simultaneidad reservada divide el grupo de simultaneidad disponible en
subconjuntos. Una función con simultaneidad reservada solo usa simultaneidad desde su grupo dedicado.
23
AWS Lambda Guía para desarrolladores
Controles de simultaneidad
Para permitir a las funciones que se escalen sin fluctuaciones en la latencia, utilice la simultaneidad
aprovisionada. Para las funciones que tardan mucho tiempo en inicializarse o que requieren latencia
extremadamente baja para todas las invocaciones, la concurrencia aprovisionada le permite preinicializar
instancias de su función y mantenerlas ejecutándose en todo momento. Lambda se integra con Auto
Scaling de aplicaciones para admitir el escalado automático para simultaneidad aprovisionada basada en
la utilización.
24
AWS Lambda Guía para desarrolladores
Invocación asincrónica
Para obtener más información, consulte Administración de la simultaneidad para una función de
Lambda (p. 62).
Invocación asincrónica
Al invocar una función, puede optar por invocarla de forma síncrona o asíncrona. Con invocación
síncrona (p. 100), espere la función para procesar el evento y devolver una respuesta. Con
invocación asíncrona, Lambda pone en cola el evento para su procesamiento y devuelve una respuesta
inmediatamente.
25
AWS Lambda Guía para desarrolladores
Mapeos de origen de eventos
Para las invocaciones asíncronas, Lambda maneja reintentos si la función devuelve un error o está
limitada. Para personalizar este comportamiento, puede configurar las opciones de gestión de errores en
una función, versión o alias. También puede configurar Lambda para que envíe eventos que hayan fallado
en el procesamiento a una cola de mensajes fallidos o para que envíe un registro de cualquier invocación a
un destino (p. 27).
26
AWS Lambda Guía para desarrolladores
Destinos
Los mapeos de origen de eventos mantienen una cola local de elementos no procesados y manejan los
reintentos si la función devuelve un error o está limitada. Puede configurar un mapeo de origen de eventos
para personalizar el comportamiento de lotes y el control de errores, o para enviar un registro de elementos
que no se han podido procesar a un destino (p. 27).
Para obtener más información, consulte Mapeos de origen de eventos de AWS Lambda (p. 109).
Destinos
Un destino es un recurso de AWS que recibe registros de invocación para una función. Para invocación
asíncrona (p. 25), puede configurar Lambda para que envíe registros de invocación a una cola, un
tema, una función o un bus de eventos. Puede configurar destinos separados para las invocaciones
exitosas y los eventos que no se procesaron correctamente. El registro de invocación contiene detalles
sobre el evento, la respuesta de la función y el motivo por el que se ha enviado el registro.
27
AWS Lambda Guía para desarrolladores
Proyectos de funciones
Para los mapeos de origen de eventos (p. 26) que leen desde secuencias, puede configurar Lambda
para que envíe un registro de lotes que no se han procesado correctamente a una cola o tema. Un registro
de error para un mapeo de origen de evento contiene metadatos sobre el lote y apunta a los elementos de
la secuencia.
Para obtener más información, consulte Configuración de destinos para invocación asincrónica (p. 104) y
las secciones de control de errores de Uso de AWS Lambda con Amazon DynamoDB (p. 216) y Uso de
AWS Lambda con Amazon Kinesis (p. 250).
Proyectos de funciones
Al crear una función en la consola de Lambda, puede optar por comenzar desde cero, utilizar un proyecto
o implementar una aplicación desde el AWS Serverless Application Repository. Un proyecto proporciona
código de muestra que indica cómo usar Lambda con un servicio de AWS o una aplicación de terceros
popular. Los proyectos incluyen preajustes de configuración de código de muestra y funciones para los
tiempos de ejecución de Node.js y Python.
28
AWS Lambda Guía para desarrolladores
Plantillas de aplicaciones
Los proyectos se proporcionan para su uso bajo la licencia Creative Commons Zero . Solo están
disponibles en la consola de Lambda.
Plantillas de aplicaciones
Puede utilizar la consola de Lambda para crear una aplicación con una canalización de entrega continua.
Las plantillas de aplicación de la consola de Lambda incluyen código para una o varias funciones,
una plantilla de aplicación que define funciones y recursos de AWS compatibles y una plantilla de
infraestructura que define una canalización de AWS CodePipeline. La canalización tiene etapas de
compilación e implementación que se ejecutan cada vez que inserta cambios en el repositorio Git incluido.
Las plantillas de aplicación se proporcionan para su uso bajo la licencia MIT sin atribución . Solo están
disponibles en la consola de Lambda.
Para obtener más información, consulte Creación de una aplicación con entrega continua en la consola de
Lambda (p. 147).
Herramientas
• AWS Command Line Interface (p. 29)
• Modelo de aplicación sin servidor de AWS (p. 29)
• CLI de SAM (p. 30)
• Herramientas para crear código (p. 30)
Para configurar la AWS CLI, consulte los siguientes temas en la AWS Command Line Interface Guía del
usuario.
Para verificar que la AWS CLI está configurada correctamente, ejecute el comando list-functions
para ver una lista de las funciones Lambda en la región actual.
29
AWS Lambda Guía para desarrolladores
CLI de SAM
Para obtener más información acerca de las plantillas de AWS SAM, consulte Aspectos básicos sobre las
plantillas de AWS SAM en la Guía para desarrolladores de Modelo de aplicación sin servidor de AWS.
CLI de SAM
La CLI de AWS SAM es una herramienta de línea de comandos independiente que puede utilizar para
administrar y probar aplicaciones de AWS SAM. Además de los comandos para cargar artefactos y lanzar
pilas de AWS CloudFormation que también están disponibles en la AWS CLI, la CLI de SAM proporciona
comandos adicionales para validar plantillas y ejecutar aplicaciones de forma local en un contenedor de
Docker.
Para configurar la CLI de AWS SAM, consulte Instalación de la CLI de AWS SAM en la Guía para
desarrolladores de Modelo de aplicación sin servidor de AWS.
En la siguiente tabla se muestran los lenguajes y las herramientas y opciones disponibles que puede
utilizar.
30
AWS Lambda Guía para desarrolladores
Cuotas
Para más información sobre simultaneidad y cómo Lambda amplía la simultaneidad de funciones en
respuesta al tráfico, consulte Escalado de funciones de AWS Lambda (p. 114).
Recurso Cuota
Asignación de memoria de función (p. 54) Desde 128 MB hasta 3,008 MB, en
incrementos de 64 MB.
Frecuencia de invocación por región (solicitudes por segundo) Cuota de ejecuciones simultáneas
10 veces mayor (síncrona (p. 100) –
todos los orígenes)
31
AWS Lambda Guía para desarrolladores
Cuotas
Recurso Cuota
256 KB (asincrónica)
3 MB (editor de consola)
Las cuotas para otros servicios, como AWS Identity and Access Management, Amazon CloudFront
(Lambda@Edge) y Amazon Virtual Private Cloud, pueden repercutir en sus funciones Lambda. Para
obtener más información, consulte Cuotas de servicio de AWS y Utilización de AWS Lambda con otros
servicios (p. 163).
32
AWS Lambda Guía para desarrolladores
Rol de ejecución
Una función de Lambda también tiene una política, que se denomina rol de ejecución (p. 33), que la
concede permiso para tener acceso a los servicios y recursos de AWS. Como mínimo, la función necesita
tener acceso a Amazon CloudWatch Logs para el streaming de registros. Si utiliza AWS X-Ray para
rastrear la función (p. 311), o la función tiene acceso a los servicios con el SDK de AWS, debe conceder
permiso a la función para llamarlos mediante el rol de ejecución. Lambda también utiliza el rol de ejecución
para obtener permiso para leer desde orígenes de eventos cuando se utiliza un mapeo de origen de
eventos (p. 109) para activar la función.
Note
Si la función necesita acceso de red a un recurso como una base de datos relacional a la que no
se tiene acceso a través de las API de AWS o de Internet, configúrela para que se conecte a la
VPC (p. 81).
Utilice las políticas basadas en recursos (p. 37) para conceder a otras cuentas y otros servicios de AWS
permiso para utilizar los recursos de Lambda. Los recursos de Lambda incluyen funciones, versiones, alias
y versiones de las capas. Cada uno de estos recursos tiene una política de permisos que se aplica cuando
se obtiene acceso al recurso, además de las políticas que se aplican al usuario. Cuando un servicio de
AWS como Amazon S3 llama a una función de Lambda, la política basada en recursos le concede acceso.
Para administrar los permisos de los usuarios y las aplicaciones en sus cuentas, utilice las políticas
administradas que proporciona Lambda (p. 42) o cree las suyas propias. La consola de Lambda utiliza
múltiples servicios para obtener información sobre la configuración y los desencadenadores de la función.
Puede utilizar las políticas administradas tal como están, o como punto de partida para políticas más
restrictivas.
Puede restringir los permisos de usuario por el recurso al que afecta una acción y, en algunos casos,
por condiciones adicionales. Por ejemplo, puede especificar un patrón para el nombre de recurso
de Amazon (ARN) de una función que requiera que el usuario incluya su nombre de usuario en el
nombre de las funciones que cree. Además, puede añadir una condición que requiera que el usuario
configure las funciones para que utilicen una capa específica, por ejemplo, para incluir software de
registro. Para conocer los recursos y las condiciones compatibles con cada acción, consulte Recursos y
condiciones (p. 47).
Para obtener más información acerca de IAM, consulte ¿Qué es IAM? en la Guía del usuario de IAM.
Temas
• Rol de ejecución de AWS Lambda (p. 33)
• Uso de políticas basadas en recursos para AWS Lambda (p. 37)
• Políticas de IAM basadas en identidad para AWS Lambda (p. 42)
• Recursos y condiciones para acciones de Lambda (p. 47)
• Uso de límites de permisos para aplicaciones de AWS Lambda (p. 50)
33
AWS Lambda Guía para desarrolladores
Rol de ejecución
cuando se invoca la función. Puede crear un rol de ejecución para tareas de desarrollo que tenga permiso
para enviar registros a Amazon CloudWatch y para cargar datos de rastreo en AWS X-Ray.
5. Elija un servicio en el menú desplegable para ver los permisos relacionados con ese servicio.
Puede añadir o eliminar permisos del rol de ejecución de una función en cualquier momento, o configurar
la función para que utilice otro rol. Añada permisos para los servicios a los que llame la función con el SDK
de AWS y para los servicios que Lambda utilice para habilitar características opcionales.
Cuando añade permisos a su función, actualice también su código o configuración. Esto obliga a las
instancias en ejecución de su función, cuyas credenciales han expirado, a detenerse y ser sustituidas.
34
AWS Lambda Guía para desarrolladores
Creación de un rol de ejecución en la consola de IAM
Para obtener instrucciones detalladas, consulte Creación de un rol en la Guía del usuario de IAM.
35
AWS Lambda Guía para desarrolladores
Políticas administradas para características de Lambda
Example trust-policy.json
{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Principal": {
"Service": "lambda.amazonaws.com"
},
"Action": "sts:AssumeRole"
}
]
}
También puede especificar la política de confianza insertada. Los requisitos de las cuotas de escape en la
cadena JSON varía según el shell.
Para añadir permisos al rol, use el comando attach-policy-to-role. Empiece añadiendo la política
administrada AWSLambdaBasicExecutionRole.
Para algunas características, la consola de Lambda intenta agregar permisos que faltan a su rol de
ejecución en una política administrada por el cliente. Estas políticas pueden llegar a ser numerosas. Añada
las políticas administradas pertinentes a su rol de ejecución antes de habilitar las funciones para evitar
crear políticas adicionales.
Cuando se utiliza un mapeo de origen de eventos (p. 109) para invocar la función, Lambda utiliza el rol
de ejecución para leer los datos de los eventos. Por ejemplo, un mapeo de origen de eventos para Amazon
Kinesis lee los eventos de un flujo de datos y se los envía a la función por lotes. Es posible utilizar los
mapeos de orígenes de eventos con los siguientes servicios:
36
AWS Lambda Guía para desarrolladores
Políticas basadas en recursos
Además de las políticas administradas, la consola de Lambda proporciona plantillas para crear una política
personalizada que tiene los permisos relacionados con otros casos de uso. Cuando crea una función en
la consola de Lambda, puede elegir crear un nuevo rol de ejecución con permisos a partir de una o más
plantillas. Estas plantillas también se aplican automáticamente cuando se crea una función a partir de un
proyecto o cuando se configuran opciones que requieren acceso a otros servicios. Existen plantillas de
ejemplo en el repositorio de GitHub de esta guía.
Para las funciones de Lambda, puede conceder a una cuenta permiso (p. 39) para invocar o administrar
una función. Puede añadir varias instrucciones para conceder acceso a varias cuentas, o permitir que
cualquier cuenta invoque la función. Para las funciones que otro servicio de AWS invoca como respuesta a
la actividad de su cuenta, utilice la política para conceder permiso de invocación al servicio (p. 39).
37
AWS Lambda Guía para desarrolladores
Políticas basadas en recursos
Para las capas de Lambda, utilice una política basada en recursos en una versión de la capa para permitir
que otras cuentas la utilicen. Además de las políticas que conceden permisos a una única cuenta o a todas
las cuentas, para las capas, también puede conceder permisos a todas las cuentas de una organización.
Note
Solo puede actualizar directivas basadas en recursos para recursos de Lambda en el ámbito
de las acciones API AddPermission (p. 509) y AddLayerVersionPermission (p. 506). No
puede crear políticas para los recursos de Lambda en JSON ni utilizar condiciones que no se
correspondan con los parámetros de estas acciones.
Las políticas basadas en recursos se aplican a una sola función, versión, alias o versión de capa.
Conceden permiso para uno o varios servicios y cuentas. Para las cuentas de confianza que desea
que tengan acceso a varios recursos, o para utilizar las acciones de la API que las políticas basadas en
recursos no admiten, puede utilizar roles entre cuentas (p. 42).
Temas
• Concesión de acceso a las funciones a los servicios de AWS (p. 39)
• Concesión de acceso a las funciones a otras cuentas (p. 39)
• Concesión de acceso a las capas a otras cuentas (p. 41)
• Limpieza de políticas basadas en recursos (p. 41)
38
AWS Lambda Guía para desarrolladores
Concesión de acceso a las funciones a los servicios de AWS
Añada una instrucción con el comando add-permission. La instrucción más sencilla de una política
basada en recursos permite un servicio invocar una función. El comando siguiente concede permiso a
Amazon SNS para invocar una función denominada my-function.
Esto permite a Amazon SNS invocar la función, pero no restringe el tema de Amazon SNS que activa la
invocación. Para asegurarse de que la función solo la invocada un recurso determinado, especifique el
nombre de recurso de Amazon (ARN) del recurso con la opción source-arn. El siguiente comando solo
permite a Amazon SNS invocar la función para las suscripciones a un tema denominado my-topic.
Algunos servicios pueden invocar funciones de otras cuentas. Esto no es un problema cuando se
especifica un ARN de origen que incluye el ID de la cuenta. Sin embargo, para Amazon S3, el origen es un
bucket cuyo ARN no incluye el ID de la cuenta. Es posible que usted elimine el bucket y que otra cuenta
cree un bucket con el mismo nombre. Utilice la opción account-id para garantizar que solo los recursos
de su cuenta pueden invocar la función.
39
AWS Lambda Guía para desarrolladores
Concesión de acceso a las funciones a otras cuentas
{"Sid":"xaccount","Effect":"Allow","Principal":
{"AWS":"arn:aws:iam::210987654321:root"},"Action":"lambda:InvokeFunction","Resource":"arn:aws:lambda:us
east-2:123456789012:function:my-function"}
La política basada en recursos concede permiso a la otra cuenta para obtener acceso a la función, pero no
permite a los usuarios de esa cuenta superar sus permisos. Los usuarios de la otra cuenta deben tener los
permisos de usuario (p. 42) correspondientes para utilizar la API de Lambda.
Para limitar el acceso a un usuario, grupo o función de otra cuenta, especifique el ARN completo de la
identidad como el principal. Por ejemplo, arn:aws:iam::123456789012:user/developer.
El alias (p. 72) limita la versión que puede invocar la otra cuenta. Requiere que la otra cuenta incluya el
alias en el ARN de la función.
Esto le permite actualizar el alias para que apunte a las versiones nuevas cuando sea necesario. Cuando
actualice el alias, la otra cuenta no tiene que modificar su código para utilizar la versión nueva, y solo tiene
permiso para invocar la versión que usted elija.
Puede conceder acceso entre cuentas para la mayoría de acciones de la API que operen con una función
existente (p. 48). Por ejemplo, puede conceder acceso a lambda:ListAliases para permitir que una
cuenta obtenga una lista de alias o a lambda:GetFunction para permitirles que descarguen el código
de la función. Añada cada permiso por separado o utilice lambda:* para conceder acceso a todas las
acciones para la función especificada.
40
AWS Lambda Guía para desarrolladores
Concesión de acceso a las capas a otras cuentas
Para conceder a otras cuentas permiso para varias funciones o para realizar acciones que no operan con
una función, utilice los roles (p. 42).
Los permisos solo se aplican a una única versión de una capa. Repita el procedimiento cada vez que cree
una nueva versión de la capa.
Para conceder permiso a todas las cuentas de una organización, utilice la opción organization-id. En
el siguiente ejemplo, se concede permiso a todas las cuentas de una organización para utilizar la versión 3
de una capa.
Para conceder permiso a todas las cuentas de AWS, utilice * para la entidad principal y omita el ID de la
organización. Para varias cuentas u organizaciones, agregue varias instrucciones.
Para las versiones y los alias, añada el número de versión o el alias al nombre de la función.
Utilice el comando get-layer-version-policy para ver los permisos de una capa. Se utiliza remove-
layer-version-permission para quitar instrucciones de la política.
41
AWS Lambda Guía para desarrolladores
Políticas de usuario
Lambda proporciona políticas administradas que conceden acceso a las acciones de la API de Lambda y,
en algunos casos, a otros servicios que se utilizan para desarrollar y administrar los recursos de Lambda.
Lambda actualiza las políticas administradas según sea necesario para garantizar que los usuarios tengan
acceso a las características nuevas que se publiquen.
• AWSLambdaFullAccess: concede acceso completo a las acciones de AWS Lambda y a otros servicios
que se utilizan para desarrollar y mantener los recursos de Lambda.
• AWSLambdaReadOnlyAccess: concede acceso de solo lectura a los recursos de AWS Lambda.
• AWSLambdaRole: concede permisos para invocar funciones de Lambda.
Las políticas administradas conceden permiso a las acciones de la API sin restringir las funciones ni las
capas que un usuario puede modificar. Para conseguir un control más preciso, puede crear sus propias
políticas que limiten el ámbito de los permisos de un usuario.
Secciones
• Desarrollo de funciones (p. 42)
• Desarrollo y uso de capas (p. 45)
• Roles entre cuentas (p. 46)
• Claves de condición para la configuración de la VPC (p. 46)
Desarrollo de funciones
A continuación, se muestra un ejemplo de una política de permisos con un ámbito limitado. Permite a un
usuario crear y administrar funciones de Lambda cuyo nombre tiene un prefijo determinado (intern-) y
que están configuradas con un rol de ejecución determinado.
{
"Version": "2012-10-17",
"Statement": [
42
AWS Lambda Guía para desarrolladores
Desarrollo de funciones
{
"Sid": "ReadOnlyPermissions",
"Effect": "Allow",
"Action": [
"lambda:GetAccountSettings",
"lambda:ListFunctions",
"lambda:ListTags",
"lambda:GetEventSourceMapping",
"lambda:ListEventSourceMappings",
"iam:ListRoles"
],
"Resource": "*"
},
{
"Sid": "DevelopFunctions",
"Effect": "Allow",
"NotAction": [
"lambda:AddPermission",
"lambda:PutFunctionConcurrency"
],
"Resource": "arn:aws:lambda:*:*:function:intern-*"
},
{
"Sid": "DevelopEventSourceMappings",
"Effect": "Allow",
"Action": [
"lambda:DeleteEventSourceMapping",
"lambda:UpdateEventSourceMapping",
"lambda:CreateEventSourceMapping"
],
"Resource": "*",
"Condition": {
"StringLike": {
"lambda:FunctionArn": "arn:aws:lambda:*:*:function:intern-*"
}
}
},
{
"Sid": "PassExecutionRole",
"Effect": "Allow",
"Action": [
"iam:ListRolePolicies",
"iam:ListAttachedRolePolicies",
"iam:GetRole",
"iam:GetRolePolicy",
"iam:PassRole",
"iam:SimulatePrincipalPolicy"
],
"Resource": "arn:aws:iam::*:role/intern-lambda-execution-role"
},
{
"Sid": "ViewExecutionRolePolicies",
"Effect": "Allow",
"Action": [
"iam:GetPolicy",
"iam:GetPolicyVersion"
],
"Resource": "arn:aws:iam::aws:policy/*"
},
{
"Sid": "ViewLogs",
"Effect": "Allow",
"Action": [
"logs:*"
],
"Resource": "arn:aws:logs:*:*:log-group:/aws/lambda/intern-*"
43
AWS Lambda Guía para desarrolladores
Desarrollo de funciones
}
]
}
Los permisos de la política están organizados en instrucciones que se basan en las condiciones y los
recursos (p. 47) a los que se aplican.
"Action": [
"lambda:GetAccountSettings",
"lambda:ListFunctions",
"lambda:ListTags",
"lambda:GetEventSourceMapping",
"lambda:ListEventSourceMappings",
"iam:ListRoles"
],
"Resource": "*"
• DevelopFunctions: permite utilizar cualquier acción de Lambda que opera sobre las funciones
cuyo nombre tiene el prefijo intern-, excepto AddPermission y PutFunctionConcurrency.
AddPermission modifica la política basada en recursos (p. 37) de la función y puede afectar a
la seguridad. PutFunctionConcurrency reserva capacidad de escalado para una función y puede
restar capacidad a las otras funciones.
"NotAction": [
"lambda:AddPermission",
"lambda:PutFunctionConcurrency"
],
"Resource": "arn:aws:lambda:*:*:function:intern-*"
"Action": [
"lambda:DeleteEventSourceMapping",
"lambda:UpdateEventSourceMapping",
"lambda:CreateEventSourceMapping"
],
"Resource": "*",
"Condition": {
"StringLike": {
"lambda:FunctionArn": "arn:aws:lambda:*:*:function:intern-*"
}
}
"Action": [
"iam:ListRolePolicies",
"iam:ListAttachedRolePolicies",
"iam:GetRole",
"iam:GetRolePolicy",
44
AWS Lambda Guía para desarrolladores
Desarrollo y uso de capas
"iam:PassRole",
"iam:SimulatePrincipalPolicy"
],
"Resource": "arn:aws:iam::*:role/intern-lambda-execution-role"
• ViewExecutionRolePolicies: permite ver las políticas administradas proporcionada por AWS que
están asociadas al rol de ejecución. Esto le permite ver los permisos de la función en la consola, pero no
incluye permiso para ver las políticas creadas por otros usuarios de la cuenta.
"Action": [
"iam:GetPolicy",
"iam:GetPolicyVersion"
],
"Resource": "arn:aws:iam::aws:policy/*"
• ViewLogs: permite utilizar CloudWatch Logs para ver los registros de las funciones cuyo nombre tiene
el prefijo intern-.
"Action": [
"logs:*"
],
"Resource": "arn:aws:logs:*:*:log-group:/aws/lambda/intern-*"
Esta política permite a un usuario comenzar a utilizar Lambda sin poner en peligro los recursos de los
demás usuarios. No permite a un usuario configurar una función que llame a otros servicios de AWS o
que se active desde ellos. Esto requiere permisos de IAM más amplios. Tampoco incluye permiso para
los servicios que no admiten políticas de ámbito limitado, como CloudWatch y X-Ray. Utilice las políticas
de solo lectura para estos servicios con objeto de dar a los usuarios acceso a las métricas y los datos de
rastreo.
Al configurar desencadenadores para una función, necesita acceso para utilizar el servicio de AWS que
invoca la función. Por ejemplo, para configurar un desencadenador de Amazon S3, necesita permiso para
las acciones de Amazon S3 que permiten administrar notificaciones de buckets. Muchos de estos permisos
están incluidos en la política administrada AWSLambdaFullAccess. Existen políticas de ejemplo en el
repositorio de GitHub de esta guía.
{
"Version": "2012-10-17",
"Statement": [
{
"Sid": "PublishLayers",
"Effect": "Allow",
"Action": [
"lambda:PublishLayerVersion"
],
"Resource": "arn:aws:lambda:*:*:layer:test-*"
},
{
45
AWS Lambda Guía para desarrolladores
Roles entre cuentas
"Sid": "ManageLayerVersions",
"Effect": "Allow",
"Action": [
"lambda:GetLayerVersion",
"lambda:DeleteLayerVersion"
],
"Resource": "arn:aws:lambda:*:*:layer:test-*:*"
}
]
}
También puede hacer obligatorio el uso de capas durante la creación y configuración de funciones con
la condición lambda:Layer. Por ejemplo, puede impedir que los usuarios utilicen capas publicados
por otras cuentas. La siguiente política añade una condición a las acciones CreateFunction y
UpdateFunctionConfiguration para exigir que las capas especificadas procedan de la cuenta
123456789012.
{
"Version": "2012-10-17",
"Statement": [
{
"Sid": "ConfigureFunctions",
"Effect": "Allow",
"Action": [
"lambda:CreateFunction",
"lambda:UpdateFunctionConfiguration"
],
"Resource": "*",
"Condition": {
"ForAllValues:StringLike": {
"lambda:Layer": [
"arn:aws:lambda:*:123456789012:layer:*:*"
]
}
}
}
]
}
Para asegurarse de que se aplica la condición, compruebe que ninguna otra instrucción conceda al usuario
permiso para estas acciones.
Puede utilizar roles entre cuentas para conceder acceso a las acciones y los recursos de Lambda a las
cuentas en las que confía. Si solo desea conceder permiso para invocar una función o utilizar una capa,
utilice las políticas basadas en recursos (p. 37) en su lugar.
Para obtener más información, consulte Roles de IAM en la Guía del usuario de IAM.
46
AWS Lambda Guía para desarrolladores
Recursos y condiciones
la organización estén conectadas a una VPC. También puede especificar las subredes y los grupos de
seguridad que las funciones pueden utilizar o a los que se les deniega el uso.
Para obtener más información, consulte the section called “Uso de claves de condición de IAM para la
configuración de la VPC” (p. 83).
Cada instrucción de una política de IAM concede permiso para realizar una acción en un recurso. Cuando
la acción no actúa sobre un recurso designado, o cuando se concede permiso para realizar la acción
en todos los recursos, el valor del recurso en la política es un comodín (*). Para muchas acciones de
API, puede restringir los recursos que un usuario puede modificar si especifica el nombre de recurso de
Amazon (ARN) de un recurso o un patrón de ARN que coincida con varios recursos.
Para restringir los permisos por recurso, especifique el recurso por ARN.
• Función: arn:aws:lambda:us-west-2:123456789012:function:my-function
• Versión de la función: – arn:aws:lambda:us-west-2:123456789012:function:my-function:1
• Alias de función: arn:aws:lambda:us-west-2:123456789012:function:my-function:TEST
• Mapeo de origen de eventos: arn:aws:lambda:us-west-2:123456789012:event-source-
mapping:fa123456-14a1-4fd2-9fec-83de64ad683de6d47
• Capa: arn:aws:lambda:us-west-2:123456789012:layer:my-layer
• Versión de la capa: arn:aws:lambda:us-west-2:123456789012:layer:my-layer:1
Por ejemplo, la siguiente política permite que un usuario de la cuenta 123456789012 invoque una función
denominada my-function en la región EE.UU. Oeste (Oregón).
{
"Version": "2012-10-17",
"Statement": [
{
"Sid": "Invoke",
"Effect": "Allow",
"Action": [
"lambda:InvokeFunction"
],
"Resource": "arn:aws:lambda:us-west-2:123456789012:function:my-function"
}
]
}
Las condiciones son un elemento opcional de la política que aplica lógica adicional para determinar si
se permite o no una acción. Además de las condiciones comunes compatibles con todas las acciones,
47
AWS Lambda Guía para desarrolladores
Funciones
Lambda define tipos de condición que puede utilizar para restringir los valores de parámetros adicionales
en algunas acciones.
Por ejemplo, la condición lambda:Principal le permite restringir el servicio o la cuenta a los que
un usuario puede conceder acceso de invocación en la política basada en recursos de una función. La
siguiente política permite a un usuario conceder permiso para que los temas de SNS invoquen una función
denominada test.
{
"Version": "2012-10-17",
"Statement": [
{
"Sid": "ManageFunctionPolicy",
"Effect": "Allow",
"Action": [
"lambda:AddPermission",
"lambda:RemovePermission"
],
"Resource": "arn:aws:lambda:us-west-2:123456789012:function:test:*",
"Condition": {
"StringEquals": {
"lambda:Principal": "sns.amazonaws.com"
}
}
}
]
}
La condición requiere que el principal sea Amazon SNS y no otro servicio o cuenta. El patrón de recursos
requiere que el nombre de la función sea test e incluye un número de versión o alias. Por ejemplo,
test:v1.
Para obtener más información sobre los recursos y las condiciones para Lambda y otros servicios de AWS,
consulte Claves de condiciones, recursos y acciones en la Guía del usuario de IAM.
Secciones
• Funciones (p. 48)
• Mapeos de origen de eventos (p. 49)
• Capas (p. 50)
Funciones
Las acciones que operan sobre una función se pueden restringir a una función específica por ARN
de función, versión o alias, tal y como se describe en la siguiente tabla. Las acciones que no admiten
restricciones de recursos solo pueden concederse para todos los recursos (*).
Funciones
Alias de función
48
AWS Lambda Guía para desarrolladores
Mapeos de origen de eventos
Alias de función
lambda:SubnetIds
lambda:SecurityGroupIds
Para estas acciones, el recurso es el mapeo de origen de eventos, por lo que Lambda proporciona una
condición que permite restringir el permiso según la función que invoca el mapeo de origen de eventos.
49
AWS Lambda Guía para desarrolladores
Capas
Capas
Las acciones de capa permiten restringir las capas que un usuario puede administrar o utilizar con una
función. Las acciones relacionadas con el uso y los permisos de capa actúan sobre una versión de una
capa, mientras que PublishLayerVersion actúa sobre un nombre de capa. Pueden utilizar cualquiera
de ellas con comodines para restringir las capas que un usuario puede utilizar por nombre.
Capas
Las plantillas de aplicación de la consola de Lambda incluyen una propiedad global que aplica un límite de
permisos a todas las funciones que crean.
Globals:
50
AWS Lambda Guía para desarrolladores
Límites de permisos
Function:
PermissionsBoundary: !Sub 'arn:${AWS::Partition}:iam::${AWS::AccountId}:policy/
${AppId}-${AWS::Region}-PermissionsBoundary'
El límite limita los permisos de los roles de las funciones. Puede agregar permisos al rol de ejecución de un
rol en la plantilla, pero ese permiso solo es efectivo si también lo permite el límite de permisos. El rol que
AWS CloudFormation adopta para implementar la aplicación exige el uso del límite de permisos. Dicho rol
solo tiene permiso para crear y transferir roles que tengan asociado el límite de permisos de la aplicación.
De forma predeterminada, el límite de permisos de una aplicación permite a las funciones realizar acciones
en los recursos de la aplicación. Por ejemplo, si la aplicación incluye una tabla de Amazon DynamoDB,
el límite permite el acceso a cualquier acción de API que se pueda restringir para operar en tablas
específicas con permisos de nivel de recurso. Solo puede usar acciones que no admitan permisos de nivel
de recursos si están específicamente permitidas en el límite. Estos incluyen las acciones de API Amazon
CloudWatch Logs y AWS X-Ray para el registro y seguimiento.
{
"Version": "2012-10-17",
"Statement": [
{
"Action": [
"*"
],
"Resource": [
"arn:aws:lambda:us-east-2:123456789012:function:my-app-getAllItemsFunction-
*",
"arn:aws:lambda:us-east-2:123456789012:function:my-app-getByIdFunction-*",
"arn:aws:lambda:us-east-2:123456789012:function:my-app-putItemFunction-*",
"arn:aws:dynamodb:us-east-1:123456789012:table/my-app-SampleTable-*"
],
"Effect": "Allow",
"Sid": "StackResources"
},
{
"Action": [
"logs:CreateLogGroup",
"logs:CreateLogStream",
"logs:DescribeLogGroups",
"logs:PutLogEvents",
"xray:Put*"
],
"Resource": "*",
"Effect": "Allow",
"Sid": "StaticPermissions"
},
...
]
}
Para acceder a otros recursos o acciones de API, usted o un administrador deben ampliar el límite de
permisos para incluir esos recursos. Es posible que también necesite actualizar el rol de ejecución o el rol
de implementación de una aplicación para permitir el uso de acciones adicionales.
• Límite de permisos: amplíe el límite de permisos de la aplicación cuando añada recursos a la aplicación
o el rol de ejecución necesite acceso a más acciones. En IAM, añada recursos al límite para permitir
el uso de acciones de API que admitan permisos de nivel de recursos en el tipo de recurso. Para las
acciones que no admitan permisos de nivel de recursos, añádalas en una instrucción que no esté en el
ámbito de ningún recurso.
51
AWS Lambda Guía para desarrolladores
Límites de permisos
• Rol de ejecución: amplíe el rol de ejecución de un rol cuando necesite utilizar acciones adicionales. En la
plantilla de aplicación, añada políticas al rol de ejecución. La intersección de permisos en el límite y el rol
de ejecución se concede a la función.
• Rol de implementación: amplíe el rol de implementación de la aplicación cuando necesite permisos
adicionales para crear o configurar recursos. En IAM, añada políticas al rol de implementación de
la aplicación. El rol de implementación necesita los mismos permisos de usuario que necesita para
implementar o actualizar una aplicación en AWS CloudFormation.
Para ver un tutorial que explica cómo añadir recursos a una aplicación y ampliar sus permisos, consulte
??? (p. 147).
Para obtener más información, consulte Límites de permisos para las entidades de IAM en la Guía del
usuario de IAM.
52
AWS Lambda Guía para desarrolladores
Para mantener secretos fuera del código de función, almacénelos en la configuración de la función y
léalos del entorno de ejecución durante la inicialización. Las variables de entorno (p. 56) están cifradas
en todo momento y también pueden cifrarse en el lado del cliente. Utilice las variables de entorno para
hacer su código de función portátil eliminando cadenas de conexión, contraseñas y puntos de enlace con
recursos externos.
Las versiones y alias (p. 70) son recursos secundarios que puede crear para administrar la
implementación e invocación de funciones. Publique versiones (p. 70) de su función para almacenar
su código y configuración como recurso independiente que no puede cambiarse y cree un alias (p. 72)
que dirija a una versión específica. A continuación, puede configurar sus clientes para invocar un alias de
función y actualizar el alias cuando quiera dirigir el cliente a una nueva versión, en lugar de actualizar el
cliente.
Si desea utilizar la función Lambda con recursos de AWS en una Amazon VPC, configúrela con grupos de
seguridad y subredes para crear una conexión de VPC (p. 81). La conexión de la función a una VPC le
permite obtener acceso a los recursos de una subred privada, como bases de datos relacionales y cachés.
También puede crear un proxy de base de datos (p. 87) para instancias de base de datos MySQL y
Aurora. Un proxy de base de datos permite que una función alcance altos niveles de simultaneidad sin
agotar las conexiones de base de datos.
Temas
• Configuración de funciones en la consola de AWS Lambda (p. 54)
• Uso de variables de entorno de AWS Lambda (p. 56)
• Administración de la simultaneidad para una función de Lambda (p. 62)
• Versiones de funciones de AWS Lambda (p. 70)
• Alias de la función AWS Lambda (p. 72)
• Capas de AWS Lambda (p. 76)
• Configuración de una función de Lambda para obtener acceso a los recursos de una VPC (p. 81)
• Configuración del acceso a la base de datos para una función Lambda (p. 87)
• Configuración del acceso al sistema de archivos para las funciones Lambda (p. 91)
• Etiquetado de funciones de Lambda (p. 95)
53
AWS Lambda Guía para desarrolladores
Consola de configuración
Para administrar una función, abra la página Funciones de la consola de Lambda y elija una función. El
diseñador de funciones está en la parte superior de la página de configuración.
El diseñador muestra información general de su función y de sus recursos anteriores y posteriores. Puede
usarlo para configurar desencadenadores, capas y destinos.
• Desencadenadores: son servicios y recursos que ha configurado para invocar su función. Elija Add
trigger (Agregar desencadenador) para crear un mapeo de origen de eventos (p. 109) de Lambda o
para configurar un desencadenador en otro servicio con el que se integre la consola de Lambda. Para
obtener más información sobre estos y otros servicios, consulte Utilización de AWS Lambda con otros
servicios (p. 163).
• Capas: elija el nodo Layers (Capas) para añadir capas (p. 76) a su aplicación. Una capa es un
archivo ZIP que contiene bibliotecas, un tiempo de ejecución personalizado u otras dependencias.
• Destinos: agregue un destino a su función para enviar detalles sobre los resultados de invocación a otro
servicio. Puede enviar registros de invocación cuando su función se invoca asincrónicamente (p. 101)
o mediante un mapeo de origen de eventos (p. 109) que se lee desde un flujo.
Configuración de funciones
• Code (Código): El código y las dependencias de la función. Para los lenguajes de scripting, puede editar
el código de la función en el editor (p. 7) integrado. Para añadir bibliotecas, o para los lenguajes no
admitidos por el editor, cargue un paquete de implementación (p. 22). si el paquete de implementación
tiene un tamaño mayor que 50 MB, seleccione Upload a file from (Cargar un archivo desde) Amazon S3.
54
AWS Lambda Guía para desarrolladores
Consola de configuración
• Runtime (Tiempo de ejecución): El tiempo de ejecución de Lambda (p. 130) que ejecuta la función.
• Handler (Controlador): El método que ejecuta el tiempo de ejecución cuando se invoca la función, como
index.handler. El primer valor es el nombre del archivo o del módulo. El segundo valor es el nombre
del método.
• Environment variables (Variables de entorno): Pares clave-valor que Lambda establece en el entorno
de ejecución. Utilice variables de entorno (p. 56) para ampliar la configuración de la función fuera del
código.
• Tags (Etiquetas): Pares clave-valor que Lambda asocia al recurso de la función. Utilice las
etiquetas (p. 95) para organizar las funciones de Lambda en grupos para generar informes de costos
y filtrarlas en la consola de Lambda.
Las etiquetas se aplican a toda la función, incluidas todas las versiones y los alias.
• Execution role (Rol de ejecución): El rol de IAM (p. 33) que AWS Lambda asume cuando ejecuta la
función.
• Description (Descripción): Una descripción de la función.
• Memory (Memoria): La cantidad de memoria disponible para la función durante la ejecución. Elija una
cantidad entre 128 MB y 3,008 MB (p. 31), en incrementos de 64 MB.
La simultaneidad reservada se aplica a toda la función, incluidas todas las versiones y los alias.
• Asynchronous invocation (Invocación asincrónica): Configure el comportamiento de administración
de errores (p. 101) para reducir el número de reintentos de Lambda o el tiempo que los eventos sin
procesar permanecerán en la cola antes de que Lambda los descarte. Configure una cola de mensajes
fallidos (p. 107) para conservar los eventos descartados.
Puede configurar las opciones de gestión de errores en una función, versión o alias.
Para configurar funciones con la API de Lambda, utilice las siguientes acciones:
55
AWS Lambda Guía para desarrolladores
Variables de entorno
• AddPermission (p. 509): modifica la política basada en recursos (p. 37) de una función, una versión o
un alias.
• PutFunctionConcurrency (p. 631): configura la simultaneidad reservada de una función.
• PublishVersion (p. 624): crea una versión inmutable con el código y la configuración actuales.
• CreateAlias (p. 513): crea alias para las versiones de la función.
• PutFunctionEventInvokeConfig: configure la gestión de errores para la invocación asincrónica.
Por ejemplo, para actualizar la configuración de memoria de una función con la AWS CLI, utilice el
comando update-function-configuration.
Las variables de entorno se establecen en la versión no publicada de la función especificando una clave
y un valor. Al publicar una versión, las variables de entorno se bloquean para esa versión junto con otra
configuración específica de la versión (p. 54).
Requisitos
• Las claves comienzan con una letra y tienen como mínimo dos caracteres.
• Las claves solo contienen letras, números y guiones bajos (_).
• Las llaves no están reservadas por Lambda (p. 58).
• El tamaño total de todas las variables de entorno no supera los 4 KB.
6. Elija Save (Guardar).
Utilice variables de entorno para pasar la configuración específica del entorno a su código. Por ejemplo,
puede tener dos funciones con el mismo código pero con configuración diferente. Una función se conecta a
una base de datos de prueba y la otra se conecta a una base de datos de producción. En esta situación, se
utilizan variables de entorno para indicar a la función el nombre de host y otros detalles de conexión para la
base de datos. También puede establecer una variable de entorno para configurar el entorno de prueba y
utilizar un registro o un seguimiento más detallados.
56
AWS Lambda Guía para desarrolladores
Variables de entorno
Para recuperar variables de entorno en el código de función, utilice el método estándar para el lenguaje de
programación.
Node.js
Python
import os
region = os.environ['AWS_REGION']
Ruby
region = ENV["AWS_REGION"]
Java
Go
C#
PowerShell
$region = $env:AWS_REGION
Lambda almacena variables de entorno de forma segura cifrándolas en reposo. Puede configurar Lambda
para que utilice una clave de cifrado diferente (p. 59), cifrar valores de variables de entorno del lado
del cliente o establezca variables de entorno en una plantilla de AWS CloudFormation con AWS Secrets
Manager.
Secciones
• Variables de entorno de tiempo de ejecución (p. 58)
• Proteger variables de entorno (p. 59)
57
AWS Lambda Guía para desarrolladores
Variables de entorno de tiempo de ejecución
58
AWS Lambda Guía para desarrolladores
Proteger variables de entorno
Los valores de muestra presentados reflejan los últimos tiempos de ejecución. La presencia de variables
específicas o sus valores pueden variar en tiempos de ejecución anteriores.
Cuando proporciona la clave, sólo los usuarios de su cuenta con acceso a la clave pueden ver o
administrar variables de entorno en la función. Su organización también podría tener requisitos internos o
externos para administrar las claves que son utilizadas para el cifrado y el control cuando se rotan.
No se requieren permisos de AWS KMS para el usuario o el rol de ejecución de la función para utilizar la
clave de cifrado predeterminada. Para utilizar una CMK administrada por el cliente, necesita permisos de
uso de la llave. Lambda usa sus permisos para crear una concesión en la clave. Esto permite a Lambda
usarlo para el cifrado.
Puede obtener estos permisos a partir de su cuenta de usuario o a partir de la política de permisos
basada en recursos de una clave. La ListAliases es proporcionada por las políticas administradas en
Lambda (p. 42). Las políticas clave conceden los permisos restantes a los usuarios del grupo Usuarios
clave .
Los usuarios sin permisos Decrypt todavía pueden administrar funciones, pero no pueden ver variables
de entorno ni administrarlas en la consola de Lambda. Para evitar que un usuario vea variables de entorno,
añada una instrucción a los permisos del usuario que deniegue el acceso a la clave predeterminada, a una
clave administrada por el cliente o a todas las claves.
{
"Version": "2012-10-17",
"Statement": [
{
"Sid": "VisualEditor0",
"Effect": "Deny",
"Action": [
"kms:Decrypt"
59
AWS Lambda Guía para desarrolladores
Configuración de variables de entorno con la API de Lambda
],
"Resource": "arn:aws:kms:us-east-2:123456789012:key/3be10e2d-xmpl-4be4-
bc9d-0405a71945cc"
}
]
}
Para obtener más información sobre la administración de permisos de clave, consulte Usar políticas de
clave en AWS KMS.
También puede cifrar los valores de variables de entorno del lado del cliente antes de enviarlos a Lambda
y descifrarlos en el código de función. Esto oscurece los valores secretos de la consola de Lambda y
los resultados de la API, incluso para los usuarios que tienen permiso para usar la clave. En el código,
recuperará el valor cifrado del entorno y lo descifrará mediante la API de AWS KMS.
Note
Cuando utiliza los ayudantes de cifrado de la consola, la función necesita permiso para llamar a la
operación de la API kms:Decrypt en su rol de ejecución (p. 33).
Para ver el código de ejemplo para el idioma de su función, seleccione Code (Código) junto a una variable
de entorno. El código de ejemplo muestra cómo recuperar una variable de entorno en una función y
descifrar su valor.
Otra opción es almacenar contraseñas en secretos AWS Secrets Manager. Puede hacer referencia al
secreto en sus plantillas de AWS CloudFormation para establecer contraseñas en las bases de datos.
También puede establecer el valor de una variable de entorno en la función de Lambda. Consulte la
siguiente sección para ver un ejemplo.
60
AWS Lambda Guía para desarrolladores
Código de muestra y plantillas
En el ejemplo siguiente se establecen dos variables de entorno en una función denominada my-
function.
Para asegurarse de que los valores no cambian entre cuando lee la configuración y cuando la actualiza,
puede pasar el ID de revisión del resultado de get-function-configuration como parámetro a
update-function-configuration.
Aplicaciones de muestra
• En blanco (p. 316): cree una función y un tema de Amazon SNS en la misma plantilla. Pase el nombre
del tema a la función en una variable de entorno. Leer variables de entorno en código (varios idiomas).
• RDS MySQL: cree una VPC y una instancia de base de datos de Amazon RDS en una plantilla, con
una contraseña almacenada en Secrets Manager. En la plantilla de aplicación, importe los detalles de la
base de datos de la pila de VPC, lea la contraseña de Secrets Manager y pase toda la configuración de
conexión a la función en variables de entorno.
61
AWS Lambda Guía para desarrolladores
Simultaneidad
La simultaneidad está sujeta a una cuota (p. 31) regional que comparten todas las funciones de una
región. Para asegurarse de que una función pueda alcanzar siempre cierto nivel de simultaneidad,
puede configurar la función con simultaneidad reservada (p. 62). Cuando una función ha reservado
simultaneidad, ninguna otra función puede usarla. La simultaneidad reservada también limita la
simultaneidad máxima para la función y se aplica a la función como un todo, incluyendo versiones y alias.
Cuando Lambda asigna una instancia de su función, el tiempo de ejecución (p. 130) carga el código
de su función y ejecuta el código de inicialización que ha definido fuera del controlador. Si el código y las
dependencias son grandes, o si crea clientes SDK durante la inicialización, este proceso puede llevar
algún tiempo. A medida que la función aumenta (p. 114), esto provoca que la parte de las solicitudes que
atienden nuevas instancias tenga una latencia mayor que el resto.
Para que su función pueda escalar sin fluctuaciones en la latencia, utilice la simultaneidad
aprovisionada (p. 64). Mediante la asignación de la simultaneidad aprovisionada antes de un aumento
en las invocaciones, puede asegurarse de que todas las solicitudes se atiendan mediante instancias
inicializadas con una latencia muy baja. Puede configurar la simultaneidad aprovisionada en una versión
de una función o en un alias.
Lambda también se integra con Auto Scaling de aplicaciones. Puede configurar Auto Scaling de
aplicaciones para administrar la simultaneidad aprovisionada según una programación o basándose en la
utilización. Utilice el escalado programado para aumentar la simultaneidad aprovisionada para prever picos
de tráfico. Para aumentar automáticamente la concurrencia aprovisionada según se requiera, utilice la API
de Auto Scaling de aplicaciones (p. 67) para registrar un objetivo y crear una política de escalado.
Secciones
• Configuración de la simultaneidad reservada (p. 62)
• Configuración de simultaneidad aprovisionada (p. 64)
• Configuración de simultaneidad con la API de Lambda (p. 67)
62
AWS Lambda Guía para desarrolladores
Configuración de la simultaneidad reservada
Puede reservar hasta el valor de Unreserved account concurrency (Simultaneidad de cuenta no reservada)
mostrado, menor a 100 para funciones que no tienen simultaneidad reservada. Para aplicar la limitación
controlada a una función, establezca la concurrencia reservada en cero. Esto impide que los eventos se
procesen hasta que elimine el límite.
El ejemplo siguiente muestra dos funciones con grupos de simultaneidad reservada, y el grupo de
simultaneidad no reservada usado por otras funciones. Los errores de restricción ocurren cuando toda la
simultaneidad de un grupo está en uso.
Leyenda
• Simultaneidad de la función
• Simultaneidad reservada
• Simultaneidad no reservada
• Limitación.
63
AWS Lambda Guía para desarrolladores
Configuración de simultaneidad aprovisionada
• Otras funciones no pueden evitar que la función se escale: todas las funciones de su cuenta en la
misma región sin simultaneidad reservada comparten el grupo de simultaneidad no reservada. Sin
simultaneidad reservada, otras funciones pueden utilizar toda la simultaneidad disponible. Esto impide
que la función se amplíe cuando sea necesario.
• Su función no se puede escalar fuera de control: la simultaneidad reservada también limita que la
función utilice la simultaneidad de un grupo no reservado, lo que limita su simultaneidad máxima. Puede
reservar simultaneidad para evitar que la función utilice toda la simultaneidad disponible en la región o
que sobrecargue los recursos empleados posteriormente.
La configuración de la simultaneidad por función puede afectar al grupo de simultaneidad que está
disponible para otras funciones. Para evitar problemas, limite el número de usuarios que pueden utilizar las
operaciones de la API PutFunctionConcurrency y DeleteFunctionConcurrency.
Puede administrar la simultaneidad aprovisionada para todos los alias y versiones desde la página de
configuración de funciones. La lista de configuraciones de simultaneidad aprovisionadas muestra el
progreso de la asignación de cada configuración. Los ajustes de simultaneidad aprovisionada también
están disponibles en la página de configuración para cada versión y alias.
64
AWS Lambda Guía para desarrolladores
Configuración de simultaneidad aprovisionada
Leyenda
• Simultaneidad de la función
• Simultaneidad reservada
• Simultaneidad aprovisionada
• Simultaneidad no reservada
• Limitación.
65
AWS Lambda Guía para desarrolladores
Configuración de simultaneidad aprovisionada
Leyenda
• Instancias de función
• Solicitudes abiertas
• Simultaneidad aprovisionada
• Simultaneidad estándar
El código de inicialización (p. 20) de su función se ejecuta durante la asignación y cada pocas horas, ya
que las instancias en ejecución de su función se reciclan. Puede ver el tiempo de inicialización en registros
y rastros (p. 311) después de que una instancia procese una solicitud. Sin embargo, la inicialización
se factura incluso si la instancia nunca procesa una solicitud. La simultaneidad aprovisionada se ejecuta
continuamente y se factura por separado de los costes de inicialización e invocación. Para obtener más
información, consulte Precios de AWS Lambda.
66
AWS Lambda Guía para desarrolladores
Configuración de simultaneidad con la API de Lambda
Cada versión de una función solo puede tener una configuración de simultaneidad aprovisionada. Puede
ser directamente en la propia versión o en un alias que apunte a la versión. Dos alias no pueden asignar
simultaneidad aprovisionada para la misma versión. Tampoco puede asignar simultaneidad aprovisionada
en un alias que apunte a la versión no publicada ($LATEST).
• ProvisionedConcurrentExecutions
• ProvisionedConcurrencyInvocations
• ProvisionedConcurrencySpilloverInvocations
• ProvisionedConcurrencyUtilization
Para obtener más información, consulte Trabajar con métricas de funciones de AWS Lambda (p. 464).
Para configurar la simultaneidad reservada con la AWS CLI, use el comando put-function-
concurrency. El comando siguiente reserva una simultaneidad de 100 para una función llamada my-
function:
67
AWS Lambda Guía para desarrolladores
Configuración de simultaneidad con la API de Lambda
Para configurar Auto Scaling de aplicaciones para administrar la concurrencia aprovisionada, utilice Auto
Scaling de aplicaciones para configurar el escalado de seguimiento de destino. Primero, registre el alias
de una función como destino de escala. En el ejemplo siguiente se registra el alias BLUE de una función
denominada my-function:
A continuación, aplique una política de escalado al destino. El ejemplo siguiente se configura Auto Scaling
de aplicaciones para ajustar la configuración de simultaneidad aprovisionada para que un alias mantenga
la utilización cerca del 70 por ciento:
Auto Scaling de aplicaciones crea dos alarmas en CloudWatch. La primera alarma se activa cuando
la utilización de la simultaneidad aprovisionada supera sistemáticamente el 70 por ciento. Cuando
esto sucede, Auto Scaling de aplicaciones asigna más simultaneidad aprovisionada para reducir esta
utilización. La segunda alarma se activa cuando la utilización es consistentemente inferior al 63 por
ciento (90 % del objetivo del 70 por ciento). Cuando esto sucede, Auto Scaling de aplicaciones reduce la
concurrencia aprovisionada del alias.
En el siguiente ejemplo, una función escala entre cantidades mínimas y máximas de simultaneidad
aprovisionada basada en su uso. Cuando el número de solicitudes abiertas aumenta, Auto Scaling
de aplicaciones aumenta la simultaneidad aprovisionada a pasos grandes hasta que llega al máximo
configurado. La función sigue escalando en simultaneidad estándar hasta que su uso comienza a
68
AWS Lambda Guía para desarrolladores
Configuración de simultaneidad con la API de Lambda
disminuir. Cuando el uso es consistentemente bajo, Auto Scaling de aplicaciones reduce la simultaneidad
aprovisionada en pasos periódicos más pequeños.
Leyenda
• Instancias de función
• Solicitudes abiertas
• Simultaneidad aprovisionada
• Simultaneidad estándar
Para consultar las cuotas de simultaneidad de su cuenta en una región, utilice get-account-settings.
69
AWS Lambda Guía para desarrolladores
Versiones
"AccountLimit": {
"TotalCodeSize": 80530636800,
"CodeSizeUnzipped": 262144000,
"CodeSizeZipped": 52428800,
"ConcurrentExecutions": 1000,
"UnreservedConcurrentExecutions": 900
},
"AccountUsage": {
"TotalCodeSize": 174913095,
"FunctionCount": 52
}
}
El sistema crea una nueva versión de la función de Lambda cada vez que se publica la función. La nueva
versión es una copia de la versión no publicada de la función. La versión de la función incluye la siguiente
información:
Puede cambiar el código y la configuración de la función solo en la versión no publicada de una función.
Cuando se publica una versión, el código y la mayoría de las opciones de configuración se bloquean para
garantizar una experiencia uniforme para los usuarios de dicha versión. Para obtener más información
acerca de la configuración de funciones, consulte Configuración de funciones en la consola de AWS
Lambda (p. 54).
Después de publicar la primera versión de una función, la consola de Lambda muestra un menú
desplegable con las versiones disponibles. El panel Designer (Diseñador) muestra un calificador de versión
al final del nombre de la función.
70
AWS Lambda Guía para desarrolladores
Administración de versiones con la API de Lambda
Para ver las versiones actuales de la función, elija una función y, a continuación, elija Qualifiers
(Calificadores). En el menú Qualifiers (Cualificadores) ampliado, elija la pestaña Versions (Versiones). El
panel Versions (Versiones) muestra la lista de versiones de la función seleccionada. Si no ha publicado
una versión de la función seleccionada, el panel Versions (Versiones) muestra solo la versión $LATEST.
El siguiente ejemplo publica una nueva versión de una función. La respuesta devuelve la información de
configuración sobre la nueva versión, incluido el número de la versión y el ARN de la función con el sufijo
de la versión.
Uso de versiones
El ARN permite hacer referencia a la función de Lambda. Existen dos ARN asociados a esta versión inicial:
71
AWS Lambda Guía para desarrolladores
Políticas de recursos
arn:aws:lambda:aws-region:acct-id:function:helloworld:$LATEST
arn:aws:lambda:aws-region:acct-id:function:helloworld
Puede utilizar este ARN incompleto en todas las operaciones pertinentes. Sin embargo, no puede
utilizarlo para crear un alias.
Si decide no publicar versiones de funciones, puede utilizar el ARN calificado o no calificado en el mapeo
de origen de eventos para invocar la función.
Lambda solo publica una nueva versión de función si el código no se ha publicado nunca o si el código
ha cambiado en comparación con la versión publicada más recientemente. Si no hay ningún cambio, la
versión de la función permanece en la versión publicada más recientemente.
Cada versión de función de Lambda tiene un ARN único. Después de publicar una versión, no puede
cambiar el ARN o el código de función.
Políticas de recursos
Cuando se utiliza una política basada en recursos (p. 37) para dar un servicio, recurso o acceso a cuentas
a su función, el alcance de dicho permiso depende de si se aplicó a una función o a una versión de una
función:
• Si utiliza un nombre de función calificado (como helloworld:1), el permiso es válido para invocar la
versión 1 de la función helloworld utilizando únicamente su ARN calificado. El uso de cualquier otro
ARN genera un error de permiso.
• Si utiliza un nombre de función no calificado (como helloworld), el permiso solo es válido para invocar
la función helloworld utilizando el ARN de la función no calificada. El uso de cualquier otro ARN,
incluido $LATEST, produce un error de permiso.
• Si utiliza el nombre de función calificado $LATEST (como helloworld:$LATEST), el permiso es válido
para invocar la función helloworld solo utilizando su ARN calificado. El uso de un ARN no calificado
genera un error de permiso.
Puede simplificar la administración de orígenes de eventos y políticas de recursos mediante el uso de alias
de función. Para obtener más información, consulte Alias de la función AWS Lambda (p. 72).
72
AWS Lambda Guía para desarrolladores
Administración de alias con la API de Lambda
4. En el formulario Create a new alias (Crear un nuevo alias), escriba un nombre para el alias y una
descripción opcional. Elija la versión de la función para este alias.
Para ver los alias definidos actualmente para una función, elija Qualifiers (Calificadores) y elija la pestaña
Alias .
Para cambiar un alias para apuntar a una nueva versión de la función, utilice el comando update-alias.
Los comandos de la AWS CLI de los pasos anteriores corresponden a las siguientes API de AWS Lambda:
Uso de alias
Cada alias tiene un ARN único. Un alias solo puede apuntar a una versión de función, no a otro alias.
Puede actualizar un alias para que apunte a una nueva versión de la función.
73
AWS Lambda Guía para desarrolladores
Políticas de recursos
Fuentes de eventos como Amazon S3 invocan su función de Lambda. Estos orígenes de eventos
mantienen un mapeo que identifica la función que invocarán cuando se produzcan eventos. Si especifica
un alias de función de Lambda en la configuración de asignación, no es necesario actualizar el mapeo
cuando cambie la versión de la función.
En una política de recursos, puede conceder permisos para que los orígenes de eventos utilicen la función
de Lambda. Si especifica un ARN de alias en la política, no es necesario que actualice la política cuando
cambie la versión de la función.
Políticas de recursos
Cuando se utiliza una política basada en recursos (p. 37) para dar un servicio, recurso o acceso a cuentas
a su función, el alcance de dicho permiso depende de si se aplicó a un alias, a una versión o a la función.
Si utiliza un nombre de alias (como helloworld:PROD), el permiso solo es válido para invocar la función
helloworld utilizando el ARN del alias. Obtiene un error de permiso si utiliza un ARN de versión o un
ARN de función. Esto incluye el ARN de versión al que apunta el alias.
Por ejemplo, el siguiente comando de AWS CLI otorga permisos a Amazon S3 para invocar el alias PROD
de la función de Lambda helloworld. Tenga en cuenta que el parámetro --qualifier especifica el
nombre del alias.
En este caso, Amazon S3 ahora puede invocar el alias PROD. Lambda puede ejecutar la versión de
la función de Lambda helloworld a la que hace referencia el alias PROD. Para que esto funcione
correctamente, debe utilizar el ARN del alias PROD en la configuración de notificaciones del bucket de S3.
Puede apuntar un alias a un máximo de dos versiones de una función de Lambda. Las versiones deben
cumplir los siguientes criterios:
74
AWS Lambda Guía para desarrolladores
Configuración de direccionamiento de alias
5. En la ventana Create a new alias (Crear un nuevo alias), escriba un valor para Name (Nombre),
opcionalmente escriba un valor para Description (Descripción) y elija la Version (Versión) de la función
de Lambda a la que hace referencia el alias.
6. En Additional version (Versión adicional), especifique los elementos siguientes:
En el ejemplo siguiente se crea un alias (denominado alias de direccionamiento) para una función de
Lambda. El alias apunta a la versión 1 de la función. La versión 2 de la función recibe el 3 por ciento del
tráfico. El 97 por ciento restante del tráfico se dirige a la versión 1.
Para dirigir todo el tráfico a la versión 2, utilice el comando UpdateAlias para cambiar la propiedad
function-version y dirigir el alias a la versión 2. El comando también restablece la configuración de
direccionamiento.
Los comandos de la CLI en los pasos anteriores corresponden a las siguientes operaciones de la API de
AWS Lambda:
• CloudWatch Logs: Lambda emite automáticamente una entrada de registro START que contiene el ID de
la versión invocada a CloudWatch Logs para cada invocación de función. A continuación se muestra un
ejemplo:
75
AWS Lambda Guía para desarrolladores
Capas
Para invocaciones de alias, Lambda utiliza la dimensión Executed Version para filtrar los datos de
las métricas por la versión ejecutada. Para obtener más información, consulte Trabajar con métricas de
funciones de AWS Lambda (p. 464).
• Carga de respuesta (invocaciones sincrónicas): las respuestas a invocaciones de funciones sincrónicas
incluyen un encabezado x-amz-executed-version para indicar qué versión de función se ha
invocado.
Las capas le permiten mantener un tamaño pequeño para el paquete de implementación, lo que facilita la
implementación. Puede evitar errores que podrían producirse al instalar y empaquetar dependencias con el
código de la función. Para las funciones Node.js, Python y Ruby, puede desarrollar el código de su función
en la consola de Lambda (p. 7) siempre que mantenga el paquete de implementación en 3 MB.
Note
Una función puede utilizar hasta 5 capas a la vez. El tamaño total descomprimido de la función
y todas las capas no puede superar el límite del tamaño del paquete de implementación sin
comprimir, de 250 MB. Para obtener más información, consulte Cuotas de AWS Lambda (p. 31).
Puede crear capas o utilizar capas publicadas por AWS y otros clientes de AWS. Las capas admiten
políticas basadas en recursos (p. 80) para conceder permisos de uso por capas a cuentas específicas
de AWS o de AWS Organizations o a todas las cuentas.
Las capas se extraen en el directorio /opt en el entorno de ejecución de la función. Cada tiempo de
ejecución busca las bibliotecas en una ubicación diferente dentro de /opt, en función del lenguaje.
Estructure su capa (p. 79) de modo que el código de la función pueda acceder a las bibliotecas sin
configuración adicional.
También puede utilizar Modelo de aplicación sin servidor de AWS (AWS SAM) para administrar las capas y
la configuración de la capa de su función. Para obtener instrucciones, consulte Declaración de recursos sin
servidor en la Guía para desarrolladores de Modelo de aplicación sin servidor de AWS.
Secciones
• Configuración de una función para usar capas (p. 76)
• Administración de capas (p. 77)
• Inclusión de dependencias de biblioteca en una capa (p. 79)
• Permisos de capa (p. 80)
• AWS CloudFormation y AWS SAM (p. 80)
• Aplicaciones de muestra (p. 81)
76
AWS Lambda Guía para desarrolladores
Administración de capas
Debe especificar la versión de cada capa que quiera utilizar proporcionando el ARN completo de la versión
de la capa. Al añadir capas para una función que ya tenga capas, la nueva lista sobrescribe la anterior.
Incluya todas las capas cada vez que actualice la configuración de la capa. Para eliminar todas las capas,
especifique una lista vacía.
Su función puede obtener acceso al contenido de la capa durante la ejecución en el directorio /opt. Las
capas se aplican en el orden que se especifica y se combinan las carpetas con el mismo nombre. Si el
mismo archivo aparece en varias capas, se utiliza la versión en la última capa aplicada.
El creador de una capa puede eliminar la versión de la capa que esté utilizando. Cuando esto sucede, la
función continúa ejecutándose como si la versión de la capa siguiera existiendo. Sin embargo, cuando
actualiza la configuración de la capa, debe eliminar la referencia a la versión eliminada.
Administración de capas
Para crear una capa, use el comando publish-layer-version con un nombre, una descripción, un
archivo ZIP y una lista de tiempos de ejecución (p. 130) que sean compatibles con la capa. La lista de
tiempos de ejecución es opcional, pero hace que la capa sea más fácil de descubrir.
77
AWS Lambda Guía para desarrolladores
Administración de capas
"LayerArn": "arn:aws:lambda:us-east-2:123456789012:layer:my-layer",
"LayerVersionArn": "arn:aws:lambda:us-east-2:123456789012:layer:my-layer:1",
"Description": "My layer",
"CreatedDate": "2018-11-14T23:03:52.894+0000",
"Version": 1,
"LicenseInfo": "MIT",
"CompatibleRuntimes": [
"python3.6",
"python3.7",
"python3.8"
]
}
Cada vez que llame a publish-layer-version crea una nueva versión. Las funciones que utilizan
la capa se refieren directamente a una versión de la capa. Puede configurar permisos (p. 80) en una
versión de la capa existente, pero para realizar cualquier otro cambio, debe crear una nueva versión.
Para encontrar capas que sean compatibles con el tiempo de ejecución de su función, utilice el comando
list-layers.
Puede omitir la opción del tiempo de ejecución para obtener una lista de todas las capas. Los detalles en
la respuesta reflejan la versión más reciente de la capa. Consulte todas las versiones de una capa con
list-layer-versions. Para obtener más información sobre una versión, utilice get-layer-version.
78
AWS Lambda Guía para desarrolladores
Inclusión de dependencias de biblioteca en una capa
"python3.8"
]
}
El enlace en la respuesta le permite descargar el archivo de la capa y es válido durante 10 minutos. Para
eliminar una versión de una capa, use el comando delete-layer-version.
Al eliminar una versión de una capa, ya no puede configurar funciones para usarla. Sin embargo, cualquier
función que ya utilice la versión sigue teniendo acceso a la misma. Los números de versión nunca se
reutilizan para un nombre de capa.
Para incluir bibliotecas en una capa, colóquelas en una de las carpetas que admita el tiempo de ejecución
o modifique esa variable de ruta para su idioma.
xray-sdk.zip
# nodejs/node_modules/aws-xray-sdk
Example Pillow
pillow.zip
# python/PIL
# python/Pillow-5.3.0.dist-info
Example JSON
json.zip
# ruby/gems/2.5.0/
| build_info
| cache
| doc
| extensions
| gems
| # json-2.1.0
# specifications
# json-2.1.0.gemspec
Example Jackson
jackson.zip
# java/lib/jackson-core-2.2.3.jar
79
AWS Lambda Guía para desarrolladores
Permisos de capa
Example JQ
jq.zip
# bin/jq
Para obtener más información acerca de la configuración de rutas en el entorno de ejecución de Lambda,
consulte Variables de entorno de tiempo de ejecución (p. 58).
Permisos de capa
Los permisos de uso de capa se administran en el recurso. Para configurar una función con una capa,
necesita permiso para llamar a GetLayerVersion en la versión de la capa. Para las funciones en su
cuenta, puede obtener este permiso desde su política de usuario (p. 42) o desde la política basada en
recursos (p. 37) de la función. Para utilizar una capa en otra cuenta, necesita permiso en su política de
usuario, y el propietario de la otra cuenta debe conceder permiso a su cuenta con una política basada en
recursos.
Para conceder el permiso de uso de capa a otra cuenta, añada una instrucción a la política de permisos de
la versión de la capa con el comando add-layer-version-permission. En cada instrucción, puede
conceder permiso a una única cuenta, a todas las cuentas o a una organización.
Los permisos solo se aplican a una única versión de una capa. Repita el procedimiento cada vez que cree
una nueva versión de la capa.
Para ver más ejemplos, consulte Concesión de acceso a las capas a otras cuentas (p. 41).
AWSTemplateFormatVersion: '2010-09-09'
Transform: 'AWS::Serverless-2016-10-31'
Description: An AWS Lambda application that calls the Lambda API.
Resources:
function:
Type: AWS::Serverless::Function
Properties:
Handler: index.handler
Runtime: nodejs12.x
CodeUri: function/.
Description: Call the AWS Lambda API
Timeout: 10
# Function's execution role
80
AWS Lambda Guía para desarrolladores
Aplicaciones de muestra
Policies:
- AWSLambdaBasicExecutionRole
- AWSLambdaReadOnlyAccess
- AWSXrayWriteOnlyAccess
Tracing: Active
Layers:
- !Ref libs
libs:
Type: AWS::Serverless::LayerVersion
Properties:
LayerName: blank-nodejs-lib
Description: Dependencies for the blank sample app.
ContentUri: lib/.
CompatibleRuntimes:
- nodejs12.x
Cuando actualiza sus dependencias e realiza la implementación, AWS SAM crea una nueva versión de la
capa y actualiza el mapeo. Si implementa cambios en el código sin modificar sus dependencias, AWS SAM
omite la actualización de capa, ahorrando tiempo de carga.
Aplicaciones de muestra
El repositorio de GitHub para esta guía proporciona aplicaciones de ejemplo (p. 315) que demuestran el
uso de capas para la administración de dependencias.
• Node.js: blank-nodejs
• Python: blank-python
• Ruby: blank-ruby
• Java: blank-java
Para obtener más información acerca de la aplicación de ejemplo en blanco, consulte Aplicación de
ejemplo de función en blanco para AWS Lambda (p. 316).
81
AWS Lambda Guía para desarrolladores
Permisos de usuario y rol de ejecución
conexión de una función a una subred pública no le concede acceso a Internet ni una
dirección IP pública.
6. Elija Save (Guardar).
Al conectar una función a una VPC, Lambda crea una interfaz de red elástica para cada combinación
de grupo de seguridad y subred en la configuración de la VPC de la función. Este proceso puede tardar
alrededor de un minuto.
Mientras Lambda crea una interfaz de red, no se pueden realizar operaciones adicionales que se dirijan
a la función, como creación de versiones (p. 70) o actualización del código de la función. Para nuevas
funciones, no se puede invocar la función hasta que su estado cambie de Pending a Active. Para las
funciones existentes, todavía puede invocar la versión anterior mientras la actualización está en curso.
Para obtener más información acerca de los estados de función, consulte Monitorización del estado de una
función con la API de Lambda (p. 113).
Varias funciones conectadas a las mismas subredes comparten interfaces de red. Conectar funciones
adicionales a una subred que tiene una interfaz de red administrada por Lambda existente es mucho
más rápido que hacer que Lambda cree interfaces de red adicionales. Sin embargo, si tiene muchas
funciones o funciones con un alto uso de red, es posible que Lambda pueda todavía crear interfaces de
red adicionales.
Si las funciones no están activas durante un largo periodo de tiempo, Lambda reclama las interfaces de red
y las funciones pasan a ser Idle. Para reactivar una función inactiva, invóquela. Esta invocación produce
un error y la función vuelve a encontrarse en un estado Pending hasta que esté disponible una interfaz de
red.
Las funciones Lambda no pueden conectarse directamente a una VPC con tenencia de instancias
dedicada. Para conectarse a los recursos de una VPC dedicada, interconéctela con una segunda VPC con
tenencia predeterminada.
Tutoriales de VPC
• Tutorial: Configuración de una función de Lambda para obtener acceso a Amazon RDS en una Amazon
VPC (p. 269)
• Tutorial: Configuración de una función de Lambda para obtener acceso a Amazon ElastiCache en una
Amazon VPC (p. 241)
Secciones
• Permisos de usuario y rol de ejecución (p. 82)
• Configuración del acceso a la VPC con la API de Lambda (p. 83)
• Uso de claves de condición de IAM para la configuración de la VPC (p. 83)
• Acceso a Internet y a los servicios para funciones conectadas a la VPC (p. 87)
• Ejemplos de configuraciones de VPC (p. 87)
• ec2:CreateNetworkInterface
• ec2:DescribeNetworkInterfaces
• ec2:DeleteNetworkInterface
82
AWS Lambda Guía para desarrolladores
Configuración del acceso a la VPC con la API de Lambda
Al configurar la conectividad de VPC, Lambda utiliza los permisos para comprobar los recursos de
red. Para configurar una función para conectarse a una VPC, su usuario de AWS Identity and Access
Management (IAM) necesita los siguientes permisos:
Permisos de usuario
• ec2:DescribeSecurityGroups
• ec2:DescribeSubnets
• ec2:DescribeVpcs
Para crear una función y conectarla a una VPC mediante la AWS Command Line Interface (AWS CLI),
puede utilizar el comando create-function con la opción vpc-config. En el ejemplo siguiente se crea
una función con una conexión a una VPC con dos subredes y un grupo de seguridad.
Para conectar una función existente a una VPC, utilice el comando update-function-configuration
con la opción vpc-config.
Para desconectar la función de de una VPC, actualice la configuración de la función con una lista vacía de
subredes y grupos de seguridad.
83
AWS Lambda Guía para desarrolladores
Uso de claves de condición de IAM
para la configuración de la VPC
Las operaciones de la API de Lambda CreateFunction (p. 524) y UpdateFunctionConfiguration (p. 667)
admiten estas claves de condición. Para obtener información sobre el uso de claves de condición en las
políticas de IAM, consulte Elementos de la política de JSON de IAM: Condición en la Guía del usuario de
IAM.
Tip
Si su función ya incluye una configuración de VPC de una solicitud de la API anterior, puede
enviar una solicitud UpdateFunctionConfiguration sin la configuración de la VPC.
{
"Version": "2012-10-17",
"Statement": [
{
"Sid": "EnforceVPCFunction",
"Action": [
"lambda:CreateFunction",
"lambda:UpdateFunctionConfiguration"
],
"Effect": "Deny",
"Resource": "*",
"Condition": {
"Null": {
"lambda:VpcIds": "true"
}
}
}
]
}
84
AWS Lambda Guía para desarrolladores
Uso de claves de condición de IAM
para la configuración de la VPC
{
"Version": "2012-10-17",
"Statement": [
{
"Sid": "EnforceOutOfVPC",
"Action": [
"lambda:CreateFunction",
"lambda:UpdateFunctionConfiguration"
],
"Effect": "Deny",
"Resource": "*",
"Condition": {
"StringEquals": {
"lambda:VpcIds": ["vpc-1", "vpc-2"]
}
}
}
Para denegar a los usuarios el acceso a subredes específicas, utilice StringEquals para comprobar el
valor de la condición lambda:SubnetIds. En el ejemplo siguiente se deniega a los usuarios el acceso a
subnet-1 y subnet-2.
{
"Sid": "EnforceOutOfSubnet",
"Action": [
"lambda:CreateFunction",
"lambda:UpdateFunctionConfiguration"
],
"Effect": "Deny",
"Resource": "*",
"Condition": {
"ForAnyValue:StringEquals": {
"lambda:SubnetIds": ["subnet-1", "subnet-2"]
}
}
}
Para denegar a los usuarios el acceso a grupos de seguridad específicos, utilice StringEquals para
comprobar el valor de la condición lambda:SecurityGroupIds. En el ejemplo siguiente se deniega a
los usuarios el acceso a sg-1 y sg-2.
{
"Sid": "EnforceOutOfSecurityGroups",
"Action": [
"lambda:CreateFunction",
"lambda:UpdateFunctionConfiguration"
],
"Effect": "Deny",
"Resource": "*",
"Condition": {
"ForAnyValue:StringEquals": {
"lambda:SecurityGroupIds": ["sg-1", "sg-2"]
}
}
}
]
}
85
AWS Lambda Guía para desarrolladores
Uso de claves de condición de IAM
para la configuración de la VPC
{
"Version": "2012-10-17",
"Statement": [
{
"Sid": "EnforceStayInSpecificVpc",
"Action": [
"lambda:CreateFunction",
"lambda:UpdateFunctionConfiguration"
],
"Effect": "Allow",
"Resource": "*",
"Condition": {
"StringEquals": {
"lambda:VpcIds": ["vpc-1", "vpc-2"]
}
}
}
Para permitir a los usuarios acceder a subredes específicas, utilice StringEquals para comprobar el
valor de la condición lambda:SubnetIds. En el siguiente ejemplo se permite a los usuarios acceder a
subnet-1 y subnet-2.
{
"Sid": "EnforceStayInSpecificSubnets",
"Action": [
"lambda:CreateFunction",
"lambda:UpdateFunctionConfiguration"
],
"Effect": "Allow",
"Resource": "*",
"Condition": {
"ForAllValues:StringEquals": {
"lambda:SubnetIds": ["subnet-1", "subnet-2"]
}
}
}
Para permitir a los usuarios acceder a grupos de seguridad específicos, utilice StringEquals para
comprobar el valor de la condición lambda:SecurityGroupIds. En el siguiente ejemplo se permite a los
usuarios acceder a sg-1 y sg-2.
{
"Sid": "EnforceStayInSpecificSecurityGroup",
"Action": [
"lambda:CreateFunction",
"lambda:UpdateFunctionConfiguration"
],
"Effect": "Allow",
"Resource": "*",
"Condition": {
"ForAllValues:StringEquals": {
"lambda:SecurityGroupIds": ["sg-1", "sg-2"]
86
AWS Lambda Guía para desarrolladores
Acceso a Internet y a los servicios
para funciones conectadas a la VPC
}
}
}
]
}
Varios servicios de AWS ofrecen puntos de enlace de la VPC. Puede utilizar los puntos de enlace
de la VPC para conectarse a servicios de AWS desde dentro de una VPC sin acceso a Internet.
El acceso a Internet desde una subred privada requiere la conversión de las direcciones de red (NAT).
Para conceder a la función acceso a Internet, enrute el tráfico saliente a una gateway NAT en una subred
pública. La gateway NAT tiene una dirección IP pública y puede conectarse a Internet a través de la
gateway de Internet de la VPC. Para obtener más información, consulte Cómo conceder acceso a Internet
a una función Lambda en una VPC.
• vpc-private.yaml: una VPC con dos subredes privadas y puntos de enlace de la VPC para Amazon
Simple Storage Service (Amazon S3) y Amazon DynamoDB. Utilice esta plantilla para crear una VPC
para funciones que no necesitan acceso a Internet. Esta configuración admite el uso de Amazon S3 y
DynamoDB con los SDK de AWS, así como el acceso a los recursos de base de datos de la misma VPC
a través de una conexión de red local.
• vpc-privatepublic.yaml: VPC con dos subredes privadas, puntos de enlace de VPC, una subred pública
con una gateway NAT y una gateway de Internet. El tráfico hacia Internet desde las funciones de las
subredes privadas se enruta a la gateway NAT mediante una tabla de enrutamiento.
Para crear una VPC con una plantilla, en la página Pilas de la consola de AWS CloudFormation, elija
Create stack (Crear pila) y, a continuación, siga las instrucciones del asistente de Create stack (Crear pila).
87
AWS Lambda Guía para desarrolladores
Uso de los permisos de la función para autenticación
Example secreta
{
"username": "admin",
"password": "e2abcecxmpldc897"
}
• Rol de IAM: un rol de IAM con permiso para usar el secreto y una política de confianza que permite
a Amazon RDS asumir el rol.
• Autenticación: método de autenticación y autorización para conectarse al proxy desde el código de
función.
5. Elija Add (Añadir).
Precios
Amazon RDS cobra un precio por hora para los proxies que está determinado por el tamaño de
instancia de su base de datos. Para obtener más información, consulte Precios del proxy de RDS.
La creación de proxy tarda unos minutos. Cuando el proxy esté disponible, configure su función para que
se conecte al punto de enlace del proxy en lugar del punto de enlace de la base de datos.
Se aplican los precios de Proxy de Amazon RDS estándar. Para obtener más información, consulte
Administración de conexiones con el proxy de Amazon RDS en la Guía del usuario de Amazon Aurora.
Temas
• Uso de los permisos de la función para autenticación (p. 88)
• Aplicación de muestra (p. 89)
Puede crear un proxy de base de datos que utilice las credenciales de IAM de la función para la
autenticación y autorización en lugar de una contraseña. Para utilizar los permisos de la función para
conectarse al proxy, establezca la función Authentication (Autenticación) en Execution role (Rol de
ejecución).
88
AWS Lambda Guía para desarrolladores
Aplicación de muestra
Para obtener más información, consulte la sección sobre autenticación de bases de datos de IAM en la
Guía del usuario de Amazon RDS.
Aplicación de muestra
Las aplicaciones de muestra que presentan el uso de Lambda con una base de datos de Amazon RDS
están disponibles en el repositorio GitHub de esta guía. Hay dos aplicaciones:
• RDS MySQL: la plantilla de AWS CloudFormation template-vpcrds.yml crea una base de datos
de MySQL 5.7 en una VPC privada. En la aplicación de muestra, una función Lambda intercepta las
consultas a la base de datos. Tanto la función como las plantillas de base de datos utilizan Secrets
Manager para obtener acceso a las credenciales de la base de datos.
89
AWS Lambda Guía para desarrolladores
Aplicación de muestra
• Administrador de listas: una función del procesador lee los eventos de un flujo de Kinesis. Utiliza los
datos de los eventos para actualizar las tablas de DynamoDB y almacena una copia del evento en una
base de datos de MySQL.
90
AWS Lambda Guía para desarrolladores
Sistema de archivos
Para utilizar las aplicaciones de muestra, siga las instrucciones del repositorio GitHub: RDS MySQL,
Administrador de listas.
Una función se conecta a un sistema de archivos a través de la red local en una VPC. Las subredes a
las que se conecta la función pueden ser las mismas subredes que contienen puntos de montaje para el
sistema de archivos, o subredes en la misma zona de disponibilidad que pueden enrutar el tráfico NFS
(puerto 2049) al sistema de archivos.
Note
Si la función aún no está conectada a una VPC, consulte Configuración de una función de
Lambda para obtener acceso a los recursos de una VPC (p. 81).
91
AWS Lambda Guía para desarrolladores
Configuración de un sistema de
archivos y un punto de acceso
• Sistema de archivos EFS: el punto de acceso para un sistema de archivos de la misma VPC.
• Ruta de montaje local: La ubicación en la que se monta el sistema de archivos en la función
Lambda, empezando por /mnt/.
Precios
Amazon EFS tiene cargos por almacenamiento y rendimiento, con tarifas que varían según la
clase de almacenamiento. Consulte Precios de Amazon EFS para obtener más información.
Cargos de Lambda por transferencia de datos entre VPC. Esto solo se aplica si la VPC de su
función está pegada a otra VPC con un sistema de archivos. Las tasas son las mismas que para
la transferencia de datos de Amazon EC2 entre VPC de la misma región. Consulte Precios de
Lambda para obtener más información.
Para obtener más información acerca de la integración de Lambda con Amazon EFS, consulte Uso de
Amazon EFS con Lambda (p. 245).
Secciones
• Configuración de un sistema de archivos y un punto de acceso (p. 92)
• Permisos de usuario y rol de ejecución (p. 93)
• Configurar el acceso al sistema de archivos con la API de Lambda (p. 93)
• AWS CloudFormation y AWS SAM (p. 94)
• Aplicaciones de muestra (p. 95)
Cuando crea un sistema de archivos, elige un modo de rendimiento que no se puede cambiar
más adelante. El modo Propósito general tiene menor latencia, y el modo E/S Max admite
un rendimiento e IOPS máximos más altos. Para obtener ayuda sobre cómo elegir, consulte
Rendimiento de Amazon EFS en la Guía del usuario de Amazon Elastic File System.
Un punto de acceso conecta cada instancia de la función con el destino de montaje correcto para la zona
de disponibilidad a la que se conecta. Para obtener el mejor rendimiento, cree un punto de acceso con
una ruta que no sea raíz y limite el número de archivos que crea en cada directorio. Los ID de usuario
y propietario son obligatorios, pero no necesitan tener un valor específico. En el siguiente ejemplo se
crea un directorio denominado my-function en el sistema de archivos y se establece el identificador de
propietario en 1001 con permisos de directorio estándar (755).
• Nombre – files
92
AWS Lambda Guía para desarrolladores
Permisos de usuario y rol de ejecución
• ID de usuario – 1001
• ID del grupo – 1001
• Ruta – /my-function
• Permisos – 755
• ID de usuario del propietario – 1001
• ID de usuario de grupo – 1001
Cuando una función utiliza el punto de acceso, se le da el ID de usuario 1001 y tiene acceso completo al
directorio.
Para obtener más información, consulte los siguientes temas en la Amazon Elastic File System User
Guide:
• elasticfilesystem:ClientMount
• elasticfilesystem:ClientWrite (no se necesita para conexiones de solo lectura)
Cuando configura un sistema de archivos, Lambda utiliza sus permisos para verificar los destinos de
montaje. Para configurar una función para conectarse a un sistema de archivos, su usuario de IAM
necesita los siguientes permisos.
Permisos de usuario
• elasticfilesystem:DescribeMountTargets
$ ARN=arn:aws:elasticfilesystem:us-east-2:123456789012:access-point/fsap-015cxmplb72b405fd
93
AWS Lambda Guía para desarrolladores
AWS CloudFormation y AWS SAM
Puede obtener el ARN del punto de acceso de un sistema de archivos con el comando describe-
access-points.
Resources:
VPC:
Type: AWS::EC2::VPC
Properties:
CidrBlock: 10.0.0.0/16
Subnet1:
Type: AWS::EC2::Subnet
Properties:
VpcId:
Ref: VPC
CidrBlock: 10.0.1.0/24
AvailabilityZone: "eu-central-1a"
EfsSecurityGroup:
Type: AWS::EC2::SecurityGroup
Properties:
VpcId:
Ref: VPC
GroupDescription: "mnt target sg"
SecurityGroupEgress:
- IpProtocol: -1
CidrIp: "0.0.0.0/0"
FileSystem:
94
AWS Lambda Guía para desarrolladores
Aplicaciones de muestra
Type: AWS::EFS::FileSystem
Properties:
PerformanceMode: generalPurpose
MountTarget1:
Type: AWS::EFS::MountTarget
Properties:
FileSystemId:
Ref: FileSystem
SubnetId:
Ref: Subnet1
SecurityGroups:
- Ref: EfsSecurityGroup
MyFunctionWithEfs:
Type: AWS::Serverless::Function
Properties:
CodeUri: function/.
Description: Use a file system.
FileSystemConfigs:
-
Arn: !Sub
- "arn:aws:elasticfilesystem:eu-central-1:123456789101:access-point/${ap}"
- {ap: !Ref AccessPoint}
LocalMountPath: "/mnt/efs0"
DependsOn: "MountTarget1"
Debe agregar el DependsOn para asegurarse de que los destinos de montaje se crean completamente
antes de las ejecuciones de Lambda por primera vez.
Aplicaciones de muestra
El repositorio de GitHub para esta guía incluye una aplicación de ejemplo que demuestra el uso de
Amazon EFS con una función Lambda.
• efs-nodejs: una función que utiliza un sistema de archivos de Amazon EFS en una Amazon VPC.
Este ejemplo incluye una VPC, un sistema de archivos, objetivos de montaje y un punto de acceso
configurados para su uso con Lambda.
95
AWS Lambda Guía para desarrolladores
Etiquetas
Puede filtrar las funciones en función de la presencia o el valor de una etiqueta utilizando la consola de
Lambda o la API de Grupos de recursos de AWS. Las etiquetas se aplican en el nivel de las funciones,
no de las versiones ni de los alias. Las etiquetas no forman parte de la configuración específica de la
instantánea que se crea al publicar una versión.
3. Elija una clave de etiqueta para ver la lista de valores que están en uso en la región actual.
4. Elija un valor para ver las funciones con ese valor o elija (all values) [(todos los valores)] para ver
todas las funciones que tienen una etiqueta con esa clave.
96
AWS Lambda Guía para desarrolladores
Uso de etiquetas con AWS CLI
La barra de búsqueda también permite buscar claves de etiqueta. Escriba tag para ver exclusivamente
una lista de claves de etiqueta o comience a escribir el nombre de una clave para encontrarla en la lista.
Con AWS Billing and Cost Management, puede utilizar etiquetas para personalizar los informes de
facturación y crear informes de asignación de costos. Para obtener más información, consulte Informe
de asignación de costos mensual y Uso de etiquetas de asignación de costos en la Guía del usuario de
administración de costos y facturación de AWS.
Secciones
• Uso de etiquetas con AWS CLI (p. 97)
• Requisitos de las claves y los valores de las etiquetas (p. 98)
Si desea ver las etiquetas que se aplican a una función de Lambda específica, puede utilizar cualquiera de
los siguientes comandos de la API de Lambda:
• ListTags (p. 615) – proporcione el ARN (nombre de recurso de Amazon de la función de Lambda para
ver una lista de las etiquetas asociadas a esta función:
97
AWS Lambda Guía para desarrolladores
Requisitos de las claves y los valores de las etiquetas
• GetFunction (p. 559) – proporcione el nombre de la función de Lambda para ver una lista de las
etiquetas asociadas a esta función:
También puede utilizar la API GetResources de AWS Tagging Service para filtrar los recursos por
etiquetas. La API GetResources admite hasta 10 filtros, y cada uno contiene una clave de etiqueta y hasta
10 valores de etiqueta. Proporcione a GetResources un valor “ResourceType” si desea filtrar por tipos de
recurso específicos. Para obtener más información acerca de AWS Tagging Service, consulte Uso de los
grupos de recursos.
98
AWS Lambda Guía para desarrolladores
Al invocar una función, puede optar por invocarla de forma síncrona o asíncrona. Con invocación
síncrona (p. 100), espere la función para procesar el evento y devolver una respuesta. Con invocación
asíncrona (p. 101), Lambda pone en cola el evento para su procesamiento y devuelve una respuesta
inmediatamente. Para invocación asíncrona, Lambda gestiona los reintentos y puede enviar registros de
invocación a un destino (p. 104).
Para utilizar su función para procesar datos automáticamente, agregue uno o más disparadores. Un
disparador es un recurso de Lambda o un recurso de otro servicio que se configura para invocar la
función en respuesta a eventos del ciclo de vida, solicitudes externas o en una programación. Su función
puede tener varios disparadores. Cada disparador actúa como un cliente invocando su función de forma
independiente. Cada evento que Lambda pasa a su función solo tiene datos de un cliente o disparador.
Para procesar elementos de una transmisión o una cola, puede crear un mapeo de origen de
eventos (p. 109). Un mapeo de origen de eventos es un recurso en Lambda que lee los elementos de
una cola de Amazon SQS, una transmisión de Amazon Kinesis o una transmisión de Amazon DynamoDB
y los envía a su función en lotes. Cada evento que su función procesa puede contener cientos o miles de
elementos.
Otros servicios y recursos de AWS invocan la función directamente. Por ejemplo, puede configurar Eventos
de CloudWatch para invocar la función en un temporizador o Amazon S3 para invocar la función cuando
se crea un objeto. Cada servicio varía en el método que utiliza para invocar la función, la estructura del
evento, y la forma de configurarla. Para obtener más información, consulte Utilización de AWS Lambda con
otros servicios (p. 163).
Dependiendo de quién invoca la función y cómo se invoca, el comportamiento de escalado y los tipos
de errores que ocurren pueden varían. Al invocar una función sincrónicamente, recibe errores en la
respuesta y puede volver a intentarlo. Al invocar de forma asíncrona, utilizar un mapeo de origen de
eventos o configurar otro servicio para invocar su función, pueden variar los requisitos de reintentos y la
forma en que la función se escala para controlar un gran número de eventos. Para más detalles, consulte
Escalado de funciones de AWS Lambda (p. 114) y Control de errores y reintentos automáticos en AWS
Lambda (p. 119).
Temas
• Invocación síncrona (p. 100)
• Invocación asincrónica (p. 101)
• Mapeos de origen de eventos de AWS Lambda (p. 109)
• Monitorización del estado de una función con la API de Lambda (p. 113)
• Escalado de funciones de AWS Lambda (p. 114)
• Control de errores y reintentos automáticos en AWS Lambda (p. 119)
• Invocación de funciones Lambda con el SDK de AWS Mobile para Android (p. 121)
99
AWS Lambda Guía para desarrolladores
Invocación síncrona
Invocación síncrona
Al invocar una función sincrónicamente, Lambda ejecuta la función y espera una respuesta. Cuando
finaliza la ejecución de la función, Lambda devuelve la respuesta desde el código de la función con datos
adicionales como la versión de la función que se ejecutó. Para invocar una función de forma síncrona con
la AWS CLI, utilice el comando invoke.
$ aws lambda invoke --function-name my-function --payload '{ "key": "value" }'
response.json
{
"ExecutedVersion": "$LATEST",
"StatusCode": 200
}
El siguiente diagrama muestra a los clientes que invocan una función Lambda de forma sincrónica.
Lambda envía los eventos directamente a la función y envía la respuesta de la función al invocador.
El payload es una cadena que contiene un evento en formato JSON. El nombre del archivo donde AWS
CLI escribe la respuesta de la función es response.json. Si la función devuelve un objeto o error, la
respuesta es el objeto o error en formato JSON. Si la función sale sin errores, la respuesta es null.
La salida del comando, que se muestra en el terminal, incluye información de los encabezados en
la respuesta de Lambda. Esto incluye la versión que ha procesado el evento (útil cuando se utilizan
alias (p. 72)) y el código de estado devuelto por Lambda. Si Lambda pudo ejecutar la función, el código de
estado es 200, incluso aunque la función devolviera un error.
Note
Para funciones con un tiempo de espera largo, el cliente puede desconectarse durante la
invocación síncrona mientras espera una respuesta. Configure el cliente HTTP, SDK, el firewall, el
proxy o el sistema operativo para permitir conexiones largas con tiempo de espera o ajustes keep-
alive.
100
AWS Lambda Guía para desarrolladores
Invocación asincrónica
Para obtener los registros de una invocación desde la línea de comandos, utilice la opción --log-type.
La respuesta incluye un campo LogResult que contiene hasta 4 KB de registros con codificación base64
a partir de la invocación.
La utilidad base64 está disponible en Linux, MacOS y Ubuntu en Windows. Para el sistema operativo
macOS, el comando es base64 -D.
Para obtener más información acerca de la API Invoke, incluida una lista completa de parámetros,
encabezados y errores, consulte Invoke (p. 587).
Al invocar una función directamente, puede comprobar la respuesta en busca de errores y volver a
intentarlo. La AWS CLI y el SDK de AWS también reintentan automáticamente en los tiempos de espera,
limitaciones y errores de servicio del cliente. Para obtener más información, consulte Control de errores y
reintentos automáticos en AWS Lambda (p. 119).
Invocación asincrónica
Varios servicios de AWS, como Amazon Simple Storage Service (Amazon S3) y Amazon Simple
Notification Service (Amazon SNS), invocan funciones de forma ansíncrona para procesar eventos.
Cuando se invoca una función de forma asíncrona, no se espera una respuesta del código de función.
Se entrega el evento a Lambda, y Lambda se ocupa del resto. Puede configurar la forma en que Lambda
maneja los errores y puede enviar registros de invocación a un recurso descendente para encadenar los
componentes de la aplicación.
El siguiente diagrama muestra los clientes que invocan una función Lambda de forma asíncrona. Lambda
pone en cola los eventos antes de enviarlos a la función.
101
AWS Lambda Guía para desarrolladores
Invocación asincrónica
Para la invocación asíncrona, Lambda coloca el evento en una cola y devuelve una respuesta de “proceso
realizado con éxito” sin información adicional. Un proceso independiente lee eventos de la cola y los envía
a la función. Para invocar una función de forma asíncrona, establezca el parámetro de tipo de invocación
en Event.
El archivo de salida (response.json) no contiene ninguna información, pero se crea al ejecutar este
comando. Si Lambda no puede añadir el caso a la cola, el mensaje de error aparece en la salida del
comando.
Lambda administra la cola de eventos asincrónica de la función y trata de reintentarlo en caso de errores.
Si la función devuelve un error, Lambda intenta ejecutarla dos veces más, con una espera de un minuto
entre los dos primeros intentos y dos minutos entre el segundo y el tercero. Los errores de la función
incluyen errores devueltos por el código de la función y los errores devueltos por el tiempo de ejecución de
la función, como, por ejemplo, los tiempos de espera.
102
AWS Lambda Guía para desarrolladores
Invocación asincrónica
Si la función no tiene disponible suficiente simultaneidad para procesar todos los eventos, se limitan las
solicitudes adicionales. Para limitar errores (429) y errores del sistema (serie 500), Lambda devuelve
el evento a la cola e intenta ejecutar la función de nuevo durante un máximo de 6 horas. El intervalo de
reintento aumenta exponencialmente desde 1 segundo después del primer intento hasta un máximo de 5
minutos. Sin embargo, podría tardar más si se realiza una copia de seguridad de la cola. Lambda también
reduce la velocidad a la que lee eventos de la cola.
El siguiente ejemplo muestra un evento que se añadió correctamente a la cola, pero que aún está
pendiente una hora después debido a la restricción.
Aunque la función no devuelva un error, es posible que reciba el mismo evento de Lambda varias
veces, ya que la propia cola ofrece consistencia final. Si la función no es capaz de gestionar los eventos
entrantes, podrían también eliminarse de la cola sin que se envíen a la función. Asegúrese de que el
código de la función gestione sin problemas eventos duplicados y de que tenga simultaneidad suficiente
disponible para gestionar todas las invocaciones.
Cuando se realiza una copia de seguridad de la cola, es posible que los nuevos eventos se agoten
antes de que Lambda pueda enviarlos a la función. Cuando un evento caduca o todos los intentos de
procesamiento fallan, Lambda lo descarga. Puede configurar la gestión de errores (p. 104) de una
función para reducir el número de reintentos que realiza Lambda o para descartar eventos no procesados
más rápidamente.
También puede configurar Lambda para que envíe un registro de invocación a otro servicio. Lambda
admite los siguientes destinos (p. 104) para la invocación asincrónica.
103
AWS Lambda Guía para desarrolladores
Configuración de la gestión de
errores para la invocación asincrónica
El registro de invocación contiene detalles sobre la solicitud y la respuesta en formato JSON. Puede
configurar destinos independientes en eventos que se procesan con éxito, y eventos que fallan todos los
intentos de procesamiento. También puede configurar una cola de SQS o un tema de SNS como una cola
de mensajes fallidos (p. 107) para eventos descartados. En las colas de mensajes fallidos, Lambda solo
envía el contenido del evento, sin detalles sobre la respuesta.
Secciones
• Configuración de la gestión de errores para la invocación asincrónica (p. 104)
• Configuración de destinos para invocación asincrónica (p. 104)
• API de configuración de invocación asincrónica (p. 106)
• Colas de mensajes fallidos de funciones de AWS Lambda (p. 107)
• Maximum age of event (Antigüedad máxima del evento): El período máximo de tiempo durante el
que Lambda retiene un evento en la cola de evento asincrónico, hasta 6 horas.
• Retry attempts (Número de reintentos): número de reintentos que Lambda realiza cuando la función
devuelve un error, entre 0 y 2.
5. Seleccione Save.
Cuando un evento de invocación supera la antigüedad máxima o no supera ningún reintento, Lambda lo
descarta. Para conservar una copia de eventos descartados, configure un destino de eventos fallidos.
El siguiente ejemplo muestra una función que está procesando invocaciones asincrónicas. Cuando
la función devuelve una respuesta correcta o sale sin lanzar un error, Lambda envía un registro de la
invocación a un bus de eventos EventBridge. Cuando un evento falla todos los intentos de procesamiento,
Lambda envía un registro de invocación a una cola de Amazon SQS.
104
AWS Lambda Guía para desarrolladores
Configuración de destinos para invocación asincrónica
Para enviar eventos a un destino, su función necesita permisos adicionales. Añada una política con los
permisos necesarios al rol de ejecución (p. 33) de la función. Cada servicio de destino requiere un permiso
diferente, como se indica a continuación:
105
AWS Lambda Guía para desarrolladores
API de configuración de invocación asincrónica
• On failure (En caso de error): enviar un registro cuando el evento no supera los intentos de
procesamiento o supera la antigüedad máxima.
• On success (Si es correcto): enviar un registro cuando la función procesa correctamente una
invocación asincrónica.
6. En Destination type (Tipo de destino), elija el tipo de recurso que recibe el registro de invocación.
7. En Destination (Destino), elija un recurso.
8. Seleccione Save.
Cuando una invocación coincide con la condición, Lambda envía un documento JSON con detalles sobre
la invocación al destino. El ejemplo siguiente muestra un registro de invocación para un evento que ha
fallado tres intentos de procesamiento debido a un error de función.
{
"version": "1.0",
"timestamp": "2019-11-14T18:16:05.568Z",
"requestContext": {
"requestId": "e4b46cbf-b738-xmpl-8880-a18cdf61200e",
"functionArn": "arn:aws:lambda:us-east-2:123456789012:function:my-function:
$LATEST",
"condition": "RetriesExhausted",
"approximateInvokeCount": 3
},
"requestPayload": {
"ORDER_IDS": [
"9e07af03-ce31-4ff3-xmpl-36dce652cb4f",
"637de236-e7b2-464e-xmpl-baf57f86bb53",
"a81ddca6-2c35-45c7-xmpl-c3a03a31ed15"
]
},
"responseContext": {
"statusCode": 200,
"executedVersion": "$LATEST",
"functionError": "Unhandled"
},
"responsePayload": {
"errorMessage": "RequestId: e4b46cbf-b738-xmpl-8880-a18cdf61200e Process exited
before completing request"
}
}
El registro de invocación contiene detalles sobre el evento, la respuesta y el motivo por el que se ha
enviado el registro.
• PutFunctionEventInvokeConfig
• GetFunctionEventInvokeConfig
• UpdateFunctionEventInvokeConfig
106
AWS Lambda Guía para desarrolladores
Colas de mensajes fallidos
• ListFunctionEventInvokeConfigs
• DeleteFunctionEventInvokeConfig
Para configurar la invocación asincrónica con la CLI de AWS, utilice el comando put-function-event-
invoke-config. En el ejemplo siguiente se configura una función con una antigüedad máxima de evento
de 1 hora y sin reintentos.
Si no se dispone de una cola o tema, debe crearse. Elija el tipo de destino que coincida con su caso de
uso.
• Cola de Amazon SQS: una cola que contiene eventos fallidos hasta que se recuperan. Puede recuperar
eventos manualmente o configurar Lambda para leer desde la cola (p. 296) e invocar una función.
107
AWS Lambda Guía para desarrolladores
Colas de mensajes fallidos
Para enviar eventos a una cola o tema, la función necesita permisos adicionales. Añada una política con
los permisos necesarios al rol de ejecución (p. 33) de la función.
Si la cola o el tema de destino están cifrados con una clave administrada por el cliente, el rol de ejecución
también debe ser un usuario en la política basada en recursos de la clave.
Después de crear el destino y actualizar el rol de ejecución de la función, añada la cola de mensajes
fallidos a la función. Puede configurar varias funciones para enviar eventos al mismo destino.
Para configurar una cola de mensajes fallidos con la AWS CLI, utilice el comando update-function-
configuration.
Lambda envía el evento a la cola de mensajes fallidos tal y como está, con información adicional en
atributos. Puede utilizar esta información para identificar el error que la función devuelve o correlacionar el
evento con los registros o un rastro de AWS X-Ray.
108
AWS Lambda Guía para desarrolladores
Mapeo de origen de eventos
Si Lambda no puede enviar un mensaje a la cola de mensajes fallidos, elimina el evento y emite la métrica
DeadLetterErrors (p. 464). Esto puede ocurrir debido a la falta de permisos o si el tamaño total del
mensaje supera el límite de la cola o tema de destino. Por ejemplo, si una notificación de Amazon SNS
cuyo cuerpo tiene cerca de 256 KB activa una función que genera un error, los datos adicionales del
evento añadidos por Amazon SNS, junto con los atributos añadidos por Lambda, pueden hacer que el
mensaje supere el tamaño máximo permitido en la cola de mensajes fallidos.
Si está utilizando Amazon SQS como origen de eventos, configure una cola de mensajes fallidos en la
propia cola de Amazon SQS y no en la función de Lambda. Para obtener más información, consulte Uso
de AWS Lambda con Amazon SQS (p. 296).
Un mapeo de origen de eventos utiliza los permisos en el rol de ejecución (p. 33) de la función para leer
y administrar elementos en el origen del evento. Los permisos, la estructura de eventos, los ajustes y
el comportamiento de sondeo varían en función del origen de eventos. Para obtener más información,
consulte el tema vinculado para el servicio que puede usar como origen de eventos.
Para administrar las asignaciones de orígenes de eventos con la AWS CLI o el SDK de AWS, utilice las
siguientes acciones de la API:
109
AWS Lambda Guía para desarrolladores
Mapeo de origen de eventos
En el siguiente ejemplo se utiliza la AWS CLI para asignar una función llamada my-function a una
secuencia de DynamoDB especificada mediante un nombre de recurso de Amazon (ARN), con un tamaño
de lote de 500.
Los mapeos de origen de eventos leen elementos de un flujo o cola en los lotes. Incluyen varios elementos
en caso de que su función los reciba. Puede configurar el tamaño del lote que el mapeo de origen de
eventos envía a su función, hasta un máximo que varía según el servicio. El número de elementos en el
evento puede ser menor que el tamaño del lote si no hay suficientes elementos disponibles o si el lote es
demasiado grande para enviarse en un evento y tiene que dividirse.
En el ejemplo siguiente se muestra una asignación de origen de eventos que lee desde una secuencia de
Kinesis. Si un lote de eventos falla todos los intentos de procesamiento, la asignación de origen de eventos
envía detalles sobre el lote a una cola de SQS.
110
AWS Lambda Guía para desarrolladores
Mapeo de origen de eventos
El lote de eventos es el evento que Lambda envía a la función. Es un lote de registros o mensajes
compilados a partir de los elementos que la asignación de origen de eventos lee desde una secuencia o
cola. El tamaño del lote y otras configuraciones solo se aplican al lote de eventos.
En transmisiones, un mapeo de origen de eventos crea un iterador para cada fragmento de la transmisión
y procesa los elementos de cada fragmento en orden. Puede configurar el mapeo de origen de eventos
para nuevos elementos de solo lectura que aparecen en la transmisión, o para comenzar con los
elementos más antiguos. Los elementos procesados no se eliminan de la transmisión y se pueden
procesar a través de otras funciones o consumidores.
De forma predeterminada, si su función devuelve un error, todo el lote se procesa hasta que la función se
realice correctamente o los elementos del lote caduquen. Para garantizar el procesamiento en orden, el
procesamiento de los fragmentos afectadas se mantiene en pausa hasta que se resuelve el error. Puede
configurar la asignación de origen de eventos para descartar eventos antiguos, restringir el número de
reintentos o procesar varios lotes en paralelo. Si procesa varios lotes en paralelo, el procesamiento en
111
AWS Lambda Guía para desarrolladores
Mapeo de origen de eventos
orden sigue estando garantizado para cada clave de partición, pero se procesan simultáneamente varias
claves de partición en el mismo fragmento.
También puede configurar la asignación de origen de eventos para enviar un registro de invocación a otro
servicio cuando descarta un lote de eventos. Lambda admite los siguientes destinos (p. 104) para las
asignaciones de origen de eventos.
El registro de invocación contiene detalles sobre el lote de eventos fallido en formato JSON.
{
"requestContext": {
"requestId": "c9b8fa9f-5a7f-xmpl-af9c-0c604cde93a5",
"functionArn": "arn:aws:lambda:us-east-2:123456789012:function:myfunction",
"condition": "RetryAttemptsExhausted",
"approximateInvokeCount": 1
},
"responseContext": {
"statusCode": 200,
"executedVersion": "$LATEST",
"functionError": "Unhandled"
},
"version": "1.0",
"timestamp": "2019-11-14T00:38:06.021Z",
"KinesisBatchInfo": {
"shardId": "shardId-000000000001",
"startSequenceNumber": "49601189658422359378836298521827638475320189012309704722",
"endSequenceNumber": "49601189658422359378836298522902373528957594348623495186",
"approximateArrivalOfFirstRecord": "2019-11-14T00:38:04.835Z",
"approximateArrivalOfLastRecord": "2019-11-14T00:38:05.580Z",
"batchSize": 500,
"streamArn": "arn:aws:kinesis:us-east-2:123456789012:stream/mystream"
}
}
Lambda también admite el procesamiento en orden para colas FIFO (primero en entrar, primero en
salir) (p. 296), escalando hasta el número de grupos de mensajes activos. Para las colas estándar, los
elementos no se procesan necesariamente en orden. Lambda escala para procesar una cola estándar lo
más rápido posible. Cuando hay un error, los lotes se devuelven a la cola como elementos individuales y
pueden procesarse en una agrupación diferente del lote original. Ocasionalmente, el mapeo de origen de
eventos podría recibir el mismo elemento de la cola dos veces, incluso si no se ha producido un error de
función. Lambda elimina elementos de la cola una vez que se procesan correctamente. Puede configurar la
cola de origen para que envíe elementos a una cola de mensajes fallidos si no se pueden procesar.
Para obtener más información acerca de los servicios que invocan funciones de Lambda directamente,
consulte Utilización de AWS Lambda con otros servicios (p. 163).
112
AWS Lambda Guía para desarrolladores
Estados de función
Si configura su función para conectarse a una nube privada virtual (VPC), el proceso puede tardar más
tiempo. Cuando conecta por primera vez una función a una VPC, Lambda aprovisiona interfaces de red,
lo que tarda aproximadamente un minuto. Para comunicar el estado actual de su función, Lambda incluye
campos adicionales en el documento de configuración de la función (p. 698) que se devuelve mediante
varias acciones de la API de Lambda.
Cuando se crea una función, inicialmente se encuentra en el estado Pending. Cuando la función
está lista para invocarse, el estado cambia de Pending a Active. Mientras el estado es Pending,
las invocaciones y otras acciones de la API que actúan en la función devuelven un error. Si crea
automatización en torno a la creación y actualización de funciones, espere a que la función se active antes
de realizar acciones adicionales que actúen en la función.
Puede utilizar la API de Lambda para obtener información sobre el estado de una función. La información
de estado se incluye en el documento FunctionConfiguration (p. 698) que devuelven varias acciones
de la API. Para ver el estado de la función con la AWS CLI, utilice el comando get-function-
configuration.
113
AWS Lambda Guía para desarrolladores
Escalado de funciones
{
"FunctionName": "my-function",
"FunctionArn": "arn:aws:lambda:us-east-2:123456789012:function:my-function",
"Runtime": "nodejs12.x",
"VpcConfig": {
"SubnetIds": [
"subnet-071f712345678e7c8",
"subnet-07fd123456788a036",
"subnet-0804f77612345cacf"
],
"SecurityGroupIds": [
"sg-085912345678492fb"
],
"VpcId": "vpc-08e1234569e011e83"
},
"State": "Active",
"LastUpdateStatus": "InProgress",
...
}
Se produce un error en las siguientes operaciones mientras se está realizando una actualización
asincrónica:
Por ejemplo, cuando conecta su función a una nube privada virtual (VPC), Lambda aprovisiona una interfaz
de red elástica para cada subred. Este proceso puede dejar su función en un estado pendiente durante
un minuto más o menos. Lambda también recupera las interfaces de red que no están en uso y cambia
la su función a un estado Inactive. Cuando la función está inactiva, una invocación hace que cambie al
estado Pending mientras se restaura el acceso a la red. La invocación que desencadena la restauración y
otras invocaciones mientras la operación está pendiente, falla con ResourceNotReadyException.
Si Lambda encuentra un error al restaurar la interfaz de red de una función, la función vuelve al
estado Inactive. La siguiente invocación puede desencadenar otro intento. Para algunos errores de
configuración, Lambda espera al menos 5 minutos antes de intentar crear otra interfaz de red. Estos
errores tienen los siguientes valores LastUpdateStatusReasonCode:
Para obtener más información sobre el funcionamiento de los estados con conectividad de VPC, consulte
Configuración de una función de Lambda para obtener acceso a los recursos de una VPC (p. 81).
114
AWS Lambda Guía para desarrolladores
Escalado de funciones
evento, Lambda inicializa otra instancia y la función procesa los dos eventos simultáneamente. Conforme
entran más eventos, Lambda los dirige a instancias disponibles y crea nuevas instancias según sea
necesario. Cuando el número de solicitudes disminuye, Lambda detiene las instancias no utilizadas para
liberar capacidad de escalado para otras funciones.
Después de la ráfaga inicial, la simultaneidad de la función puede escalarse en 500 instancias adicionales
cada minuto. Esto continúa hasta que haya suficientes instancias para servir a todas las solicitudes o hasta
que se alcance un límite de simultaneidad. Cuando llegan las solicitudes más rápidamente de lo que la
función puede escalar o cuando la función está en simultaneidad máxima, las solicitudes adicionales fallan
con un error de limitación (código de estado 429).
El siguiente ejemplo muestra una función que procesa un pico de tráfico. A medida que las invocaciones
aumentan exponencialmente, la función se escala hacia arriba. Inicializa una nueva instancia para
cualquier solicitud que no se pueda enrutar a una instancia disponible. Cuando se alcanza el límite de
ráfaga de simultaneidad, la función comienza a escalar linealmente. Si no es suficiente simultaneidad para
atender todas las solicitudes, las solicitudes adicionales se limitarán y se deben volver a intentar.
115
AWS Lambda Guía para desarrolladores
Escalado de funciones
Leyenda
• Instancias de función
• Solicitudes abiertas
• Posibles limitaciones
La función continúa escalando hasta que se alcanza el límite de simultaneidad de la cuenta para la Región
de la función. La función alcanza la demanda, las solicitudes disminuyen y las instancias no utilizadas de
la función se detienen después de estar inactivas durante algún tiempo. Las instancias no utilizadas se
congelan mientras esperan solicitudes y no generan cargos.
116
AWS Lambda Guía para desarrolladores
Escalado de funciones
El límite de concurrencia regional comienza en 1,000. Puede aumentar el límite enviando una solicitud
en la consola del Centro de soporte técnico. Para asignar capacidad por función, puede configurar las
funciones con simultaneidad reservada (p. 62). La simultaneidad reservada crea un grupo que solo su
función puede utilizar y también evita que su función use simultaneidad sin reservas.
Cuando su función escala hacia arriba, la primera solicitud atendida por cada instancia se ve afectada
por el tiempo que tarda en cargar e inicializar su código. Si el código de inicialización (p. 20) tarda mucho
tiempo, el impacto en la latencia media y percentil puede ser significativo. Para que su función pueda
escalar sin fluctuaciones en la latencia, utilice la simultaneidad aprovisionada (p. 62). En el ejemplo
siguiente se muestra una función con simultaneidad aprovisionada que procesa un pico de tráfico.
Leyenda
• Instancias de función
• Solicitudes abiertas
• Simultaneidad aprovisionada
• Simultaneidad estándar
117
AWS Lambda Guía para desarrolladores
Escalado de funciones
Cuando asigna simultaneidad aprovisionada, su función está lista para servir una ráfaga de solicitudes
entrantes con una latencia muy baja. Cuando se está utilizando toda la simultaneidad aprovisionada, la
función se amplía normalmente para gestionar cualquier solicitud adicional.
Auto Scaling de aplicaciones lleva esto un paso más allá al proporcionar escalado automático
para la simultaneidad aprovisionada. Con Auto Scaling de aplicaciones, puede crear una política
de escala de seguimiento de destino que ajuste automáticamente los niveles de simultaneidad
aprovisionados, en función de la métrica de utilización que Lambda emita. Utilice la API de Auto Scaling de
aplicaciones (p. 67) para registrar un alias como destino escalable y crear una política de escalado.
En el siguiente ejemplo, una función escala entre cantidades mínimas y máximas de simultaneidad
aprovisionada basada en su uso. Cuando el número de solicitudes abiertas aumenta, Auto Scaling
de aplicaciones aumenta la simultaneidad aprovisionada a pasos grandes hasta que llega al máximo
configurado. La función sigue escalando en simultaneidad estándar hasta que su uso comienza a
disminuir. Cuando el uso es consistentemente bajo, Auto Scaling de aplicaciones reduce la simultaneidad
aprovisionada en pasos periódicos más pequeños.
118
AWS Lambda Guía para desarrolladores
Control de errores
Leyenda
• Instancias de función
• Solicitudes abiertas
• Simultaneidad aprovisionada
• Simultaneidad estándar
Al invocar la función de forma asíncrona mediante un mapeo de origen de eventos u otro servicio de AWS,
el comportamiento de escalado varía. Por ejemplo, los mapeos de orígenes de eventos que leen a partir
de una transmisión están limitados por la cantidad de fragmentos de la transmisión. La capacidad de
ampliación que no está utilizada por un origen de eventos está disponible para su uso por parte de otros
clientes y orígenes de eventos. Para obtener más información, consulte los siguientes temas.
Puede monitorizar los niveles de simultaneidad de su cuenta mediante las métricas siguientes:
Métricas de simultaneidad
• ConcurrentExecutions
• UnreservedConcurrentExecutions
• ProvisionedConcurrentExecutions
• ProvisionedConcurrencyInvocations
• ProvisionedConcurrencySpilloverInvocations
• ProvisionedConcurrencyUtilization
Para obtener más información, consulte Trabajar con métricas de funciones de AWS Lambda (p. 464).
Problemas con la solicitud, el intermediario o la cuenta pueden provocar errores de invocación. Los errores
de invocación incluyen un tipo de error y un código de estado en la respuesta que indican la causa del
error.
119
AWS Lambda Guía para desarrolladores
Control de errores
Los clientes como la AWS CLI y el SDK de AWS reintentan si se supera el tiempo de espera de cliente,
hay errores de limitación controlada (429) y otros errores no causados por una solicitud incorrecta (serie
500). Para obtener una lista completa de los errores de invocación, consulte Invoke (p. 587).
Los errores de función se producen cuando el código de la función o el tiempo de ejecución que utiliza
devuelve un error.
• Function (Función): su código de la función genera una excepción o devuelve un objeto de error.
• Runtime (Tiempo de ejecución): el tiempo de ejecución terminó la función al agotarse el tiempo de
espera, al detectarse un error de sintaxis o al no haber podido serializar el objeto de respuesta en JSON.
La función salió con un código de error.
A diferencia de los errores de invocación, los errores de funciones no hacen que Lambda devuelva un
código de estado de la serie 400 o de la serie 500. Si la función devuelve un error, Lambda lo indica
incluyendo un encabezado con el nombre X-Amz-Function-Error, y una respuesta con formato JSON
con el mensaje de error y otros detalles. Para ver ejemplos de errores de las funciones en cada idioma,
consulte los siguientes temas.
Al invocar una función directamente, se determina la estrategia para la gestión del seguimiento de errores.
Puede volver a probar, enviar el evento a una cola para su depurar o ignorar el error. El código de la
función puede haberse ejecutado en su totalidad, en parte o no haberse ejecutado. Si vuelve a intentarlo,
asegúrese de que el código de la función pueda gestionar el mismo evento varias veces sin generar
transacciones duplicados u otros efectos colaterales no deseados.
Al invocar una función indirectamente, que debe tener en cuenta el comportamiento de reintento del
invocador y cualquier servicio que la solicitud encuentra en el proceso. Esto incluye los siguientes
escenarios.
• Asynchronous Invocation (Invocación asíncrona): Lambda reintenta los errores de funciones dos veces.
Si la función no tiene capacidad suficiente para gestionar todas las solicitudes entrantes, los eventos
podrían esperan en la cola durante horas o días para su envío a la función. Puede configurar una cola
de mensajes fallidos en la función para capturar eventos que no se hubieran procesado correctamente.
Para obtener más información, consulte Invocación asincrónica (p. 101).
• Event Source Mappings (mapeos de origen de eventos): los mapeos de orígenes de eventos que
leen desde transmisiones reintentan el lote de elementos completo. Los errores repetidos bloquean el
procesamiento del fragmento afectado hasta que se resuelve el error o los elementos caduquen. Para
detectar fragmentos estancados, puede monitorizar la métrica antigüedad del iterador (p. 464).
Para mapeos de orígenes de eventos que leen de una cola, debe determinar el período de tiempo entre
los reintentos y el destino de los eventos fallidos configurando el tiempo de espera de visibilidad y la
política de redireccionamiento en la cola de origen. Para obtener más información, consulte Mapeos de
120
AWS Lambda Guía para desarrolladores
SDK de Mobile para Android
origen de eventos de AWS Lambda (p. 109) y los temas específicos del servicio en Utilización de AWS
Lambda con otros servicios (p. 163).
• AWS Services (Servicios de AWS ): los servicios de AWS pueden invocar la función de forma
síncrona (p. 100) o asíncrona. Para la invocación síncrona, el servicio decide si volver a intentarlo.
Servicios como API Gateway y Elastic Load Balancing, que el proxy solicita de un usuario o cliente
ascendente, también pueden optar por retransmitir la respuesta de error al solicitante.
Para ayudarle a abordar errores en aplicaciones de Lambda, Lambda se integra con servicios como
Amazon CloudWatch y AWS X-Ray. Puede utilizar una combinación de registros, métricas, alarmas y
seguimiento para detectar y identificar rápidamente problemas en el código de la función, la API u otros
recursos que admiten la aplicación. Para obtener más información, consulte Monitorización y solución de
problemas de aplicaciones basadas en Lambda (p. 463).
Para ver una aplicación de muestra que utiliza una suscripción de CloudWatch Logs, el seguimiento de
X-Ray y una función de Lambda para detectar y procesar errores, consulte Aplicación de ejemplo de
procesamiento de errores para AWS Lambda (p. 323).
Al invocar una función desde una aplicación móvil, puede seleccionar la estructura del evento, el tipo de
invocación (p. 99) y el modelo de permisos. Puede utilizar los alias (p. 72) para permitir actualizaciones
sin problemas del código de la función, pero por lo demás, la función y la aplicación están estrechamente
vinculadas. A medida que añada más funciones, puede crear una capa de API para desacoplar el código
de las funciones de los clientes de front-end y mejorar el rendimiento.
Para crear una API web completa para las aplicaciones móviles y web, utilice Amazon API Gateway. Con
API Gateway, puede añadir autorizadores personalizados, limitar las solicitudes y almacenar los resultados
en caché para todas sus funciones. Para obtener más información, consulte Uso de AWS Lambda con
Amazon API Gateway (p. 165).
Temas
• Tutorial: Uso de AWS Lambda con el SDK de Mobile para Android (p. 122)
• Código de función de ejemplo (p. 127)
121
AWS Lambda Guía para desarrolladores
Tutorial
La aplicación móvil recupera las credenciales de AWS de un grupo de identidades de Amazon Cognito
y las utiliza para invocar una función de Lambda con un evento que contiene los datos de la solicitud. La
función procesa la solicitud y devuelve una respuesta al front-end.
Requisitos previos
En este tutorial, se le presuponen algunos conocimientos sobre las operaciones básicas de Lambda y la
consola de Lambda. Si aún no lo ha hecho, siga las instrucciones que se indican en Introducción a AWS
Lambda (p. 3) para crear la primera función de Lambda.
Para seguir los procedimientos de esta guía, necesitará un shell o un terminal de línea de comando donde
pueda ejecutar los comandos. Los comandos aparecen en listas y van precedidos del símbolo del sistema
($) y del nombre del directorio actual, si es aplicable:
Para los comandos largos, se utiliza un carácter de escape (\) para dividir un comando en varias líneas.
En Linux y macOS, use su administrador de shell y paquetes preferido. En Windows 10, puede instalar
Windows Subsystem para Linux para obtener una versión de Ubuntu y Bash integrada con Windows.
122
AWS Lambda Guía para desarrolladores
Tutorial
Creación de la función
El siguiente ejemplo utiliza datos para generar una respuesta de cadena.
Note
Para ver código de muestra en otros lenguajes, consulte Código de función de ejemplo (p. 127).
Example index.js
123
AWS Lambda Guía para desarrolladores
Tutorial
Para obtener más información sobre las funciones de IAM, consulte Funciones de IAM en la Guía del
usuario de IAM. Para obtener más información acerca de los servicios de Amazon Cognito, consulte la
página de detalles del producto de Amazon Cognito.
• El grupo de identidades que está creando debe permitir el acceso a identidades sin autenticar
porque la aplicación móvil de ejemplo no requiere que el usuario inicie sesión. Por lo tanto,
asegúrese de seleccionar la opción Enable access to unauthenticated identities (Habilitar acceso a
identidades sin autenticar).
• Añada la siguiente instrucción a la política de permisos asociada con las identidades sin autenticar.
{
"Effect": "Allow",
"Action": [
"lambda:InvokeFunction"
],
"Resource": [
"arn:aws:lambda:us-
east-1:123456789012:function:AndroidBackendLambdaFunction"
]
}
{
"Version":"2012-10-17",
"Statement":[
{
"Effect":"Allow",
"Action":[
"mobileanalytics:PutEvents",
"cognito-sync:*"
],
"Resource":[
"*"
]
},
{
"Effect":"Allow",
"Action":[
"lambda:invokefunction"
],
"Resource":[
"arn:aws:lambda:us-east-1:account-
id:function:AndroidBackendLambdaFunction"
]
124
AWS Lambda Guía para desarrolladores
Tutorial
}
]
}
Para obtener instrucciones acerca de cómo crear un grupo de identidades, inicie sesión en la consola
de Amazon Cognito y siga el asistente New Identity Pool (Nuevo grupo de identidades).
3. Anote el ID del grupo de identidades. Debe especificar este ID en la aplicación móvil que creará en
la siguiente sección. La aplicación utiliza este ID cuando envía una solicitud a Amazon Cognito para
solicitar credenciales de seguridad temporales.
compile 'com.amazonaws:aws-android-sdk-core:2.2.+'
compile 'com.amazonaws:aws-android-sdk-lambda:2.2.+'
3. Compile el proyecto para que las dependencias necesarias se descarguen según sea necesario.
4. En el manifiesto de la aplicación para Android (AndroidManifest.xml), añada los siguientes
permisos para que la aplicación se pueda conectarse a Internet. Puede añadirlos justo antes de la
etiqueta final </manifest>.
import com.amazonaws.mobileconnectors.lambdainvoker.*;
import com.amazonaws.auth.CognitoCachingCredentialsProvider;
import com.amazonaws.regions.Regions;
6. En la sección package, añada las dos clases siguientes (RequestClass y ResponseClass). Tenga
en cuenta que el POJO es el mismo que el POJO que creó en la función de Lambda de la sección
anterior.
• RequestClass. Las instancias de esta clase actúan como POJO (Plain Old Java Object) para
datos de eventos que constan de nombre y apellidos. Si está utilizando el ejemplo de Java para la
función de Lambda que creó en la sección anterior, este POJO es igual que el POJO que creó en el
código de la función de Lambda.
package com.example....lambdaeventgenerator;
public class RequestClass {
String firstName;
String lastName;
125
AWS Lambda Guía para desarrolladores
Tutorial
public RequestClass() {
}
}
• ResponseClass
package com.example....lambdaeventgenerator;
public class ResponseClass {
String greetings;
public ResponseClass() {
}
}
7. En el mismo paquete, cree una interfaz denominada MyInterface para invocar la función de
Lambda AndroidBackendLambdaFunction.
package com.example.....lambdaeventgenerator;
import com.amazonaws.mobileconnectors.lambdainvoker.LambdaFunction;
public interface MyInterface {
/**
* Invoke the Lambda function "AndroidBackendLambdaFunction".
* The function name is the method name.
*/
@LambdaFunction
ResponseClass AndroidBackendLambdaFunction(RequestClass request);
126
AWS Lambda Guía para desarrolladores
Código de muestra
// Create the Lambda proxy object with a default Json data binder.
// You can provide your own data binder by implementing
// LambdaDataBinder.
final MyInterface myInterface = factory.build(MyInterface.class);
@Override
protected void onPostExecute(ResponseClass result) {
if (result == null) {
return;
}
// Do a toast
Toast.makeText(MainActivity.this, result.getGreetings(),
Toast.LENGTH_LONG).show();
}
}.execute(request);
Temas
127
AWS Lambda Guía para desarrolladores
Código de muestra
Node.js
El siguiente ejemplo utiliza datos para generar una respuesta de cadena.
Example index.js
Comprima el código de muestra para crear un paquete de implementación. Para obtener instrucciones,
consulte Paquete de implementación de AWS Lambda en Node.js (p. 336).
Java
El siguiente ejemplo utiliza datos para generar una respuesta de cadena.
En el código, el handler (myHandler) utiliza los tipos RequestClass y ResponseClass para entrada y
salida. El código proporciona implementación para estos tipos.
Example HelloPojo.java
package example;
import com.amazonaws.services.lambda.runtime.Context;
128
AWS Lambda Guía para desarrolladores
Código de muestra
public RequestClass() {
}
}
public ResponseClass() {
}
Dependencias.
• aws-lambda-java-core
Cree el código con las dependencias de la biblioteca de Lambda para crear un paquete de
implementación. Para obtener instrucciones, consulte Paquete de implementación de AWS Lambda en
Java (p. 386).
129
AWS Lambda Guía para desarrolladores
Amazon Linux
• Imagen: amzn-ami-hvm-2018.03.0.20181129-x86_64-gp2
• Kernel de Linux – 4.14.171-105.231.amzn1.x86_64
Amazon Linux 2
• Imagen: personalizada
• Kernel de Linux – 4.14.165-102.205.amzn2.x86_64
Cuando se invoca su función, Lambda intenta reutilizar el entorno de ejecución de una invocación previa,
si la hay. Esto ahorra tiempo de preparación del entorno de ejecución y le permite ahorrar recursos como
conexiones de base de datos y archivos temporales en el contexto de ejecución (p. 132) para evitar tener
que crearlos cada vez que se ejecuta la función.
Un tiempo de ejecución es compatible con una sola versión de un idioma, múltiples versiones de un idioma
o múltiples idiomas. Los tiempos de ejecución específicos de un idioma o versión de marco de trabajo
están restringidas (p. 132) cuando la versión alcanza el fin de su vida útil.
130
AWS Lambda Guía para desarrolladores
Runtimes de Java
Tiempos de ejecución de Go
Runtimes de .NET
Temas
• Contexto de ejecución de AWS Lambda (p. 132)
• Política de soporte del tiempo de ejecución (p. 132)
• Tiempos de ejecución personalizados de AWS Lambda (p. 134)
• Interfaz de tiempo de ejecución de AWS Lambda (p. 136)
131
AWS Lambda Guía para desarrolladores
Contexto de ejecución
Se necesita tiempo para configurar un contexto de ejecución y realizar el proceso de arranque necesario,
lo que añade cierta latencia cada vez que se invoca una función de Lambda. Normalmente, esta latencia
aparece cuando se invoca una función de Lambda por primera vez o después de actualizarla, ya que
AWS Lambda intenta reutilizar el contexto de ejecución para las invocaciones posteriores de la función de
Lambda.
Una vez ejecutada la función de Lambda, AWS Lambda mantiene el contexto de ejecución durante cierto
tiempo, anticipándose a otra posible invocación de la función de Lambda. A efectos prácticos, el servicio
congela el contexto de ejecución una vez finalizada la función de Lambda y, si AWS Lambda decide
reutilizarlo cuando se invoque de nuevo la función de Lambda, lo descongela para su reutilización. Este
enfoque de reutilización de contextos de ejecución tiene las siguientes implicaciones:
• Los objetos declarados fuera del método del controlador de la función permanecen inicializados, lo que
proporciona una optimización adicional cuando la función se invoca de nuevo. Por ejemplo, si la función
de Lambda establece una conexión con una base de datos, en lugar de volver a establecer la conexión,
se utiliza la conexión original en posteriores invocaciones. Le sugerimos que añada lógica al código que
compruebe si existe una conexión antes de crear una nueva.
• Cada contexto de ejecución proporciona 512 MB de espacio en disco adicional en el directorio /tmp.
El contenido del directorio se conserva al congelar el contexto de ejecución, proporcionando una
caché transitoria que se puede utilizar para varias invocaciones. Puede agregar código adicional para
comprobar si la caché dispone de los datos que se almacenaron. Para obtener información acerca de los
límites de implementación, consulte Cuotas de AWS Lambda (p. 31).
• Los procesos en segundo plano o las devoluciones de llamada iniciadas por la función de Lambda que
no se completaron al finalizar la función se reanudan si AWS Lambda decide reutilizar el contexto de
ejecución. Asegúrese de que los procesos en segundo plano o las devoluciones de llamada del código
se completen antes de que este finalice.
Cuando escriba el código de la función de Lambda no presuponga que AWS Lambda reutiliza
automáticamente el contexto de ejecución para las siguientes invocaciones de la función. Otros factores
pueden dictar la necesidad de que AWS Lambda cree un nuevo contexto de ejecución, lo que puede
producir resultados inesperados, como errores de conexión a la base de datos.
132
AWS Lambda Guía para desarrolladores
Política de soporte del tiempo de ejecución
Este proceso se produce en dos fases. Durante la primera fase, no es posible crear funciones que utilicen
el tiempo de ejecución obsoleto. Durante al menos 30 días, puede continuar actualizando las funciones
existentes que utilizan el tiempo de ejecución obsoleto. Pasado este tiempo, tanto la creación de funciones
como sus actualizaciones se deshabilitan de forma permanente. Sin embargo, la función sigue estando
disponible para procesar eventos de invocación.
Note
Python 2.7 alcanzó el final de su vida útil el 1 de enero de 2020. Sin embargo, el tiempo de
ejecución de Python 2.7 sigue siendo compatible y no está programado para ser obsoleto en este
momento. Para obtener más información, consulte Soporte continuo para Python 2.7 en AWS
Lambda.
En la mayoría de los casos, la fecha de fin de vida útil de una versión de un lenguaje o un sistema
operativo se conoce con mucha antelación. Si tiene funciones que utilizan un tiempo de ejecución que
quedará obsoleto en los próximos 60 días, Lambda de notifica por correo electrónico que debe preparar
la migración de la función a un tiempo de ejecución admitido. En algunos casos, como, por ejemplo,
problemas de seguridad que requieren una actualización incompatible con versiones anteriores, o software
que no admite un programa de soporte a largo plazo (LTS), puede que no sea posible dar un aviso con
antelación.
• Node.js – github.com
• Python – devguide.python.org
• Ruby – www.ruby-lang.org
• Java – www.oracle.com y aws.amazon.com/corretto
• Go – golang.org
• .NET Core – dotnet.microsoft.com
Después de que un tiempo de ejecución se quede obsoleto, es posible que Lambda lo retire por completo
en cualquier momento desactivando la invocación. Los tiempos de ejecución obsoletos no pueden recibir
actualizaciones de seguridad ni soporte técnico. Antes de retirar un tiempo de ejecución, Lambda envía
notificaciones adicionales a los clientes afectados. En este momento, no hay tiempos de ejecución que
vayan a retirarse.
133
AWS Lambda Guía para desarrolladores
Runtimes personalizados
Para comenzar a utilizar tiempos de ejecución personalizados, consulte Tutorial: publicación de un tiempo
de ejecución personalizado (p. 138). También puede estudiar un tiempo de ejecución personalizado
implementado en C++ en awslabs/aws-lambda-cpp en GitHub.
Temas
• Uso de un tiempo de ejecución personalizado (p. 134)
• Creación de un tiempo de ejecución personalizado (p. 134)
Example function.zip
.
### bootstrap
### function.sh
Si hay un archivo llamado bootstrap en el paquete de implementación, Lambda ejecuta ese archivo. De
lo contrario, Lambda busca un tiempo de ejecución en el capas de la función. Si el no se encuentra archivo
de arranque o no es ejecutable, la función devuelve un error tras la invocación.
Example arranque
#!/bin/sh
cd $LAMBDA_TASK_ROOT
134
AWS Lambda Guía para desarrolladores
Creación de un tiempo de ejecución personalizado
./node-v11.1.0-linux-x64/bin/node runtime.js
Tareas de inicialización
• Recuperar opciones de configuración–: leer variables de entorno para obtener detalles acerca de la
función y el entorno.
• _HANDLER–: la ubicación del controlador, a partir de la configuración de la función. El formato estándar
es file.method, donde file es el nombre del archivo sin extensión, y method es el nombre de un
método o una función que se define en el archivo.
• LAMBDA_TASK_ROOT–: el directorio que contiene el código de la función.
• AWS_LAMBDA_RUNTIME_API–: el host y el puerto de la API de tiempo de ejecución.
Consulte en Variables de entorno de tiempo de ejecución (p. 58) la lista completa de variables
disponibles.
• Inicializar la función–: cargar el archivo de controlador y ejecutar cualquier código global o estático en él.
Las funciones deben crear los recursos estáticos, como clientes SDK y conexiones de bases de datos,
una vez, y después volver a utilizarlos para varias invocaciones.
• Gestionar errores–: si se produce un error, llamar a la API de error de inicialización (p. 138) y salir de
forma inmediata.
La inicialización se tiene en cuenta al calcular el tiempo de ejecución y el tiempo de espera que se factura.
Cuando una ejecución activa la inicialización de una nueva instancia de la función, puede ver el tiempo de
inicialización en los registros y el rastreo de AWS X-Ray (p. 311).
Example log
Mientras se ejecuta, el tiempo de ejecución utiliza la interfaz de tiempo de ejecución de Lambda (p. 136)
para administrar eventos entrantes e informar sobre errores. Después de completar las tareas de
inicialización, el tiempo de ejecución procesa los eventos entrantes en bucle. En el código de tiempo de
ejecución, realice los siguientes pasos en orden.
135
AWS Lambda Guía para desarrolladores
Interfaz de tiempo de ejecución
Procesamiento de tareas
• Obtener un evento–: llamar a la API de la siguiente invocación (p. 136) para obtener el siguiente
evento. El cuerpo de la respuesta contiene los datos del evento. Los encabezados de respuesta
contienen el ID de la solicitud y otra información.
• Propagar el encabezado de rastreo–: obtener el encabezado de rastreo de X-Ray desde el encabezado
Lambda-Runtime-Trace-Id en la respuesta de la API. Establezca localmente la variable de entorno
_X_AMZN_TRACE_ID con el mismo valor. El SDK de X-Ray utiliza este valor para conectar datos de
rastreo entre servicios.
• Crear un objeto context–: crear un objeto con información de contexto a partir de las variables de entorno
y los encabezados en la respuesta de la API.
• Invocar el controlador de la función–: transferir el evento y el objeto context al controlador.
• Gestionar la respuesta–: llamar a la API de respuesta de invocación (p. 137) para publicar la respuesta
desde el controlador.
• Gestionar errores–: si se produce un error, llamar a la API de error de invocación (p. 138).
• Limpiar–: liberar recursos no utilizados, enviar datos a otros servicios o realizar tareas adicionales antes
de obtener el siguiente evento.
Puede incluir el tiempo de ejecución del paquete de implementación de la función o distribuir el tiempo de
ejecución aparte en una capa de función. Para ver un tutorial de ejemplo, consulte Tutorial: publicación de
un tiempo de ejecución personalizado (p. 138).
La especificación de OpenAPI para la versión de la API de tiempo de ejecución 2018-06-01 está disponible
aquí: runtime-api.zip.
Example Solicitud
curl "http://${AWS_LAMBDA_RUNTIME_API}/2018-06-01/runtime/invocation/next"
Recursos
• Siguiente invocación (p. 136)
• Respuesta de la invocación (p. 137)
• Error de invocación (p. 138)
• Error de inicialización (p. 138)
Siguiente invocación
Ruta: /runtime/invocation/next
Método: GET
136
AWS Lambda Guía para desarrolladores
Respuesta de la invocación
Encabezados de respuesta
Respuesta de la invocación
Ruta: /runtime/invocation/AwsRequestId/response
Método: POST
Envía una respuesta de invocación a Lambda. Una vez que el tiempo de ejecución invoca el controlador
de la función, publica la respuesta de la función en la ruta de respuesta de la invocación. En el caso de
invocaciones síncronas, Lambda envía después la respuesta de vuelta al cliente.
REQUEST_ID=156cb537-e2d4-11e8-9b34-d36013741fb9
curl -X POST "http://${AWS_LAMBDA_RUNTIME_API}/2018-06-01/runtime/invocation/$REQUEST_ID/
response" -d "SUCCESS"
137
AWS Lambda Guía para desarrolladores
Error de invocación
Error de invocación
Ruta: /runtime/invocation/AwsRequestId/error
Método: POST
Si la función devuelve un error, el tiempo de ejecución da formato de documento JSON al error y lo publica
en la ruta de error de invocación.
{
"errorMessage" : "Error parsing event data.",
"errorType" : "InvalidEventDataException"
}
REQUEST_ID=156cb537-e2d4-11e8-9b34-d36013741fb9
ERROR="{\"errorMessage\" : \"Error parsing event data.\", \"errorType\" :
\"InvalidEventDataException\"}"
curl -X POST "http://${AWS_LAMBDA_RUNTIME_API}/2018-06-01/runtime/invocation/$REQUEST_ID/
error" -d "$ERROR" --header "Lambda-Runtime-Function-Error-Type: Unhandled"
Error de inicialización
Ruta: /runtime/init/error
Método: POST
Requisitos previos
En este tutorial, se le presuponen algunos conocimientos sobre las operaciones básicas de Lambda y la
consola de Lambda. Si aún no lo ha hecho, siga las instrucciones que se indican en Introducción a AWS
Lambda (p. 3) para crear la primera función de Lambda.
138
AWS Lambda Guía para desarrolladores
Crear una función
Para seguir los procedimientos de esta guía, necesitará un shell o un terminal de línea de comando donde
pueda ejecutar los comandos. Los comandos aparecen en listas y van precedidos del símbolo del sistema
($) y del nombre del directorio actual, si es aplicable:
Para los comandos largos, se utiliza un carácter de escape (\) para dividir un comando en varias líneas.
En Linux y macOS, use su administrador de shell y paquetes preferido. En Windows 10, puede instalar
Windows Subsystem para Linux para obtener una versión de Ubuntu y Bash integrada con Windows.
Necesita un rol de IAM para crear una función de Lambda. El rol necesita permiso para enviar registros
a CloudWatch Logs y acceder a los servicios de AWS que utilizan la función. Si no tiene un rol para el
desarrollo de funciones, cree uno.
El tiempo de ejecución carga un script de función desde el paquete de implementación. Utiliza dos
variables para localizar el script. LAMBDA_TASK_ROOT le indica dónde se extrajo el paquete y _HANDLER
incluye el nombre del script.
Example arranque
#!/bin/sh
# Processing
while true
do
HEADERS="$(mktemp)"
# Get an event. The HTTP request will block until one is received
EVENT_DATA=$(curl -sS -LD "$HEADERS" -X GET "http://${AWS_LAMBDA_RUNTIME_API}/2018-06-01/
runtime/invocation/next")
139
AWS Lambda Guía para desarrolladores
Crear una función
Tras cargar el script, el tiempo de ejecución procesa los eventos en bucle. Utiliza la API de tiempo de
ejecución para recuperar un evento de invocación de Lambda, pasa el evento al controlador y publica
la respuesta de vuelta en Lambda. Para obtener el ID de la solicitud, el tiempo de ejecución guarda los
encabezados de la respuesta de la API en un archivo temporal y lee el encabezado Lambda-Runtime-
Aws-Request-Id del archivo.
Note
Los tiempos de ejecución se encargan de algunas cosas más, como gestionar errores y
proporcionar información de contexto al controlador. Para obtener información, consulte Creación
de un tiempo de ejecución personalizado (p. 134).
El script define una función de controlador que toma datos de eventos, la registra en stderr y la devuelve.
Example function.sh
function handler () {
EVENT_DATA=$1
echo "$EVENT_DATA" 1>&2;
RESPONSE="Echoing request: '$EVENT_DATA'"
echo $RESPONSE
}
runtime-tutorial
# bootstrap
# function.sh
140
AWS Lambda Guía para desarrolladores
Crear una capa
"Handler": "function.handler",
"CodeSha256": "mv/xRv84LPCxdpcbKvmwuuFzwo7sLwUO1VxcUv3wKlM=",
"Version": "$LATEST",
"TracingConfig": {
"Mode": "PassThrough"
},
"RevisionId": "2e1d51b0-6144-4763-8e5c-7d5672a01713",
...
}
Actualización de la función
Para utilizar la capa de tiempo de ejecución con la función, configure la función para que use la capa y, a
continuación, elimine de ella el código de tiempo de ejecución.
141
AWS Lambda Guía para desarrolladores
Actualización del tiempo de ejecución
Esto agrega el tiempo de ejecución a la función en el directorio /opt. Lambda utiliza este tiempo de
ejecución, pero solo si se elimina del paquete de implementación de la función. Actualice el código de la
función para que incluya solo el script del controlador.
Invoque la función de para verificar que funciona con la capa de tiempo de ejecución.
Example arranque
#!/bin/sh
142
AWS Lambda Guía para desarrolladores
Uso compartido de la capa
env
Puede agregar varias instrucciones de manera que cada una conceda permiso a una única cuenta,
cuentas de una organización o todas las cuentas.
Eliminar recursos
Elimine cada versión de la capa.
Puesto que la función contiene una referencia a la versión 2 de la capa, esta sigue existiendo en Lambda.
Si bien la función sigue funcionando, ya no se pueden configurar funciones para que utilicen la versión
eliminada. Si después modifica la lista de capas en la función, deberá especificar una nueva versión u
omitir la capa eliminada.
143
AWS Lambda Guía para desarrolladores
Administración de aplicaciones
AWS Serverless Application Repository proporciona una recopilación de aplicaciones Lambda que puede
implementar en su cuenta con tan solo unos clics. El repositorio incluye tanto aplicaciones listas para usar
como muestras que puede utilizar como punto de partida para sus propios proyectos. También puede
enviar sus propios proyectos para su inclusión.
AWS CloudFormation le permite crear una plantilla que defina los recursos de su aplicación y le permita
administrar la aplicación como una pila. Puede agregar o modificar recursos de forma más segura en su
pila de aplicaciones. Si se produce un fallo en alguna parte de una actualización, AWS CloudFormation
restaura automáticamente a la configuración anterior. Con los parámetros de AWS CloudFormation, puede
crear varios entornos para la aplicación a partir de la misma plantilla. AWS SAM (p. 29) amplía AWS
CloudFormation con una sintaxis simplificada centrada en el desarrollo de aplicaciones de Lambda.
La AWS CLI (p. 29) y SAM CLI (p. 30) son herramientas de línea de comandos para la administración de
pilas de aplicaciones de Lambda. Además de comandos para la administración de pilas de aplicaciones
con la API de AWS CloudFormation, AWS CLI admite los comandos de nivel superior, que simplifican
tareas como la carga de paquetes de implementación y la actualización de plantillas. El CLI AWS SAM
proporciona funcionalidad adicional, que incluye validación de plantillas y pruebas de forma local.
Temas
• Administración de aplicaciones en la consola de AWS Lambda (p. 144)
• Creación de una aplicación con entrega continua en la consola de Lambda (p. 147)
• Implementaciones continuas para funciones de Lambda (p. 156)
• Tipos de aplicaciones de Lambda y casos de uso comunes (p. 157)
• Prácticas recomendadas para trabajar con funciones AWS Lambda (p. 159)
144
AWS Lambda Guía para desarrolladores
Monitorización de aplicaciones
Monitorización de aplicaciones
La pestaña Monitoring (Monitorización) muestra un panel Amazon CloudWatch con métricas para los
recursos de la aplicación.
De forma predeterminada, la consola de Lambda muestra un panel básico. Puede personalizar esta página
definiendo tableros personalizados en su plantilla de aplicación. Si su plantilla incluye uno o varios paneles,
la página le mostrará sus paneles en lugar del panel predeterminado. Puede cambiar entre los paneles con
el menú desplegable en la parte superior derecha de la página.
Resources:
MyDashboard:
Type: AWS::CloudWatch::Dashboard
Properties:
DashboardName: my-dashboard
DashboardBody: |
{
"widgets": [
{
"type": "metric",
"width": 12,
"height": 6,
145
AWS Lambda Guía para desarrolladores
Paneles personalizados de monitorización
"properties": {
"metrics": [
[
"AWS/Lambda",
"Invocations",
"FunctionName",
"my-function",
{
"stat": "Sum",
"label": "MyFunction"
}
],
[
{
"expression": "SUM(METRICS())",
"label": "Total Invocations"
}
]
],
"region": "us-east-1",
"title": "Invocations",
"view": "timeSeries",
"stacked": false
}
}
]
}
Puede obtener la definición de cualquiera de los widgets del panel de monitorización predeterminado
desde la consola de CloudWatch.
5. Elija Source.
Para obtener más información acerca de la creación de paneles y widgets de CloudWatch, consulte
Estructura y sintaxis del cuerpo del panel en la Referencia de la API de Amazon CloudWatch.
146
AWS Lambda Guía para desarrolladores
Tutorial: Crear una aplicación
La canalización asigna una única ramificación de un repositorio a una única pila de aplicación. Puede
crear canalizaciones adicionales para agregar entornos para otras ramificaciones del mismo repositorio.
También puede añadir etapas a la canalización para pruebas, ensayo y las aprobaciones manuales. Para
obtener más información sobre AWS CodePipeline, consulte ¿Qué es AWS CodePipeline?.
Secciones
• Requisitos previos (p. 148)
• Cree una aplicación (p. 148)
• Describe cómo invocar la función. (p. 149)
• Añadir un recurso de AWS (p. 150)
• Actualizar el límite de permisos (p. 152)
• Actualizar el código de la función (p. 152)
• Pasos siguientes (p. 154)
• Solución de problemas (p. 154)
147
AWS Lambda Guía para desarrolladores
Requisitos previos
Requisitos previos
En este tutorial, se le presuponen algunos conocimientos sobre las operaciones básicas de Lambda y la
consola de Lambda. Si aún no lo ha hecho, siga las instrucciones que se indican en Introducción a AWS
Lambda (p. 3) para crear la primera función de Lambda.
Para seguir los procedimientos de esta guía, necesitará un shell o un terminal de línea de comando donde
pueda ejecutar los comandos. Los comandos aparecen en listas y van precedidos del símbolo del sistema
($) y del nombre del directorio actual, si es aplicable:
Para los comandos largos, se utiliza un carácter de escape (\) para dividir un comando en varias líneas.
En Linux y macOS, use su administrador de shell y paquetes preferido. En Windows 10, puede instalar
Windows Subsystem para Linux para obtener una versión de Ubuntu y Bash integrada con Windows.
Este tutorial utiliza CodeCommit para el control de código fuente. Para configurar el equipo local para
acceder y actualizar el código de la aplicación, consulte Configuración en la Guía del usuario de AWS
CodeCommit.
Lambda crea la canalización y los recursos relacionados y confirma el código de la aplicación de muestra
en el repositorio de Git. A medida que se crean los recursos, aparecen en la página de información
general.
148
AWS Lambda Guía para desarrolladores
Describe cómo invocar la función.
La pila Infraestructura contiene el repositorio, el proyecto de compilación y otros recursos que se combinan
para formar una canalización de entrega continua. Cuando esta pila termina de implementarse, a su vez
implementa la pila de aplicación que contiene la función y el rol de ejecución. Estos son los recursos de la
aplicación que aparecen en Recursos.
La consola de Lambda ejecuta la función y muestra el resultado. Expanda la sección Details (Detalles)
debajo del resultado para ver los detalles de salida y ejecución.
149
AWS Lambda Guía para desarrolladores
Añadir un recurso de AWS
...
Resources:
ddbTable:
Type: AWS::Serverless::SimpleTable
Properties:
150
AWS Lambda Guía para desarrolladores
Añadir un recurso de AWS
PrimaryKey:
Name: id
Type: String
ProvisionedThroughput:
ReadCapacityUnits: 1
WriteCapacityUnits: 1
helloFromLambdaFunction:
Type: AWS::Serverless::Function
Properties:
CodeUri: ./
Handler: src/handlers/hello-from-lambda.helloFromLambdaHandler
Runtime: nodejs10.x
MemorySize: 128
Timeout: 60
Description: A Lambda function that returns a static string.
Environment:
Variables:
DDB_TABLE: !Ref ddbTable
Policies:
- DynamoDBCrudPolicy:
TableName: !Ref ddbTable
- AWSLambdaBasicExecutionRole
151
AWS Lambda Guía para desarrolladores
Actualizar el límite de permisos
Para que la función utilice el permiso de DynamoDB que agregó a su rol de ejecución en el paso anterior,
debe extender el límite de permisos para permitir los permisos adicionales. La consola de Lambda detecta
recursos que no están en el límite de permisos y proporciona una directiva actualizada que puede usar
para actualizarla.
Para obtener más información sobre los límites de permisos, consulte Uso de límites de permisos para
aplicaciones de AWS Lambda (p. 50).
Example src/handlers/index.js
const response = {
body: JSON.stringify(message)
152
AWS Lambda Guía para desarrolladores
Actualizar el código de la función
};
console.log(`body: ${response.body}`);
return response;
}
Example template.yml
...
helloFromLambdaFunction:
Type: AWS::Serverless::Function
Properties:
CodeUri: ./
Handler: src/handlers/index.handler
Runtime: nodejs10.x
Después de implementar el cambio de código, invoque la función varias veces para actualizar la tabla
DynamoDB.
Lambda crea instancias adicionales de su función para manejar múltiples invocaciones simultáneas.
Cada flujo de registro en el grupo de registros de CloudWatch Logs corresponde a una instancia de
función. También se crea una nueva instancia de función cuando se cambia el código o la configuración
de la función. Para obtener más información sobre el escalado, consulte Escalado de funciones de AWS
Lambda (p. 114).
153
AWS Lambda Guía para desarrolladores
Pasos siguientes
Pasos siguientes
La plantilla de AWS CloudFormation que define los recursos de la aplicación utiliza la transformación de
Modelo de aplicación sin servidor de AWS para simplificar la sintaxis de las definiciones de recursos y
automatizar la carga del paquete de implementación y otros artefactos. AWS SAM también proporciona
una interfaz de línea de comandos (la CLI de AWS SAM), que tiene la misma funcionalidad de
empaquetado e implementación que la AWS CLI, con características adicionales específicas para las
aplicaciones Lambda. Utilice la CLI de AWS SAM para probar su aplicación localmente en un contenedor
Docker que emula el entorno de ejecución de Lambda.
AWS Cloud9 proporciona un entorno de desarrollo online que incluye Node.js, la CLI de AWS SAM
y Docker. Con AWS Cloud9, puede comenzar a desarrollar rápidamente y acceder a su entorno de
desarrollo desde cualquier equipo. Para obtener instrucciones, consulte Introducción en la Guía del usuario
de AWS Cloud9.
Para el desarrollo local, los conjuntos de herramientas de AWS para entornos de desarrollo integrados
(IDE) le permiten probar y depurar funciones antes de insertarlas en su repositorio.
• AWS Toolkit for JetBrains: plugin para IDE de PyCharm (Python) e IntelliJ (Java).
• AWS Toolkit for Eclipse: plugin para IDE de Eclipse (varios idiomas).
• AWS Toolkit for Visual Studio Code: plugin para IDE de Visual Studio Code (varios idiomas).
• AWS Toolkit for Visual Studio: plugin para IDE de Visual Studio (varios idiomas).
Solución de problemas
A medida que desarrolle su aplicación, es probable que encuentre los siguientes tipos de errores.
• Errores de compilación: problemas que se producen durante la fase de compilación, incluidos errores de
compilación, prueba y empaquetado.
• Errores de implementación: problemas que se producen cuando AWS CloudFormation no puede
actualizar la pila de aplicaciones. Estos incluyen errores de permisos, cuotas de cuenta, problemas de
servicio o errores de plantilla.
• Errores de invocación: errores devueltos por el código o tiempo de ejecución de una función.
Para los errores de implementación que se producen durante la acción ExecuteChangeSet, la canalización
se vincula a una lista de eventos de pila en la consola de AWS CloudFormation. Busque un evento con
154
AWS Lambda Guía para desarrolladores
Eliminar recursos
el estado UPDATE_FAILED. Dado que AWS CloudFormation vuelve al estado anterior después de un
error, el evento pertinente está debajo de otros eventos en la lista. Si AWS CloudFormation no pudo crear
un conjunto de cambios, el error aparece en Change sets (Conjuntos de cambios) en lugar de en Events
(Eventos).
Una causa común de errores de implementación e invocación es la falta de permisos en uno o más roles.
La canalización tiene un rol para implementaciones (CloudFormationRole) equivalente a los permisos
de usuario (p. 42) que utilizaría para actualizar una pila de AWS CloudFormation directamente. Si agrega
recursos a la aplicación o habilita características de Lambda que requieren permisos de usuario, se
utiliza el rol de implementación. Puede encontrar un vínculo al rol de implementación en Infrastructure
(Infraestructura) en la información general de la aplicación.
Si su función accede a otros servicios o recursos de AWS, o si habilita las características que requieren
que la función tenga permisos adicionales, se utilizará el rol de ejecución (p. 33) de la función. Todos los
roles de ejecución que se crean en la plantilla de aplicación también están sujetos al límite de permisos de
la aplicación. Este límite requiere que conceda explícitamente acceso a servicios y recursos adicionales en
IAM después de agregar permisos al rol de ejecución en la plantilla.
Por ejemplo, para conectar una función a una nube privada virtual (p. 81) (VPC), necesita permisos
de usuario para describir los recursos de VPC. El rol de ejecución necesita permiso para administrar
interfaces de red. Esto requiere los siguientes pasos.
Después de corregir los errores de permisos, elija Release change (Cambio de versión) en la información
general de la canalización para volver a ejecutar la compilación y la implementación.
Eliminar recursos
Puede seguir modificando y utilizar la muestra para desarrollar su propia aplicación. Si ha terminado
de usar la muestra, elimine la aplicación para evitar pagar por la canalización, el repositorio y el
almacenamiento.
1. Abra la Log groups page (Página del grupo de registros) de la consola de Amazon CloudWatch.
2. Elija el grupo de registros de la función (/aws/lambda/my-app-
helloFromLambdaFunction-YV1VXMPLK7QK).
3. Elija Actions (Acciones) y, a continuación, elija Delete log group (Eliminar grupo de registro).
4. Elija Yes, Delete (Sí, eliminar).
155
AWS Lambda Guía para desarrolladores
Implementaciones continuas
Para configurar una implementación continua utilice AWS CodeDeploy y AWS SAM. CodeDeploy es un
servicio que automatiza las implementaciones de aplicaciones en plataformas informáticas de Amazon
como Amazon EC2 y AWS Lambda. Para obtener más información, consulte ¿Qué es CodeDeploy?. Al
utilizar CodeDeploy para implementar la función de Lambda, puede monitorizar fácilmente el estado de la
implementación e iniciar una restauración si detecta algún problema.
AWS SAM es un marco de código abierto para crear aplicaciones sin servidor. Cree una plantilla de
AWS SAM (en formato YAML) para especificar la configuración de los componentes necesarios para la
implementación continua. AWS SAM utiliza la plantilla para crear y configurar los componentes. Para
obtener más información, consulte ¿Qué es el modelo de aplicación sin servidor de AWS?.
AWSTemplateFormatVersion : '2010-09-09'
Transform: AWS::Serverless-2016-10-31
Description: A sample SAM template for deploying Lambda functions.
Resources:
# Details about the myDateTimeFunction Lambda function
myDateTimeFunction:
Type: AWS::Serverless::Function
Properties:
Handler: myDateTimeFunction.handler
Runtime: nodejs12.x
# Creates an alias named "live" for the function, and automatically publishes when you
update the function.
AutoPublishAlias: live
DeploymentPreference:
# Specifies the deployment configuration
Type: Linear10PercentEvery2Minutes
Esta plantilla define una función de Lambda denominada myDateTimeFunction con las siguientes
propiedades.
156
AWS Lambda Guía para desarrolladores
Casos de uso
AutoPublishAlias
La propiedad AutoPublishAlias crea un alias denominado live. Además, el marco de AWS SAM
detecta automáticamente cuando guarda código nuevo para la función. A continuación, el marco
publica una nueva versión de función y actualiza el alias live para que apunte a la nueva versión.
DeploymentPreference
Para obtener un tutorial detallado sobre cómo utilizar CodeDeploy con funciones de Lambda, consulte
Implementación de una función de Lambda actualizada con CodeDeploy.
• Procesamiento de archivos: supongamos que tiene una aplicación de uso compartido de fotografías. Los
usuarios utilizan la aplicación para cargar fotografías, y esta las almacena en un bucket de Amazon S3.
A continuación, la aplicación crea una versión en miniatura las fotografías de cada usuario y las muestra
en la página de perfil del usuario. En este caso, puede optar por crear una función de Lambda para crear
una miniatura automáticamente. Amazon S3 es uno de los orígenes de eventos de AWS que pueden
publicar eventos de creación de objetos e invocar una función de Lambda. El código de la función de
Lambda puede leer el objeto de fotografía del bucket de S3, crear una versión en miniatura y guardarla
en otro bucket de S3.
• Datos y análisis: supongamos que está creando una aplicación de análisis, y que almacena los datos
sin procesar en una tabla de DynamoDB. Cuando se escriben, actualizan o eliminan elementos de
una tabla, los flujos de DynamoDB pueden publicar eventos de actualización de elementos en un flujo
asociado a la tabla. En este caso, los datos del evento proporcionan la clave del elemento, el nombre del
evento (por ejemplo, insert, update y delete) y otros detalles. Puede escribir una función de Lambda que
genere métricas personalizadas agregando los datos sin procesar.
• Sitios web: supongamos que está creando un sitio web y que desea alojar la lógica del backend en
Lambda. Puede invocar la función de Lambda a través de HTTP utilizando Amazon API Gateway como
punto de enlace HTTP. A continuación, el cliente web puede invocar la API y, por último, API Gateway
puede dirigir la solicitud a Lambda.
• Aplicaciones móviles: supongamos que tiene una aplicación móvil personalizada que produce
eventos. Puede crear una función de Lambda para procesar los eventos publicados por la aplicación
personalizada. Por ejemplo, en este caso, puede configurar una función de Lambda para procesar los
clics que se realizan en la aplicación móvil personalizada.
AWS Lambda admite muchos servicios de AWS como orígenes de eventos. Para obtener más información,
consulte Utilización de AWS Lambda con otros servicios (p. 163). Cuando se configuran estos orígenes
157
AWS Lambda Guía para desarrolladores
Ejemplo 1: Amazon S3 envía eventos
e invoca una función de Lambda
de eventos para activar una función de Lambda, la función de Lambda se invoca automáticamente cuando
se producen los eventos. Debe definir el mapeo de orígenes de eventos, que es la forma de identificar los
eventos cuyo seguimiento se desea realizar y la función de Lambda que se debe invocar.
Puede configurar Amazon S3 para que invoque la función como una acción de notificación del bucket. Para
conceder a Amazon S3 permisos para invocar la función, actualice la política basada en recursos (p. 37)
de la función.
158
AWS Lambda Guía para desarrolladores
Prácticas recomendadas
En el siguiente diagrama se muestra cómo una aplicación personalizada escribe registros en un flujo de
Kinesis.
Cuando trabaje con orígenes de eventos basados en flujos, debe crear mapeos de orígenes de eventos en
AWS Lambda. Lambda lee los elementos del flujo e invoca la función de forma síncrona. No es necesario
que conceda a Lambda permiso para invocar la función, pero esta necesita permiso para leer los datos del
flujo.
Temas
• Código de función (p. 159)
• Función de configuración (p. 160)
• Métricas y alarmas (p. 161)
• Uso de secuencias (p. 161)
Código de función
• Separe el controlador de Lambda de la lógica del núcleo. Esto le permite probar las distintas unidades de
la función con mayor facilidad. En Node.js, podría tener este aspecto:
159
AWS Lambda Guía para desarrolladores
Función de configuración
callback(null, result);
}
Para evitar posibles filtraciones de datos entre las invocaciones, no utilice el contexto de ejecución para
almacenar datos de usuario, eventos u otra información con implicaciones de seguridad. Si su función se
basa en un estado mutable que no se puede almacenar en la memoria dentro del controlador, considere
crear una función independiente o versiones independientes de una función para cada usuario.
• Utilice variables de entorno (p. 56) para pasar parámetros operativos a su función. Por ejemplo, si está
escribiendo en un bucket de Amazon S3, en lugar de codificar de forma rígida el nombre del bucket,
configúrelo como una variable de entorno.
• Controle las dependencias del paquete de implementación de la función. El entorno de ejecución
de AWS Lambda contiene una serie de bibliotecas, como el SDK de AWS para los tiempos de
ejecución de Node.js y Python (puede encontrar una lista completa aquí: Tiempos de ejecución de
AWS Lambda. (p. 130)). Para disponer del conjunto más reciente de características y actualizaciones
de seguridad, Lambda actualizará periódicamente estas bibliotecas. Estas actualizaciones pueden
introducir cambios sutiles en el comportamiento de la función de Lambda. Para disponer de un control
total de las dependencias que utiliza la función, empaquete todas las dependencias con el paquete de
implementación.
• Minimice el tamaño del paquete de implementación de acuerdo con las necesidades de su tiempo de
ejecución. Esto reducirá la cantidad de tiempo que tarda el paquete de implementación en descargarse
y desempaquetarse antes de la invocación. En las funciones creadas en Java o .NET Core, evite cargar
toda la biblioteca del SDK de AWS como parte del paquete de implementación. En lugar de ello, cree
dependencias selectivas de los módulos que seleccionen los componentes del SDK que necesita (por
ejemplo, DynamoDB, módulos del SDK de Amazon S3 y bibliotecas básicas de Lambda).
• Reduzca el tiempo que tarda Lambda en desempaquetar los paquetes de implementación escritos
en Java colocando los archivos .jar de dependencias en un directorio /lib independiente. Esto es
más rápido que colocar todo el código de la función en un único archivo jar con un gran número de
archivos .class. Para obtener instrucciones, consulte Paquete de implementación de AWS Lambda en
Java (p. 386).
• Minimice la complejidad de las dependencias. Son preferibles los marcos de trabajo más sencillos, ya
que se cargan rápidamente al arrancar el contexto de ejecución (p. 132). Por ejemplo, es preferible
utilizar los marcos de trabajo de inserción de dependencias (IoC) de Java más sencillos, como Dagger o
Guice, que los más complejos, como Spring Framework.
• Evite utilizar código recursivo en la función de Lambda que haga que esta llame a sí misma
automáticamente hasta que se cumplan ciertos criterios arbitrarios. Esto podría producir un volumen no
intencionado de invocaciones de la función y costos elevados. Si lo hace accidentalmente, establezca el
límite de ejecuciones simultáneas de la función en 0 para limitar inmediatamente todas las invocaciones
a la función, mientras actualiza el código.
Función de configuración
• La prueba de desempeño de la función de Lambda es una parte crucial a la hora de garantizar la
elección de la configuración de memoria óptima. Cualquier aumento del tamaño de la memoria causa
un aumento equivalente de la CPU disponible para la función. El uso de la memoria de la función se
160
AWS Lambda Guía para desarrolladores
Métricas y alarmas
determina por invocación y puede visualizarse en AWS CloudWatch Logs. En cada invocación se genera
una entrada REPORT:, tal como se muestra a continuación:
Analice el campo Max Memory Used: para determinar si la función necesita más memoria o si ha
aprovisionado en exceso el tamaño de la memoria para la función.
• Realice una prueba de carga de la función de Lambda para determinar un valor de tiempo de espera
óptimo. Es importante analizar cuánto tiempo se ejecuta la función para determinar más fácilmente
los posibles problemas con un servicio de dependencias que puedan aumentar la concurrencia de la
función más allá de lo esperado. Esto es especialmente importante cuando la función de Lambda realiza
llamadas de red a recursos que pueden no gestionar el escalado de Lambda.
• Utilice los permisos más restrictivos al establecer las políticas de IAM. Conozca los recursos y las
operaciones que la función de Lambda necesita, y limite el rol de ejecución a estos permisos. Para
obtener más información, consulte Permisos de AWS Lambda (p. 33).
• Familiarícese con los Cuotas de AWS Lambda (p. 31). A menudo, el tamaño de carga, los descriptores
de archivo y el espacio de /tmp se pasan por alto a la hora de determinar los límites de recursos del
tiempo de ejecución.
• Elimine las funciones de Lambda que ya no utilice. Al hacerlo, las funciones no utilizadas no contarán
innecesariamente para el límite de tamaño del paquete de implementación.
• Si usa Amazon Simple Queue Service como origen de eventos, asegúrese de que el valor del tiempo de
ejecución esperado de la función no supere el valor de tiempo de espera de visibilidad en la cola. Esto
se aplica tanto a CreateFunction (p. 524) como a UpdateFunctionConfiguration (p. 667).
• En el caso de CreateFunction, AWS Lambda no realizará el proceso de creación de función.
• En el caso de UpdateFunctionConfiguration, podría dar lugar a invocaciones duplicadas de la función.
Métricas y alarmas
• Utilice Trabajar con métricas de funciones de AWS Lambda (p. 464) y Alarmas de CloudWatch en
lugar de crear o actualizar una métrica desde dentro de la función de código de Lambda. Es una forma
mucho más eficaz de realizar el seguimiento del estado de las funciones de Lambda, y le permitirá
identificar los problemas al comienzo del proceso de desarrollo. Por ejemplo, puede configurar una
alarma de acuerdo con la duración esperada del tiempo de ejecución de la función Lambda para
solucionar los cuellos de botella o las latencias atribuibles al código de la función.
• Utilice la biblioteca de registro y las dimensiones y métricas de AWS Lambda para detectar los errores
de las aplicaciones (por ejemplo, ERR, ERROR, WARNING, etc.)
Uso de secuencias
• Pruebe con diferentes tamaños de lote y de registro para que la frecuencia de sondeo de cada
origen de eventos se ajuste a la velocidad con la que la función es capaz de completar su tarea.
BatchSize (p. 518) controla el número máximo de registros que se pueden enviar a la función en
cada invocación. A menudo, un tamaño de lote mayor puede absorber de forma más eficiente el tráfico
adicional asociado a un conjunto de registros mayor, mejorando el desempeño.
De forma predeterminada, Lambda llama a su función en cuanto los registros están disponibles en el
flujo. Si el lote que lee desde el flujo solo tiene un registro, Lambda solo envía un registro a la función.
Para evitar invocar a la función con un número de registros pequeño, puede indicar al origen del evento
que almacene en búfer registros durante hasta 5 minutos configurando una ventana de lote. Antes de
invocar a la función, Lambda sigue leyendo registros desde el flujo hasta que haya recopilado un lote
completo o hasta que caduca la ventana de lote.
161
AWS Lambda Guía para desarrolladores
Uso de secuencias
162
AWS Lambda Guía para desarrolladores
Cada servicio que se integra con Lambda envía datos a la función como un evento con formato JSON.
La estructura del documento de evento es diferente para cada tipo de evento y contiene datos sobre el
recurso o la solicitud que activó la función. Los tiempos de ejecución de Lambda convierten el evento en un
objeto y se lo pasan a la función.
{
"requestContext": {
"elb": {
"targetGroupArn": "arn:aws:elasticloadbalancing:us-
east-2:123456789012:targetgroup/lambda-279XGJDqGZ5rsrHC2Fjr/49e9d65c45c6791a"
}
},
"httpMethod": "GET",
"path": "/lambda",
"queryStringParameters": {
"query": "1234ABCD"
},
"headers": {
"accept": "text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/
apng,*/*;q=0.8",
"accept-encoding": "gzip",
"accept-language": "en-US,en;q=0.9",
"connection": "keep-alive",
"host": "lambda-alb-123578498.us-east-2.elb.amazonaws.com",
"upgrade-insecure-requests": "1",
"user-agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML,
like Gecko) Chrome/71.0.3578.98 Safari/537.36",
"x-amzn-trace-id": "Root=1-5c536348-3d683b8b04734faae651f476",
"x-forwarded-for": "72.12.164.125",
"x-forwarded-port": "80",
"x-forwarded-proto": "http",
"x-imforwards": "20"
},
"body": "",
"isBase64Encoded": false
}
Note
El runtime de Lambda convierte el documento de evento en un objeto y se lo pasa al controlador
de la función (p. 18). Para los lenguajes compilados, Lambda proporciona las definiciones de los
tipos de eventos en una biblioteca. Consulte los temas siguientes para obtener más información.
163
AWS Lambda Guía para desarrolladores
En el caso de los servicios que generan una cola o un flujo de datos, debe crear un mapeo de origen de
eventos (p. 109) en Lambda y conceder a Lambda permiso para tener acceso al otro servicio en el rol de
ejecución (p. 33). Lambda lee los datos desde el otro servicio, crea un evento e invoca la función.
Los demás servicios invocan la función directamente. Debe conceder al otro servicio permiso en la política
basada en recursos (p. 37) de la función y configurar el otro servicio para que genere eventos e invoque
la función. En función del servicio, la invocación puede ser síncrona o asíncrona. Para la invocación
síncrona, el otro servicio espera la respuesta de la función y puede realizar reintentos si se producen
errores (p. 119).
Para la invocación asíncrona, Lambda coloca el evento en la cola antes de pasárselo a la función. El otro
servicio obtiene una respuesta de operación correcta en cuanto el evento se pone en cola y no está al
tanto de lo que ocurre después. Si se produce un error, Lambda gestiona los reintentos (p. 119) y puede
enviar los eventos con errores al destino (p. 104) que se haya configurado.
164
AWS Lambda Guía para desarrolladores
Alexa
Además, algunos servicios se integran con Lambda de otras maneras que no implican invocar funciones.
Consulte los temas de este capítulo para obtener más información sobre cada servicio y eventos de
ejemplo que puede utilizar para probar la función.
{
"header": {
"payloadVersion": "1",
"namespace": "Control",
"name": "SwitchOnOffRequest"
},
"payload": {
"switchControlAction": "TURN_ON",
"appliance": {
"additionalApplianceDetails": {
"key2": "value2",
"key1": "value1"
},
"applianceId": "sampleId"
},
"accessToken": "sampleAccessToken"
}
}
165
AWS Lambda Guía para desarrolladores
API Gateway
Con el desencadenador de API Gateway (Gateway de API) seleccionado en el diseñador, elija el punto de
enlace que va a invocar la función con API Gateway.
Las API de API Gateway se componen de etapas, recursos, métodos e integraciones. La etapa y el
recurso determinan la ruta del punto de enlace:
La integración de Lambda asigna una combinación de ruta y método HTTP a una función Lambda. Puede
configurar API Gateway para pasar el cuerpo de la solicitud HTTP tal cual (integración personalizada) o
para encapsular el cuerpo de la solicitud en un documento que incluya toda la información de la solicitud,
incluidos los encabezados, los recursos, la ruta y el método.
Amazon API Gateway invoca la función sincrónicamente (p. 100) con un evento que contiene una
representación JSON de la solicitud HTTP. En las integraciones personalizadas, el evento es el cuerpo de
la solicitud. En las integraciones de proxy, el evento tiene una estructura definida. En el siguiente ejemplo,
se muestra un evento proxy procedente de una API REST de API Gateway.
{
"resource": "/",
"path": "/",
166
AWS Lambda Guía para desarrolladores
API Gateway
"httpMethod": "GET",
"requestContext": {
"resourcePath": "/",
"httpMethod": "GET",
"path": "/Prod/",
...
},
"headers": {
"accept": "text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/
apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9",
"accept-encoding": "gzip, deflate, br",
"Host": "70ixmpl4fl.execute-api.us-east-2.amazonaws.com",
"User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML,
like Gecko) Chrome/80.0.3987.132 Safari/537.36",
"X-Amzn-Trace-Id": "Root=1-5e66d96f-7491f09xmpl79d18acf3d050",
...
},
"multiValueHeaders": {
"accept": [
"text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/
*;q=0.8,application/signed-exchange;v=b3;q=0.9"
],
"accept-encoding": [
"gzip, deflate, br"
],
...
},
"queryStringParameters": null,
"multiValueQueryStringParameters": null,
"pathParameters": null,
"stageVariables": null,
"body": null,
"isBase64Encoded": false
}
En este ejemplo, se muestra un evento de una solicitud GET en la ruta raíz de la etapa Prod de una API
REST. La forma y el contenido del evento varían según el tipo de API (p. 170) y la configuración.
API Gateway espera una respuesta de la función y transmite el resultado a la persona que llama. En las
integraciones personalizadas, debe definir una respuesta de integración y una respuesta de método para
convertir la salida de la función en una respuesta HTTP. En las integraciones de proxy, la función debe
responder con una representación de la respuesta en un formato específico.
En el ejemplo siguiente, se muestra un objeto response de una función Node.js. El objeto response
representa una respuesta HTTP correcta que contiene un documento JSON.
var response = {
"statusCode": 200,
"headers": {
"Content-Type": "application/json"
},
"isBase64Encoded": false,
"multiValueHeaders": {
"X-Custom-Header": ["My value", "My other value"],
},
"body": "{\n \"TotalCodeSize\": 104330022,\n \"FunctionCount\": 26\n}"
}
El tiempo de ejecución de Lambda serializa el objeto response en un archivo JSON y lo envía a la API. La
API analiza la respuesta y la utiliza para crear una respuesta HTTP, que luego envía al cliente que realizó
la solicitud original.
167
AWS Lambda Guía para desarrolladores
Permisos
Los recursos de la API definen uno o varios métodos, como GET o POST. Los métodos tienen una
integración que enruta las solicitudes a una función Lambda o a otro tipo de integración. Puede definir cada
recurso y cada método de manera individual, o utilizar tipos de recursos y métodos especiales para que
coincidan con todas las solicitudes que se ajustan a un patrón. Un recurso proxy captura todas las rutas
que hay debajo de un recurso. El método ANY captura todos los métodos HTTP.
Secciones
• Permisos (p. 168)
• Administración de errores con una API de API Gateway (p. 170)
• Elegir un tipo de API (p. 170)
• Aplicaciones de muestra (p. 172)
• Tutorial: uso de AWS Lambda con Amazon API Gateway (p. 172)
• Código de función de ejemplo (p. 181)
• Creación de un microservicio sencillo utilizando Lambda y API Gateway (p. 183)
• Plantilla de AWS SAM para una aplicación de API Gateway (p. 185)
Permisos
Amazon API Gateway necesita permiso para invocar la función desde la política basada en
recursos (p. 37) de la función. Puede conceder permiso de invocación a toda una API o conceder acceso
limitado a una etapa, un recurso o un método.
Cuando agrega una API a la función utilizando la consola de Lambda, la consola de API Gateway o una
plantilla de AWS SAM, la política basada en recursos de la función se actualiza automáticamente. En
el ejemplo siguiente, se muestra la política de una función con una instrucción agregada mediante una
plantilla de AWS SAM.
{
"Version": "2012-10-17",
"Id": "default",
"Statement": [
{
"Sid": "nodejs-apig-functiongetEndpointPermissionProd-BWDBXMPLXE2F",
"Effect": "Allow",
"Principal": {
"Service": "apigateway.amazonaws.com"
},
"Action": "lambda:InvokeFunction",
168
AWS Lambda Guía para desarrolladores
Permisos
"Resource": "arn:aws:lambda:us-east-2:123456789012:function:nodejs-apig-
function-1G3MXMPLXVXYI",
"Condition": {
"ArnLike": {
"AWS:SourceArn": "arn:aws:execute-api:us-east-2:123456789012:ktyvxmpls1/*/GET/"
}
}
}
]
}
Confirme la política de la función (p. 37) en la pestaña Permissions (Permisos) de la consola de Lambda.
Puede administrar manualmente los permisos de las políticas de funciones con las siguientes operaciones
de API:
Para conceder permiso de invocación a una API existente, utilice el comando add-permission.
Note
El ARN de origen de este ejemplo concede permiso a una integración del método GET del recurso raíz
en la etapa predeterminada de una API, con el ID mnh1xmpli7. Puede utilizar un asterisco en el ARN de
origen para conceder permisos a varias etapas, métodos o recursos.
Patrones de recursos
Para obtener información detallada acerca de cómo ver la política y quitar instrucciones, consulte Limpieza
de políticas basadas en recursos (p. 41).
169
AWS Lambda Guía para desarrolladores
Administración de errores con una API de API Gateway
En el ejemplo siguiente, se muestra un mapa de seguimiento de X-Ray de una solicitud que generó un
error de función y un error 502 de API Gateway. El cliente recibirá el mensaje de error genérico.
Para personalizar la respuesta del error, debe detectar errores en el código y elaborar una respuesta en el
formato que desee.
API Gateway convierte esta respuesta en un error HTTP con un código de estado y un cuerpo
personalizados. En el mapa de seguimiento, el nodo de la función es verde porque el error se administró
correctamente.
170
AWS Lambda Guía para desarrolladores
Elegir un tipo de API
Las API HTTP y REST son API RESTful que procesan solicitudes HTTP y devuelven respuestas. Las
API HTTP son más recientes y se construyen con la API de la versión 2 de API Gateway. Las siguientes
características son nuevas en las API HTTP:
Las API REST son las API RESTful clásicas que API Gateway admite desde su lanzamiento. En la
actualidad, las API REST tienen más características de personalización, integración y administración.
• Tipos de integración: las API REST son compatibles con las integraciones de Lambda personalizadas.
Con una integración personalizada, puede enviar solo el cuerpo de la solicitud a la función o aplicar una
plantilla de transformación al cuerpo de la solicitud antes de enviarla a la función.
• Control de acceso: las API REST admiten más opciones de autenticación y autorización.
• Monitoreo y seguimiento: la API REST admiten el seguimiento de AWS X-Ray y otras opciones de
registro.
Para ver una comparativa detallada, consulte Elección entre HTTP API y REST API en la Guía para
desarrolladores de API Gateway.
Las API de WebSocket también usan la API de la versión 2 de API Gateway y admiten un conjunto de
características similares. Utilice una API de WebSocket para las aplicaciones que se benefician de una
conexión persistente entre el cliente y la API. Las API de WebSocket proporcionan comunicación dúplex
completa, lo que significa que tanto el cliente como la API pueden enviar mensajes continuamente sin
esperar una respuesta.
Las API HTTP admiten un formato de evento simplificado (versión 2.0). En el ejemplo siguiente, se
muestra el evento de una API HTTP.
{
"version": "2.0",
"routeKey": "ANY /nodejs-apig-function-1G3XMPLZXVXYI",
"rawPath": "/default/nodejs-apig-function-1G3XMPLZXVXYI",
"rawQueryString": "",
"cookies": [
"s_fid=7AABXMPL1AFD9BBF-0643XMPL09956DE2",
"regStatus=pre-register"
],
"headers": {
171
AWS Lambda Guía para desarrolladores
Aplicaciones de muestra
"accept": "text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/
apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9",
"accept-encoding": "gzip, deflate, br",
...
},
"requestContext": {
"accountId": "123456789012",
"apiId": "r3pmxmplak",
"domainName": "r3pmxmplak.execute-api.us-east-2.amazonaws.com",
"domainPrefix": "r3pmxmplak",
"http": {
"method": "GET",
"path": "/default/nodejs-apig-function-1G3XMPLZXVXYI",
"protocol": "HTTP/1.1",
"sourceIp": "205.255.255.176",
"userAgent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36
(KHTML, like Gecko) Chrome/80.0.3987.132 Safari/537.36"
},
"requestId": "JKJaXmPLvHcESHA=",
"routeKey": "ANY /nodejs-apig-function-1G3XMPLZXVXYI",
"stage": "default",
"time": "10/Mar/2020:05:16:23 +0000",
"timeEpoch": 1583817383220
},
"isBase64Encoded": true
}
Para obtener más información, consulte este artículo sobre las integraciones de AWS Lambda en la Guía
para desarrolladores de API Gateway.
Aplicaciones de muestra
El repositorio de GitHub para esta guía incluye la siguiente aplicación de ejemplo de API Gateway.
• API Gateway con Node.js: función con una plantilla de AWS SAM que crea una API REST que tiene el
seguimiento de AWS X-Ray habilitado. Incluye scripts para implementar, invocar la función, probar la API
y limpiar.
Lambda también dispone de proyectos (p. 28) y plantillas (p. 29) que puede utilizar para crear una
aplicación de API Gateway en la consola de Lambda.
El método POST del recurso DynamoDBManager admite las siguientes operaciones de DynamoDB:
172
AWS Lambda Guía para desarrolladores
Tutorial
La carga de solicitud que se envía en la solicitud POST identifica la operación de DynamoDB y proporciona
los datos necesarios. Por ejemplo:
• A continuación se muestra una carga de solicitud de ejemplo para una operación create item de
DynamoDB:
{
"operation": "create",
"tableName": "lambda-apigateway",
"payload": {
"Item": {
"id": "1",
"name": "Bob"
}
}
}
• A continuación se muestra una carga de solicitud de ejemplo para una operación read item de
DynamoDB:
{
"operation": "read",
"tableName": "lambda-apigateway",
"payload": {
"Key": {
"id": "1"
}
}
}
• A continuación se muestra una carga de solicitud de ejemplo para una operación echo. Envía una
solicitud HTTP POST al punto de enlace usando los datos siguientes en el cuerpo de la solicitud.
{
"operation": "echo",
"payload": {
"somekey1": "somevalue1",
"somekey2": "somevalue2"
}
}
Note
• Transferencia de la solicitud completa: una función de Lambda puede recibir la solicitud HTTP
completa (en lugar de solo el cuerpo de la solicitud) y establecer la respuesta HTTP (en lugar
de solo el cuerpo de la respuesta) utilizando el tipo de integración AWS_PROXY.
• Métodos catch-all: mapea todos los métodos de un recurso de la API a una sola función de
Lambda con un único mapeo, utilizando el método catch-all ANY.
• Recursos catch-all: mapea todas las subrutas de un recurso a una función de Lambda sin
necesidad de realizar ninguna configuración adicional, mediante el nuevo parámetro de ruta
({proxy+}).
Para obtener más información acerca de estas características de la gateway API, consulte
Configuración de la integración del proxy para un recurso de proxy.
173
AWS Lambda Guía para desarrolladores
Tutorial
Requisitos previos
En este tutorial, se le presuponen algunos conocimientos sobre las operaciones básicas de Lambda y la
consola de Lambda. Si aún no lo ha hecho, siga las instrucciones que se indican en Introducción a AWS
Lambda (p. 3) para crear la primera función de Lambda.
Para seguir los procedimientos de esta guía, necesitará un shell o un terminal de línea de comando donde
pueda ejecutar los comandos. Los comandos aparecen en listas y van precedidos del símbolo del sistema
($) y del nombre del directorio actual, si es aplicable:
Para los comandos largos, se utiliza un carácter de escape (\) para dividir un comando en varias líneas.
En Linux y macOS, use su administrador de shell y paquetes preferido. En Windows 10, puede instalar
Windows Subsystem para Linux para obtener una versión de Ubuntu y Bash integrada con Windows.
{
"Version": "2012-10-17",
"Statement": [
{
"Sid": "Stmt1428341300017",
"Action": [
"dynamodb:DeleteItem",
"dynamodb:GetItem",
"dynamodb:PutItem",
"dynamodb:Query",
"dynamodb:Scan",
"dynamodb:UpdateItem"
],
"Effect": "Allow",
"Resource": "*"
},
{
"Sid": "",
"Resource": "*",
"Action": [
"logs:CreateLogGroup",
"logs:CreateLogStream",
"logs:PutLogEvents"
],
"Effect": "Allow"
}
]
174
AWS Lambda Guía para desarrolladores
Tutorial
La política personalizada tiene los permisos que la función necesita para escribir datos a DynamoDB y
subir registros. Anote el nombre de recurso de Amazon (ARN) del rol para uso posterior.
Creación de la función
A continuación se muestra código de ejemplo que recibe un evento de API Gateway como entrada y
procesa los mensajes que contiene. Con fines ilustrativos, el código escribe parte de los datos de los
eventos de entrada en CloudWatch Logs.
Note
Para ver código de muestra en otros lenguajes, consulte Código de función de ejemplo (p. 181).
Example index.js
console.log('Loading function');
/**
* Provide an event that contains the following keys:
*
* - operation: one of the operations in the switch statement below
* - tableName: required for operations that interact with DynamoDB
* - payload: a parameter to pass to the operation being performed
*/
exports.handler = function(event, context, callback) {
//console.log('Received event:', JSON.stringify(event, null, 2));
if (event.tableName) {
event.payload.TableName = event.tableName;
}
switch (operation) {
case 'create':
dynamo.put(event.payload, callback);
break;
case 'read':
dynamo.get(event.payload, callback);
break;
case 'update':
dynamo.update(event.payload, callback);
break;
case 'delete':
dynamo.delete(event.payload, callback);
break;
case 'list':
dynamo.scan(event.payload, callback);
break;
case 'echo':
callback(null, "Success");
break;
case 'ping':
callback(null, "pong");
break;
default:
callback('Unknown operation: ${operation}');
}
175
AWS Lambda Guía para desarrolladores
Tutorial
};
{
"operation": "echo",
"payload": {
"somekey1": "somevalue1",
"somekey2": "somevalue2"
}
}
En primer lugar, debe crear una API (DynamoDBOperations) utilizando Amazon API Gateway con un
recurso (DynamoDBManager) y un método (POST). A continuación, asociará el método POST a la función
de Lambda. Y, por último, probará la experiencia integral.
Cree el API
Ejecute el siguiente comando create-rest-api para crear la API DynamoDBOperations para este
tutorial.
176
AWS Lambda Guía para desarrolladores
Tutorial
Guarde el ID de API para su uso en comandos futuros. También necesita el ID del recurso raíz de la API.
Para obtener el ID, ejecute el comando get-resources.
$ API=bs8fqo6bp0
$ aws apigateway get-resources --rest-api-id $API
{
"items": [
{
"path": "/",
"id": "e8kitthgdb"
}
]
}
En ese momento solo tiene el recurso raíz, pero añadirá más recursos en el siguiente paso.
$ RESOURCE=iuig5w
$ aws apigateway put-method --rest-api-id $API --resource-id $RESOURCE \
--http-method POST --authorization-type NONE
{
"apiKeyRequired": false,
"httpMethod": "POST",
"authorizationType": "NONE"
}
177
AWS Lambda Guía para desarrolladores
Tutorial
$ REGION=us-east-2
$ ACCOUNT=123456789012
$ aws apigateway put-integration --rest-api-id $API --resource-id $RESOURCE \
--http-method POST --type AWS --integration-http-method POST \
--uri arn:aws:apigateway:$REGION:lambda:path/2015-03-31/functions/arn:aws:lambda:$REGION:
$ACCOUNT:function:LambdaFunctionOverHttps/invocations
{
"type": "AWS",
"httpMethod": "POST",
"uri": "arn:aws:apigateway:us-east-2:lambda:path/2015-03-31/functions/
arn:aws:lambda:us-east-2:123456789012:function:LambdaFunctionOverHttps/invocations",
"passthroughBehavior": "WHEN_NO_MATCH",
"timeoutInMillis": 29000,
"cacheNamespace": "iuig5w",
"cacheKeyParameters": []
}
--integration-http-method es el método que usa API Gateway para comunicarse con AWS
Lambda. --uri es identificador único para el punto de enlace al cual Amazon API Gateway puede mandar
solicitud.
• Ejecute el siguiente comando para establecer la respuesta del método POST en JSON. Este es el tipo de
respuesta que devuelve el método de la API.
• Ejecute el siguiente comando para establecer la respuesta de integración del método POST en JSON.
Este es el tipo de respuesta que devuelve la función de Lambda.
178
AWS Lambda Guía para desarrolladores
Tutorial
Implementar la API
En este paso, implementará la API que ha creado en una etapa denominada prod.
Para ello, debe añadir un permiso a la política de permisos asociada a la función de Lambda. Ejecute el
siguiente comando add-permission de AWS Lambda para conceder a la entidad principal del servicio
de Amazon API Gateway (apigateway.amazonaws.com) permisos para invocar la función de Lambda
(LambdaFunctionOverHttps).
Debe conceder este permiso para poder realizar pruebas (si va a Amazon API Gateway y elige Test
(Probar) para probar el método de la API, necesitará este permiso). Observe que --source-arn
especifica un carácter comodín (*) como valor para la etapa (indica que solo es para pruebas). Esto le
permite hacer pruebas sin implementar la API.
Note
Si la función y la API se encuentran en regiones diferentes, el identificador de región en el ARN
del origen debe coincidir con la región de la función, no la región de la API.
Ahora, ejecute el mismo comando de nuevo, pero esta vez conceda a la API implementada permisos para
invocar la función de Lambda.
Puede conceder este permiso para que la API implementada tenga permisos para invocar la función de
Lambda. Observe que --source-arn especifica prod, que es el nombre de la etapa que se utilizó al
implementar la API.
179
AWS Lambda Guía para desarrolladores
Tutorial
Puede utilizar comandos de la CLI de Amazon API Gateway para enviar una solicitud de HTTP POST al
punto de enlace del recursoDynamoDBManager. Dado que ha implementado su Amazon API Gateway,
puede utilizar Curl para invocar los métodos para realizar la misma operación.
La función de Lambda permite utilizar la operación create para crear un elemento en la tabla de
DynamoDB. Para solicitar esta operación, utilice el siguiente JSON:
Example create-item.json
{
"operation": "create",
"tableName": "lambda-apigateway",
"payload": {
"Item": {
"id": "1234ABCD",
"number": 5
}
}
}
Para enviar la solicitud para la operación echo que admite la función de Lambda, puede utilizar la
siguiente carga de solicitud:
180
AWS Lambda Guía para desarrolladores
Código de muestra
Example echo.json
{
"operation": "echo",
"payload": {
"somekey1": "somevalue1",
"somekey2": "somevalue2"
}
}
Guarde la información de pruebas en un archivo llamado echo.json. Ejecute el comando CLI de Amazon
API Gateway test-invoke-method para enviar una solicitud de método HTTP POST al punto de enlace
recursoDynamoDBManagerusando el JSON anterior en el cuerpo de solicitud.
Temas
• Node.js (p. 181)
• Python 3 (p. 182)
• Go (p. 183)
Node.js
El siguiente ejemplo procesa mensajes desde API Gateway y administra documentos DynamoDB basados
en el método requerido.
Example index.js
console.log('Loading function');
/**
* Provide an event that contains the following keys:
*
* - operation: one of the operations in the switch statement below
* - tableName: required for operations that interact with DynamoDB
* - payload: a parameter to pass to the operation being performed
*/
exports.handler = function(event, context, callback) {
//console.log('Received event:', JSON.stringify(event, null, 2));
181
AWS Lambda Guía para desarrolladores
Código de muestra
if (event.tableName) {
event.payload.TableName = event.tableName;
}
switch (operation) {
case 'create':
dynamo.put(event.payload, callback);
break;
case 'read':
dynamo.get(event.payload, callback);
break;
case 'update':
dynamo.update(event.payload, callback);
break;
case 'delete':
dynamo.delete(event.payload, callback);
break;
case 'list':
dynamo.scan(event.payload, callback);
break;
case 'echo':
callback(null, "Success");
break;
case 'ping':
callback(null, "pong");
break;
default:
callback('Unknown operation: ${operation}');
}
};
Comprima el código de muestra para crear un paquete de implementación. Para obtener instrucciones,
consulte Paquete de implementación de AWS Lambda en Node.js (p. 336).
Python 3
El siguiente ejemplo procesa mensajes desde API Gateway y administra documentos DynamoDB basados
en el método requerido.
Example LambdaFunctionOverHttps.py
import boto3
import json
print('Loading function')
operation = event['operation']
if 'tableName' in event:
dynamo = boto3.resource('dynamodb').Table(event['tableName'])
182
AWS Lambda Guía para desarrolladores
Proyecto de microservicio
operations = {
'create': lambda x: dynamo.put_item(**x),
'read': lambda x: dynamo.get_item(**x),
'update': lambda x: dynamo.update_item(**x),
'delete': lambda x: dynamo.delete_item(**x),
'list': lambda x: dynamo.scan(**x),
'echo': lambda x: x,
'ping': lambda x: 'pong'
}
if operation in operations:
return operations[operation](event.get('payload'))
else:
raise ValueError('Unrecognized operation "{}"'.format(operation))
Comprima el código de muestra para crear un paquete de implementación. Para obtener instrucciones,
consulte Paquete de implementación de AWS Lambda en Python (p. 352).
Go
El siguiente ejemplo procesa mensajes desde API Gateway y registra información basada en la petición.
Example LambdaFunctionOverHttps.go
import (
"strings"
"github.com/aws/aws-lambda-go/events"
)
fmt.Println("Headers:")
for key, value := range request.Headers {
fmt.Printf(" %s: %s\n", key, value)
}
Compile el ejecutable con go build y cree un paquete de implementación. Para obtener instrucciones,
consulte Paquete de implementación de AWS Lambda en Go (p. 417).
183
AWS Lambda Guía para desarrolladores
Proyecto de microservicio
• Nombre – lambda-microservice.
• Rol – Crear un rol nuevo a partir de una o varias plantillas.
• Role name (Nombre de rol): lambda-apigateway-role.
• Plantillas de política – Simple microservice permissions (Permisos de microservicio simples).
• API – Crear un nuevo API.
• Seguridad – Abrir.
Cuando complete el asistente y cree la función, Lambda crea un recurso proxy llamado lambda-
microservice bajo el nombre API seleccionado. Para obtener más información acerca de los recursos
de proxy, consulte Configuración de la integración de proxy para un recurso de proxy.
Un recurso de proxy tiene un tipo de integración AWS_PROXY y un método catch-all ANY. El tipo de
integración AWS_PROXY aplica una plantilla de mapeo predeterminada para pasar toda la solicitud a la
función de Lambda y transforma la salida de la función de Lambda en respuestas HTTP. El método ANY
define la misma configuración de integración para todos los métodos admitidos, incluidos GET, POST,
PATCH, DELETE y otros.
{
"httpMethod": "GET",
"queryStringParameters": {
"TableName": "MyTable"
}
}
184
AWS Lambda Guía para desarrolladores
Plantilla de muestra
Example template.yaml
AWSTemplateFormatVersion: '2010-09-09'
Transform: AWS::Serverless-2016-10-31
Resources:
LambdaFunctionOverHttps:
Type: AWS::Serverless::Function
Properties:
Handler: index.handler
Runtime: nodejs12.x
Policies: AmazonDynamoDBFullAccess
Events:
HttpPost:
Type: Api
Properties:
Path: '/DynamoDBOperations/DynamoDBManager'
Method: post
Para obtener más información sobre cómo empaquetar e implementar una aplicación sin servidor usando
los comandos de empaquetado e implementación, consulte Implementación de aplicaciones sin servidor
en la Guía para desarrolladores de Modelo de aplicación sin servidor de AWS.
Puede utilizar la característica de notificaciones de los buckets de Amazon S3 y hacer que Amazon S3
publique eventos de creación de objetos para AWS Lambda. Siempre que CloudTrail escriba registros en
el bucket de S3, Amazon S3 puede invocar la función de Lambda pasando el evento de creación de objeto
de Amazon S3 como parámetro. El evento de S3 proporciona información, incluido el nombre del bucket
y el nombre de la clave del objeto de log creado por CloudTrail. El código de la función de Lambda puede
leer el objeto del registro y procesar los registros de acceso generados por CloudTrail. Por ejemplo, puede
escribir el código de una función de Lambda para que le notifique si se ha realizado una llamada a una API
específica en su cuenta.
En este caso, CloudTrail escribe los registros de acceso a su bucket de S3. En cuanto a AWS Lambda,
Amazon S3 es el origen de eventos, por lo que Amazon S3 publica los eventos para AWS Lambda e
invoca la función de Lambda.
{
"Records":[
{
"eventVersion":"1.02",
185
AWS Lambda Guía para desarrolladores
CloudTrail
"userIdentity":{
"type":"Root",
"principalId":"123456789012",
"arn":"arn:aws:iam::123456789012:root",
"accountId":"123456789012",
"accessKeyId":"access-key-id",
"sessionContext":{
"attributes":{
"mfaAuthenticated":"false",
"creationDate":"2015-01-24T22:41:54Z"
}
}
},
"eventTime":"2015-01-24T23:26:50Z",
"eventSource":"sns.amazonaws.com",
"eventName":"CreateTopic",
"awsRegion":"us-east-2",
"sourceIPAddress":"205.251.233.176",
"userAgent":"console.amazonaws.com",
"requestParameters":{
"name":"dropmeplease"
},
"responseElements":{
"topicArn":"arn:aws:sns:us-east-2:123456789012:exampletopic"
},
"requestID":"3fdb7834-9079-557e-8ef2-350abc03536b",
"eventID":"17b46459-dada-4278-b8e2-5a4ca9ff1a9c",
"eventType":"AwsApiCall",
"recipientAccountId":"123456789012"
},
{
"eventVersion":"1.02",
"userIdentity":{
"type":"Root",
"principalId":"123456789012",
"arn":"arn:aws:iam::123456789012:root",
"accountId":"123456789012",
"accessKeyId": "AKIAIOSFODNN7EXAMPLE",
"sessionContext":{
"attributes":{
"mfaAuthenticated":"false",
"creationDate":"2015-01-24T22:41:54Z"
}
}
},
"eventTime":"2015-01-24T23:27:02Z",
"eventSource":"sns.amazonaws.com",
"eventName":"GetTopicAttributes",
"awsRegion":"us-east-2",
"sourceIPAddress":"205.251.233.176",
"userAgent":"console.amazonaws.com",
"requestParameters":{
"topicArn":"arn:aws:sns:us-east-2:123456789012:exampletopic"
},
"responseElements":null,
"requestID":"4a0388f7-a0af-5df9-9587-c5c98c29cbec",
"eventID":"ec5bb073-8fa1-4d45-b03c-f07b9fc9ea18",
"eventType":"AwsApiCall",
"recipientAccountId":"123456789012"
}
]
}
Para obtener información detallada acerca de cómo configurar Amazon S3 como origen de eventos,
consulte Uso de AWS Lambda con Amazon S3 (p. 272).
186
AWS Lambda Guía para desarrolladores
Registros de CloudTrail
Temas
• Registrar llamadas a la API de AWS Lambda con AWS CloudTrail (p. 187)
• Tutorial: Activación de una función Lambda con eventos de AWS CloudTrail (p. 190)
• Código de función de muestra (p. 195)
Para obtener más información sobre CloudTrail, incluido cómo configurarlo y habilitarlo, consulte la AWS
CloudTrail User Guide.
Para mantener un registro continuo de los eventos de la cuenta de AWS, incluidos los eventos de
AWS Lambda, cree un registro de seguimiento. Un registro de seguimiento permite a CloudTrail enviar
archivos de registro a un bucket de Amazon S3. De forma predeterminada, cuando se crea un registro
de seguimiento en la consola, este se aplica a todas las regiones de AWS. El registro de seguimiento
registra los eventos de todas las regiones de la partición de AWS y envía los archivos de registro al bucket
de Amazon S3 especificado. También puede configurar otros servicios de AWS para analizar y actuar en
función de los datos de eventos recopilados en los registros de CloudTrail. Para obtener más información,
consulte los siguientes temas:
AWS Lambda admite el registro de las siguientes acciones como eventos en los archivos de registro de
CloudTrail:
187
AWS Lambda Guía para desarrolladores
Registros de CloudTrail
Cada entrada de registro contiene información sobre quién generó la solicitud. La información de identidad
del usuario que figura en el registro le ayudará a determinar si la solicitud se hizo con credenciales de
usuario de IAM o raíz, con credenciales de seguridad temporales para un rol o un usuario federado,
o mediante otro servicio de AWS. Para obtener más información, consulte el campo userIdentity en la
Referencia de eventos de CloudTrail.
Puede almacenar los archivos de log en su bucket todo el tiempo que desee, y también puede definir
reglas de ciclo de vida de Amazon S3 para archivar o eliminar archivos de log automáticamente. De forma
predeterminada, los archivos de registro se cifran utilizando el cifrado en el servidor (SSE) de Amazon S3.
Puede hacer que CloudTrail publique notificaciones de Amazon SNS cuando se entreguen nuevos
archivos de registro si desea actuar rápidamente en ese momento. Para obtener más información, consulte
Configuración de notificaciones de Amazon SNS para CloudTrail.
También puede agregar archivos de registro de AWS Lambda de varias regiones de AWS y de varias
cuentas de AWS en un solo bucket de S3. Para obtener más información, consulte Trabajar con archivos
de registro de CloudTrail.
En el siguiente ejemplo se muestran entradas de registro de CloudTrail para las acciones GetFunction y
DeleteFunction.
{
"Records": [
{
"eventVersion": "1.03",
"userIdentity": {
188
AWS Lambda Guía para desarrolladores
Registros de CloudTrail
"type": "IAMUser",
"principalId": "A1B2C3D4E5F6G7EXAMPLE",
"arn": "arn:aws:iam::999999999999:user/myUserName",
"accountId": "999999999999",
"accessKeyId": "AKIAIOSFODNN7EXAMPLE",
"userName": "myUserName"
},
"eventTime": "2015-03-18T19:03:36Z",
"eventSource": "lambda.amazonaws.com",
"eventName": "GetFunction",
"awsRegion": "us-east-1",
"sourceIPAddress": "127.0.0.1",
"userAgent": "Python-httplib2/0.8 (gzip)",
"errorCode": "AccessDenied",
"errorMessage": "User: arn:aws:iam::999999999999:user/myUserName is not
authorized to perform: lambda:GetFunction on resource: arn:aws:lambda:us-
west-2:999999999999:function:other-acct-function",
"requestParameters": null,
"responseElements": null,
"requestID": "7aebcd0f-cda1-11e4-aaa2-e356da31e4ff",
"eventID": "e92a3e85-8ecd-4d23-8074-843aabfe89bf",
"eventType": "AwsApiCall",
"recipientAccountId": "999999999999"
},
{
"eventVersion": "1.03",
"userIdentity": {
"type": "IAMUser",
"principalId": "A1B2C3D4E5F6G7EXAMPLE",
"arn": "arn:aws:iam::999999999999:user/myUserName",
"accountId": "999999999999",
"accessKeyId": "AKIAIOSFODNN7EXAMPLE",
"userName": "myUserName"
},
"eventTime": "2015-03-18T19:04:42Z",
"eventSource": "lambda.amazonaws.com",
"eventName": "DeleteFunction",
"awsRegion": "us-east-1",
"sourceIPAddress": "127.0.0.1",
"userAgent": "Python-httplib2/0.8 (gzip)",
"requestParameters": {
"functionName": "basic-node-task"
},
"responseElements": null,
"requestID": "a2198ecc-cda1-11e4-aaa2-e356da31e4ff",
"eventID": "20b84ce5-730f-482e-b2b2-e8fcc87ceb22",
"eventType": "AwsApiCall",
"recipientAccountId": "999999999999"
}
]
}
Note
189
AWS Lambda Guía para desarrolladores
Tutorial
identidades invocan las funciones y la frecuencia de sus invocaciones. Para obtener más información
sobre esta opción, consulte Registro de eventos de datos en los registros de seguimiento.
RESOURCE_NOT_FOUND
"serviceEventDetails":{
"ESMDisableReason":"Lambda Function not found"
}
Utilice las siguientes instrucciones para crear una función Lambda que le avise cuando se produzca una
llamada a la API específica en su cuenta. La función procesa eventos de notificación de Amazon S3, lee
registros de un bucket y publica alertas a través de un tema de Amazon SNS. En este tutorial, va a crear:
190
AWS Lambda Guía para desarrolladores
Tutorial
Requisitos
En este tutorial, se le presuponen algunos conocimientos sobre las operaciones básicas de Lambda y la
consola de Lambda. Si aún no lo ha hecho, siga las instrucciones que se indican en Introducción a AWS
Lambda (p. 3) para crear la primera función de Lambda.
191
AWS Lambda Guía para desarrolladores
Tutorial
{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Action": [
"logs:*"
],
"Resource": "arn:aws:logs:*:*:*"
},
{
"Effect": "Allow",
"Action": [
"s3:GetObject"
],
"Resource": "arn:aws:s3:::my-bucket/*"
},
{
"Effect": "Allow",
"Action": [
"sns:Publish"
],
"Resource": "arn:aws:sns:us-west-2:123456789012:my-topic"
}
]
}
1. Cree una carpeta y asígnele un nombre que indique que es su función Lambda (por ejemplo,
lambda-cloudtrail).
2. En la carpeta, cree un archivo llamado index.js.
3. Pegue el siguiente código en index.js. Sustituya el ARN del tema de Amazon SNS por el ARN que
Amazon S3 creó cuando se creó el tema de Amazon SNS.
192
AWS Lambda Guía para desarrolladores
Tutorial
async.waterfall([
function fetchLogFromS3(next){
console.log('Fetching compressed log from S3...');
s3.getObject({
Bucket: srcBucket,
Key: srcKey
},
next);
},
function uncompressLog(response, next){
console.log("Uncompressing log...");
zlib.gunzip(response.Body, next);
},
function publishNotifications(jsonBuffer, next) {
console.log('Filtering log...');
var json = jsonBuffer.toString();
console.log('CloudTrail JSON from S3:', json);
var records;
try {
records = JSON.parse(json);
} catch (err) {
next('Unable to parse CloudTrail JSON: ' + err);
return;
}
var matchingRecords = records
.Records
.filter(function(record) {
return record.eventSource.match(EVENT_SOURCE_TO_TRACK)
&& record.eventName.match(EVENT_NAME_TO_TRACK);
});
193
AWS Lambda Guía para desarrolladores
Tutorial
};
$ zip -r function.zip .
1. Ejecute el siguiente comando add-permission. Sustituya el ARN y el ID de cuenta por los suyos
propios.
Este comando concede a la entidad principal del servicio Amazon S3 (s3.amazonaws.com) permisos
para realizar la acción lambda:InvokeFunction. Los permisos de invocación se conceden a
Amazon S3 solo si se cumplen las siguientes condiciones:
194
AWS Lambda Guía para desarrolladores
Código de muestra
Cuando CloudTrail almacena registros en el bucket, Amazon S3 envía un evento a la función. El evento
proporciona información, incluido el nombre del bucket y el nombre de la clave del objeto de registro
creado por CloudTrail.
Temas
• Node.js (p. 195)
Node.js
El ejemplo siguiente procesa registros de CloudTrail y envía una notificación cuando se crea un tema de
Amazon SNS.
Example index.js
async.waterfall([
function fetchLogFromS3(next){
console.log('Fetching compressed log from S3...');
s3.getObject({
Bucket: srcBucket,
195
AWS Lambda Guía para desarrolladores
Eventos de CloudWatch
Key: srcKey
},
next);
},
function uncompressLog(response, next){
console.log("Uncompressing log...");
zlib.gunzip(response.Body, next);
},
function publishNotifications(jsonBuffer, next) {
console.log('Filtering log...');
var json = jsonBuffer.toString();
console.log('CloudTrail JSON from S3:', json);
var records;
try {
records = JSON.parse(json);
} catch (err) {
next('Unable to parse CloudTrail JSON: ' + err);
return;
}
var matchingRecords = records
.Records
.filter(function(record) {
return record.eventSource.match(EVENT_SOURCE_TO_TRACK)
&& record.eventName.match(EVENT_NAME_TO_TRACK);
});
Comprima el código de muestra para crear un paquete de implementación. Para obtener instrucciones,
consulte Paquete de implementación de AWS Lambda en Node.js (p. 336).
196
AWS Lambda Guía para desarrolladores
Eventos de CloudWatch
Puede crear reglas que coincidan con los eventos seleccionados en el flujo y los transfieran a una función
de AWS Lambda para realizar alguna acción. Por ejemplo, puede invocar automáticamente una función
AWS Lambda para registrar el estado de una instancia EC2 o un grupo de AutoScaling.
Eventos de CloudWatch invoca su función de forma asíncrona con un documento de evento que envuelve
el evento desde su origen. En el siguiente ejemplo se muestra un evento que se originó a partir de una
instantánea de base de datos de Amazon Relational Database Service.
{
"version": "0",
"id": "fe8d3c65-xmpl-c5c3-2c87-81584709a377",
"detail-type": "RDS DB Instance Event",
"source": "aws.rds",
"account": "123456789012",
"time": "2020-04-28T07:20:20Z",
"region": "us-east-2",
"resources": [
"arn:aws:rds:us-east-2:123456789012:db:rdz6xmpliljlb1"
],
"detail": {
"EventCategories": [
"backup"
],
"SourceType": "DB_INSTANCE",
"SourceArn": "arn:aws:rds:us-east-2:123456789012:db:rdz6xmpliljlb1",
"Date": "2020-04-28T07:20:20.112Z",
"Message": "Finished DB Instance backup",
"SourceIdentifier": "rdz6xmpliljlb1"
}
}
También puede crear una función de Lambda y configurar AWS Lambda para que la ejecute de manera
periódica. Puede especificar una frecuencia fija (por ejemplo, ejecutar una función de Lambda cada hora o
cada 15 minutos), o puede especificar una expresión Cron.
{
"account": "123456789012",
"region": "us-east-2",
"detail": {},
"detail-type": "Scheduled Event",
"source": "aws.events",
"time": "2019-03-01T01:23:45Z",
"id": "cdc73f9d-aea9-11e3-9d5a-835b769c0d9c",
"resources": [
"arn:aws:events:us-east-1:123456789012:rule/my-schedule"
]
}
197
AWS Lambda Guía para desarrolladores
Tutorial
Para obtener más información sobre las expresiones de programación, consulte Programación de
expresiones con rate o cron (p. 201).
Cada cuenta de AWS puede tener un máximo de 100 orígenes de eventos exclusivos de tipo Eventos
de CloudWatch - Schedule (Programación de CloudWatch). Cada uno de ellos puede ser el origen de
eventos de hasta cinco funciones de Lambda. Es decir, puede tener hasta 500 funciones de Lambda que
se ejecuten de forma programada en su cuenta de AWS.
Temas
• Tutorial: Uso de AWS Lambda con eventos programados (p. 198)
• Plantilla de AWS SAM para una aplicación de Eventos de CloudWatch (p. 200)
• Programación de expresiones con rate o cron (p. 201)
• Crear una función de Lambda utilizando el proyecto lambda-canary. También configurará la función de
Lambda para que se ejecute cada minuto. Tenga en cuenta que si la función devuelve un error, AWS
Lambda registra las métricas de error en CloudWatch.
• Configurar una alarma de CloudWatch en la métrica Errors de la función de Lambda para que
publique un mensaje en el tema de Amazon SNS cuando AWS Lambda envíe las métricas de error
a CloudWatch. Debe suscribirse a los temas de Amazon SNS para obtener notificaciones por correo
electrónico. En este tutorial, hará lo siguiente para configurar esto:
• Creación de un tema de Amazon SNS.
• Suscribirse al tema para poder recibir notificaciones por correo electrónico cuando se publique un
mensaje nuevo en el tema.
• En Amazon CloudWatch, configure una alarma en la métrica Errors de la función de Lambda para
publicar un mensaje en el tema de SNS cuando se produzcan errores.
Requisitos previos
En este tutorial, se le presuponen algunos conocimientos sobre las operaciones básicas de Lambda y la
consola de Lambda. Si aún no lo ha hecho, siga las instrucciones que se indican en Introducción a AWS
Lambda (p. 3) para crear la primera función de Lambda.
• Nombre – lambda-canary.
198
AWS Lambda Guía para desarrolladores
Tutorial
• Nombre – lambda-canary-notifications.
• Nombre que mostrar – Canary.
4. Seleccione Create subscription.
5. Cree una suscripción con la siguiente configuración:
• Protocolo – Email.
• Punto de enlace – Su dirección de email.
199
AWS Lambda Guía para desarrolladores
Plantilla de muestra
Amazon SNS envía un email desde Canary <no-reply@sns.amazonaws.com>, que refleja el nombre
intuitivo del tema. Use el enlace del correo electrónico para verificar la dirección.
Pruebe la alarma
Actualice la configuración de función para hacer que la función devuelva un error, lo que activa la alarma.
A continuación, hay una plantilla AWS SAM de muestra para la aplicación de Lambda del
tutorial (p. 198). Copie el texto siguiente en un archivo .yaml y guárdelo junto al paquete ZIP que ha
200
AWS Lambda Guía para desarrolladores
Programación de expresiones
creado anteriormente. Tenga en cuenta que los valores de los parámetros Handler y Runtime deben
coincidir con los que utilizó cuando creó la función en la sección anterior.
Example template.yaml
AWSTemplateFormatVersion: '2010-09-09'
Transform: AWS::Serverless-2016-10-31
Parameters:
NotificationEmail:
Type: String
Resources:
CheckWebsitePeriodically:
Type: AWS::Serverless::Function
Properties:
Handler: LambdaFunctionOverHttps.handler
Runtime: runtime
Policies: AmazonDynamoDBFullAccess
Events:
CheckWebsiteScheduledEvent:
Type: Schedule
Properties:
Schedule: rate(1 minute)
AlarmTopic:
Type: AWS::SNS::Topic
Properties:
Subscription:
- Protocol: email
Endpoint: !Ref NotificationEmail
Alarm:
Type: AWS::CloudWatch::Alarm
Properties:
AlarmActions:
- !Ref AlarmTopic
ComparisonOperator: GreaterThanOrEqualToThreshold
Dimensions:
- Name: FunctionName
Value: !Ref CheckWebsitePeriodically
EvaluationPeriods: 1
MetricName: Errors
Namespace: AWS/Lambda
Period: 60
Statistic: Sum
Threshold: '1'
Para obtener más información sobre cómo empaquetar e implementar una aplicación sin servidor usando
los comandos de empaquetado e implementación, consulte Implementación de aplicaciones sin servidor
en la Guía para desarrolladores de Modelo de aplicación sin servidor de AWS.
rate(Value Unit)
Donde Value es un número entero positivo y Unit puede expresarse en minutos, horas o días. Si el valor
es 1, la unidad debe ir en singular (por ejemplo, rate(1 day)); para otros valores, en plural (por ejemplo,
rate(5 days)).
201
AWS Lambda Guía para desarrolladores
Registros de CloudWatch
Para obtener más información, consulte Programar expresiones para reglas en la Guía del usuario de
Eventos de CloudWatch.
CloudWatch Logs invoca la función de forma asíncrona con un evento que contiene datos de registro
codificados. El valor del campo de datos es un archivo ZIP codificado en Base64.
202
AWS Lambda Guía para desarrolladores
CloudFormation
"awslogs": {
"data":
"ewogICAgIm1lc3NhZ2VUeXBlIjogIkRBVEFfTUVTU0FHRSIsCiAgICAib3duZXIiOiAiMTIzNDU2Nzg5MDEyIiwKICAgICJsb2dHc
}
}
Cuando se descodifican y descomprimen, los datos del registro son un documento JSON con la siguiente
estructura.
{
"messageType": "DATA_MESSAGE",
"owner": "123456789012",
"logGroup": "/aws/lambda/echo-nodejs",
"logStream": "2019/03/13/[$LATEST]94fa867e5374431291a7fc14e2f56ae7",
"subscriptionFilters": [
"LambdaStream_cloudwatchlogs-node"
],
"logEvents": [
{
"id": "34622316099697884706540976068822859012661220141643892546",
"timestamp": 1552518348220,
"message": "REPORT RequestId: 6234bffe-149a-b642-81ff-2e8e376d8aff\tDuration:
46.84 ms\tBilled Duration: 100 ms \tMemory Size: 192 MB\tMax Memory Used: 72 MB\t\n"
}
]
}
Para ver una aplicación de ejemplo que utiliza CloudWatch Logs como desencadenador, consulte
Aplicación de ejemplo de procesamiento de errores para AWS Lambda (p. 323).
Resources:
primerinvoke:
Type: AWS::CloudFormation::CustomResource
Version: "1.0"
Properties:
ServiceToken: !GetAtt primer.Arn
FunctionName: !Ref randomerror
El token de servicio es el Nombre de recurso de Amazon (ARN) de la función que AWS CloudFormation
invoca al crear, actualizar o eliminar la pila. También puede incluir propiedades adicionales como
FunctionName, que AWS CloudFormation pasa a su función tal cual.
AWS CloudFormation invoca la función Lambda de forma asíncrona (p. 101) con un evento que incluye
una URL de devolución de llamada.
203
AWS Lambda Guía para desarrolladores
CloudFormation
{
"RequestType": "Create",
"ServiceToken": "arn:aws:lambda:us-east-2:123456789012:function:lambda-error-processor-
primer-14ROR2T3JKU66",
"ResponseURL": "https://cloudformation-custom-resource-response-useast2.s3-us-
east-2.amazonaws.com/arn%3Aaws%3Acloudformation%3Aus-east-2%3A123456789012%3Astack/lambda-
error-processor/1134083a-2608-1e91-9897-022501a2c456%7Cprimerinvoke%7C5d478078-13e9-
baf0-464a-7ef285ecc786?
AWSAccessKeyId=AKIAIOSFODNN7EXAMPLE&Expires=1555451971&Signature=28UijZePE5I4dvukKQqM
%2F9Rf1o4%3D",
"StackId": "arn:aws:cloudformation:us-east-2:123456789012:stack/lambda-error-
processor/1134083a-2608-1e91-9897-022501a2c456",
"RequestId": "5d478078-13e9-baf0-464a-7ef285ecc786",
"LogicalResourceId": "primerinvoke",
"ResourceType": "AWS::CloudFormation::CustomResource",
"ResourceProperties": {
"ServiceToken": "arn:aws:lambda:us-east-2:123456789012:function:lambda-error-
processor-primer-14ROR2T3JKU66",
"FunctionName": "lambda-error-processor-randomerror-ZWUC391MQAJK"
}
}
La función es responsable de devolver una respuesta a la URL de devolución de llamada que indica el
éxito o el error de la operación. Para ver la sintaxis de respuesta completa, consulte Objetos de respuesta
de recursos personalizados.
{
"Status": "SUCCESS",
"PhysicalResourceId": "2019/04/18/[$LATEST]b3d1bfc65f19ec610654e4d9b9de47a0",
"StackId": "arn:aws:cloudformation:us-east-2:123456789012:stack/lambda-error-
processor/1134083a-2608-1e91-9897-022501a2c456",
"RequestId": "5d478078-13e9-baf0-464a-7ef285ecc786",
"LogicalResourceId": "primerinvoke"
}
AWS CloudFormation proporciona una biblioteca llamada cfn-response que controla el envío de
la respuesta. Si define su función dentro de una plantilla, puede solicitar la biblioteca por nombre. A
continuación, AWS CloudFormation añade la biblioteca al paquete de implementación que crea para la
función.
La función de ejemplo siguiente invoca una segunda función. Si la llamada se realiza sin error, la función
envía una respuesta de operación correcta a AWS CloudFormation y la actualización de la pila continúa.
La plantilla utiliza el tipo de recurso AWS::Serverless::Function proporcionado por Modelo de aplicación sin
servidor de AWS.
Transform: 'AWS::Serverless-2016-10-31'
Resources:
primer:
Type: AWS::Serverless::Function
Properties:
Handler: index.handler
Runtime: nodejs12.x
InlineCode: |
var aws = require('aws-sdk');
204
AWS Lambda Guía para desarrolladores
CloudFront (Lambda@Edge)
Si la función que el recurso personalizado invoca no está definida en una plantilla, puede obtener el código
fuente de cfn-response desde el módulo cfn-response en la Guía del usuario de AWS CloudFormation.
Para ver una aplicación de ejemplo que utiliza un recurso personalizado para asegurarse de que el grupo
de registros de una función se crea antes que un recurso dependiente, consulte Aplicación de ejemplo de
procesamiento de errores para AWS Lambda (p. 323).
Para obtener más información sobre los recursos personalizados, consulte Recursos personalizados en la
Guía del usuario de AWS CloudFormation.
• Después de que CloudFront reciba una solicitud de un espectador (solicitud del espectador)
• Antes de que CloudFront reenvíe la solicitud al origen (solicitud al origen)
• Después de que CloudFront reciba la respuesta del origen (respuesta del origen)
• Antes de que CloudFront reenvíe la respuesta al espectador (respuesta al espectador)
205
AWS Lambda Guía para desarrolladores
CloudFront (Lambda@Edge)
Note
También puede generar respuestas a los espectadores sin necesidad de enviar la solicitud al origen.
{
"Records": [
{
"cf": {
"config": {
"distributionId": "EDFDVBD6EXAMPLE"
},
"request": {
"clientIp": "2001:0db8:85a3:0:0:8a2e:0370:7334",
"method": "GET",
"uri": "/picture.jpg",
"headers": {
"host": [
{
"key": "Host",
"value": "d111111abcdef8.cloudfront.net"
}
],
"user-agent": [
{
"key": "User-Agent",
"value": "curl/7.51.0"
}
]
}
}
}
}
]
}
• Inspeccionar las cookies para rescribir URL en diferentes versiones de un sitio y poder realizar pruebas
A/B.
206
AWS Lambda Guía para desarrolladores
CodeCommit
• Enviar diferentes objetos a los usuarios en función del encabezado User-Agent, que contiene
información sobre el dispositivo que envió la solicitud. Por ejemplo, puede enviar imágenes en diferentes
resoluciones a los usuarios en función de sus dispositivos.
• Revisar los encabezados o los tokens autorizados, insertar el encabezado correspondiente y permitir el
control de acceso antes de reenviar una solicitud al origen.
• Añadir, eliminar y modificar encabezados, así como reescribir la ruta de la URL para dirigir a los usuarios
a distintos objetos de la caché.
• Generar nuevas respuestas HTTP para realizar tareas como redirigir a los usuarios sin autenticar a
páginas de inicio de sesión, o crear y entregar páginas web estáticas desde el borde. Para obtener más
información, consulte Utilización de funciones de Lambda para generar respuestas HTTP a solicitudes
de origen y del visor en la Guía para desarrolladores de Amazon CloudFront.
Para obtener más información sobre cómo utilizar Lambda@Edge, consulte Uso de CloudFront con
Lambda@Edge.
{
"Records": [
{
"awsRegion": "us-east-2",
"codecommit": {
"references": [
{
"commit": "5e493c6f3067653f3d04eca608b4901eb227078",
"ref": "refs/heads/master"
}
]
},
"eventId": "31ade2c7-f889-47c5-a937-1cf99e2790e9",
"eventName": "ReferenceChanges",
"eventPartNumber": 1,
"eventSource": "aws:codecommit",
"eventSourceARN": "arn:aws:codecommit:us-east-2:123456789012:lambda-pipeline-
repo",
"eventTime": "2019-03-12T20:58:25.400+0000",
"eventTotalParts": 1,
"eventTriggerConfigId": "0d17d6a4-efeb-46f3-b3ab-a63741badeb8",
"eventTriggerName": "index.handler",
"eventVersion": "1.0",
"userIdentityARN": "arn:aws:iam::123456789012:user/intern"
}
]
}
Para obtener más información, consulte Administración de los disparadores de un repositorio de AWS
CodeCommit.
207
AWS Lambda Guía para desarrolladores
CodePipeline
CodePipeline invoca la función de forma asincrónica con un evento que contiene detalles sobre el
trabajo. En el ejemplo siguiente se muestra un evento de una canalización que ha invocado una función
denominada my-function.
{
"CodePipeline.job": {
"id": "c0d76431-b0e7-xmpl-97e3-e8ee786eb6f6",
"accountId": "123456789012",
"data": {
"actionConfiguration": {
"configuration": {
"FunctionName": "my-function",
"UserParameters": "{\"KEY\": \"VALUE\"}"
}
},
"inputArtifacts": [
{
"name": "my-pipeline-SourceArtifact",
"revision": "e0c7xmpl2308ca3071aa7bab414de234ab52eea",
"location": {
"type": "S3",
"s3Location": {
"bucketName": "aws-us-west-2-123456789012-my-pipeline",
"objectKey": "my-pipeline/test-api-2/TdOSFRV"
}
}
}
],
"outputArtifacts": [
{
"name": "invokeOutput",
"revision": null,
"location": {
"type": "S3",
"s3Location": {
"bucketName": "aws-us-west-2-123456789012-my-pipeline",
"objectKey": "my-pipeline/invokeOutp/D0YHsJn"
}
}
}
],
"artifactCredentials": {
"accessKeyId": "AKIAIOSFODNN7EXAMPLE",
"secretAccessKey": "6CGtmAa3lzWtV7a...",
"sessionToken": "IQoJb3JpZ2luX2VjEA...",
"expirationTime": 1575493418000
}
}
}
}
208
AWS Lambda Guía para desarrolladores
Permisos
Para completar el trabajo, la función debe llamar a la API de CodePipeline para señalizar si se ha
realizado correcta o incorrectamente. En el ejemplo siguiente de función de Node.js se utiliza la operación
PutJobSuccessResult para señalizar que se ha realizado correctamente. Obtiene el ID de trabajo para
la llamada a la API desde el objeto de evento.
Example index.js
En la invocación asincrónica, Lambda pone en cola el mensaje y, si la función devuelve un error, lo intenta
de nuevo (p. 119). Configure la función con un destino (p. 104) para conservar los eventos que la función
no puede procesar.
Para obtener más información sobre la configuración de una canalización para invocar una función
Lambda, consulte Invocar una función AWS Lambda en una canalización en la Guía del usuario de AWS
CodePipeline.
Secciones
• Permisos (p. 209)
• Creación de una canalización de entrega continua para una aplicación de Lambda con AWS
CodePipeline (p. 210)
Permisos
Para invocar una función, una canalización CodePipeline necesita permiso para utilizar las siguientes
operaciones de la API:
Para completar un trabajo, el rol necesita los siguientes permisos en su rol de ejecución (p. 33).
• codepipeline:PutJobSuccessResult
• codepipeline:PutJobFailureResult
209
AWS Lambda Guía para desarrolladores
Tutorial
La canalización asigna una única ramificación de un repositorio a una única pila de AWS CloudFormation.
Puede crear canalizaciones adicionales para agregar entornos para otras ramificaciones del mismo
repositorio. También puede añadir etapas a la canalización para pruebas, ensayo y las aprobaciones
manuales. Para obtener más información sobre AWS CodePipeline, consulte ¿Qué es AWS
CodePipeline?.
Para conocer otra forma de crear una canalización con Modelo de aplicación sin servidor de AWS y AWS
CloudFormation, vea Automate Your Serverless Application Deployments en el canal de YouTube de
Amazon Web Services.
Secciones
• Requisitos previos (p. 211)
• Cree de un rol de AWS CloudFormation. (p. 211)
• Configuración de un repositorio (p. 212)
• Cree una canalización (p. 213)
• Actualización del rol de la etapa de compilación (p. 214)
• Finalización de la etapa de implementación (p. 214)
• Pruebe la aplicación. (p. 215)
210
AWS Lambda Guía para desarrolladores
Tutorial
Requisitos previos
En este tutorial, se le presuponen algunos conocimientos sobre las operaciones básicas de Lambda y la
consola de Lambda. Si aún no lo ha hecho, siga las instrucciones que se indican en Introducción a AWS
Lambda (p. 3) para crear la primera función de Lambda.
Para seguir los procedimientos de esta guía, necesitará un shell o un terminal de línea de comando donde
pueda ejecutar los comandos. Los comandos aparecen en listas y van precedidos del símbolo del sistema
($) y del nombre del directorio actual, si es aplicable:
Para los comandos largos, se utiliza un carácter de escape (\) para dividir un comando en varias líneas.
En Linux y macOS, use su administrador de shell y paquetes preferido. En Windows 10, puede instalar
Windows Subsystem para Linux para obtener una versión de Ubuntu y Bash integrada con Windows.
Durante la fase de compilación, el script de compilación carga los artefactos en Amazon Simple Storage
Service (Amazon S3). Puede utilizar un bucket existente o crear uno nuevo para la canalización. Utilice la
AWS CLI para crear un bucket.
$ aws s3 mb s3://lambda-deployment-artifacts-123456789012
{
"Statement": [
{
"Action": [
"apigateway:*",
"codedeploy:*",
"lambda:*",
"cloudformation:CreateChangeSet",
"iam:GetRole",
"iam:CreateRole",
"iam:DeleteRole",
"iam:PutRolePolicy",
"iam:AttachRolePolicy",
"iam:DeleteRolePolicy",
"iam:DetachRolePolicy",
"iam:PassRole",
"s3:GetObject",
211
AWS Lambda Guía para desarrolladores
Tutorial
"s3:GetObjectVersion",
"s3:GetBucketVersioning"
],
"Resource": "*",
"Effect": "Allow"
}
],
"Version": "2012-10-17"
}
Configuración de un repositorio
Creación de un repositorio de AWS CodeCommit para almacenar los archivos del proyecto. Para obtener
más información, consulte Configuración en la Guía del usuario de CodeCommit.
Example index.js
Una función de Lambda que devuelve la hora actual.
Example template.yml
La plantilla de AWS SAM (p. 29) que define la aplicación.
AWSTemplateFormatVersion: '2010-09-09'
Transform: AWS::Serverless-2016-10-31
Description: Outputs the time
Resources:
TimeFunction:
Type: AWS::Serverless::Function
Properties:
Handler: index.handler
Runtime: nodejs10.x
CodeUri: ./
Events:
MyTimeApi:
Type: Api
Properties:
Path: /TimeResource
Method: GET
212
AWS Lambda Guía para desarrolladores
Tutorial
Example buildspec.yml
Una especificación de compilación de AWS CodeBuild que instala los paquetes necesarios y carga el
paquete de implementación en Amazon S3. Sustituya el texto resaltado por el nombre del bucket.
version: 0.2
phases:
install:
runtime-versions:
nodejs: 10
build:
commands:
- npm install time
- export BUCKET=lambda-deployment-artifacts-123456789012
- aws cloudformation package --template-file template.yml --s3-bucket $BUCKET --
output-template-file outputtemplate.yml
artifacts:
type: zip
files:
- template.yml
- outputtemplate.yml
213
AWS Lambda Guía para desarrolladores
Tutorial
La canalización genera un error la primera vez que se ejecuta, ya que necesita permisos adicionales. En la
sección siguiente, añadirá permisos al rol que se genera para la fase de compilación.
214
AWS Lambda Guía para desarrolladores
Cognito
La canalización está lista. Envíe los cambios a la ramificación maestra para desencadenar una
implementación.
Pruebe la aplicación.
La aplicación incluye una API de API Gateway con un punto de enlace público que devuelve la hora actual.
Utilice la consola de Lambda para ver la aplicación y obtener acceso a la API.
The time in Los Angeles is: Thu Jun 27 2019 16:07:20 GMT-0700 (PDT)
{
"datasetName": "datasetName",
"eventType": "SyncTrigger",
"region": "us-east-1",
"identityId": "identityId",
"datasetRecords": {
"SampleKey2": {
"newValue": "newValue2",
215
AWS Lambda Guía para desarrolladores
Config
"oldValue": "oldValue2",
"op": "replace"
},
"SampleKey1": {
"newValue": "newValue1",
"oldValue": "oldValue1",
"op": "replace"
}
},
"identityPoolId": "identityPoolId",
"version": 2
}
{
"invokingEvent": "{\"configurationItem\":{\"configurationItemCaptureTime\":
\"2016-02-17T01:36:34.043Z\",\"awsAccountId\":\"000000000000\",\"configurationItemStatus\":
\"OK\",\"resourceId\":\"i-00000000\",\"ARN\":\"arn:aws:ec2:us-east-1:000000000000:instance/
i-00000000\",\"awsRegion\":\"us-east-1\",\"availabilityZone\":\"us-east-1a\",
\"resourceType\":\"AWS::EC2::Instance\",\"tags\":{\"Foo\":\"Bar\"},\"relationships\":
[{\"resourceId\":\"eipalloc-00000000\",\"resourceType\":\"AWS::EC2::EIP\",\"name\":
\"Is attached to ElasticIp\"}],\"configuration\":{\"foo\":\"bar\"}},\"messageType\":
\"ConfigurationItemChangeNotification\"}",
"ruleParameters": "{\"myParameterKey\":\"myParameterValue\"}",
"resultToken": "myResultToken",
"eventLeftScope": false,
"executionRoleArn": "arn:aws:iam::012345678912:role/config-role",
"configRuleArn": "arn:aws:config:us-east-1:012345678912:config-rule/config-
rule-0123456",
"configRuleName": "change-triggered-config-rule",
"configRuleId": "config-rule-0123456",
"accountId": "012345678912",
"version": "1.0"
}
Para obtener más información, consulte Evaluación de recursos con reglas de AWS Config.
216
AWS Lambda Guía para desarrolladores
DynamoDB
Lambda lee los registros del flujo e invoca la función de forma síncrona (p. 100) con un evento que
contiene los registros del flujo. Lambda lee los registros por lotes e invoca la función para procesar los
registros de cada lote.
{
"Records": [
{
"eventID": "1",
"eventVersion": "1.0",
"dynamodb": {
"Keys": {
"Id": {
"N": "101"
}
},
"NewImage": {
"Message": {
"S": "New item!"
},
"Id": {
"N": "101"
}
},
"StreamViewType": "NEW_AND_OLD_IMAGES",
"SequenceNumber": "111",
"SizeBytes": 26
},
"awsRegion": "us-west-2",
"eventName": "INSERT",
"eventSourceARN": eventsourcearn,
"eventSource": "aws:dynamodb"
},
{
"eventID": "2",
"eventVersion": "1.0",
"dynamodb": {
"OldImage": {
"Message": {
"S": "New item!"
},
"Id": {
"N": "101"
}
},
"SequenceNumber": "222",
"Keys": {
"Id": {
"N": "101"
}
},
"SizeBytes": 59,
"NewImage": {
"Message": {
"S": "This item has changed"
},
"Id": {
"N": "101"
}
},
"StreamViewType": "NEW_AND_OLD_IMAGES"
},
"awsRegion": "us-west-2",
"eventName": "MODIFY",
217
AWS Lambda Guía para desarrolladores
Permisos de rol de ejecución
"eventSourceARN": sourcearn,
"eventSource": "aws:dynamodb"
}
Lambda sondea las particiones del flujo de DynamoDB y busca registros 4 veces por segundo. Cuando
hay registros disponibles, Lambda invoca la función y espera el resultado. Si el procesamiento se realiza
correctamente, Lambda reanuda el sondeo hasta que recibe más registros.
De forma predeterminada, Lambda llama a su función en cuanto los registros están disponibles en el flujo.
Si el lote que lee desde el flujo solo tiene un registro, Lambda solo envía un registro a la función. Para
evitar invocar a la función con un número de registros pequeño, puede indicar al origen del evento que
almacene en búfer registros durante hasta 5 minutos configurando una ventana de lote. Antes de invocar
a la función, Lambda sigue leyendo registros desde el flujo hasta que haya recopilado un lote completo o
hasta que caduca la ventana de lote.
Si la función devuelve un error, Lambda volverá a intentar ejecutar el lote hasta que el procesamiento
se realice correctamente o los datos caduquen. Para evitar particiones detenidas, puede configurar la
asignación del origen de eventos para que vuelva a intentarlo con un tamaño de lote menor, para que limite
el número de reintentos o para que se descarten los registros que sean muy antiguos. Si desea conservar
los eventos descartados, puede configurar la asignación del origen de eventos para que envíe información
sobre los lotes con errores a una cola de SQS o un tema de SNS.
También puede aumentar la simultaneidad procesando varios lotes de cada partición en paralelo. Lambda
puede procesar hasta 10 lotes en cada partición simultáneamente. Si aumenta el número de lotes
simultáneos en cada partición, Lambda seguirá garantizando que el procesamiento se realiza en orden en
el nivel de la clave de partición.
Secciones
• Permisos de rol de ejecución (p. 218)
• Configuración de una secuencia como origen de eventos (p. 219)
• API de mapeo de origen de eventos (p. 220)
• Control de errores (p. 221)
• Métricas de Amazon CloudWatch (p. 222)
• Tutorial: Uso de AWS Lambda con flujos de Amazon DynamoDB (p. 223)
• Código de función de ejemplo (p. 227)
• Plantilla de AWS SAM para una aplicación de DynamoDB (p. 230)
• dynamodb:DescribeStream
• dynamodb:GetRecords
• dynamodb:GetShardIterator
• dynamodb:ListStreams
Para enviar registros de un lote con errores a una cola o un tema, la función necesita permisos adicionales.
Cada servicio de destino requiere un permiso diferente, como se indica a continuación:
218
AWS Lambda Guía para desarrolladores
Configuración de una secuencia como origen de eventos
Para configurar la función para que lea desde Flujos de DynamoDB en la consola de Lambda, cree un
desencadenador de DynamoDB.
Lambda admite las siguientes opciones para los orígenes de eventos de DynamoDB.
Tras procesar cualquier registro existente, la función es alcanzada y continúa procesando registros
nuevos.
• On-failure destination (Destino en caso de error): cola de SQS o tema de SNS de los registros que no
pueden procesarse. Cuando Lambda descarta un lote de registros porque es demasiado antiguo o se
han agotado todos los reintentos, envía información sobre el lote a la cola o al tema.
• Retry attempts (Número de reintentos): número máximo de reintentos que Lambda realiza cuando la
función devuelve un error. No se aplica a los errores ni las limitaciones de los servicios en los que el lote
no alcanza la función.
• Maximum age of record (Antigüedad máxima del registro): antigüedad máxima de un registro que
Lambda envía a la función.
• Split batch on error (Dividir lote en caso de error): cuando la función devuelve un error, el lote se divide
en dos antes de intentarlo de nuevo.
• Process multiple batches from the same shard concurrently (Lotes simultáneos por partición): procesa
simultáneamente varios lotes de la misma partición.
• Enabled (Habilitado): establecer en true para habilitar la asignación de origen de eventos. Establecer
en false el origen de eventos para dejar de procesar registros. Lambda toma nota del último registro
procesado y sigue procesando desde ese punto cuando se habilita de nuevo el mapeo.
219
AWS Lambda Guía para desarrolladores
API de mapeo de origen de eventos
Note
DynamoDB cobra por las solicitudes de lectura que Lambda hace para obtener registros de la
secuencia. Para obtener más información sobre precios, consulte precios de Amazon DynamoDB.
Para administrar la configuración de origen de evento más tarde, elija el desencadenador en el diseñador.
En el siguiente ejemplo se utiliza la AWS CLI para asignar una función llamada my-function a una
secuencia de DynamoDB especificada mediante un nombre de recurso de Amazon (ARN), con un tamaño
de lote de 500.
Configure otras opciones para personalizar el modo en que se procesan los lotes y especificar cuándo
deben descargarse los registros que no se pueden procesar. En el siguiente ejemplo, se actualiza la
asignación de un origen de eventos para enviar un registro de error a una cola de SQS después de dos
reintentos o si los registros tienen más de una hora de antigüedad.
220
AWS Lambda Guía para desarrolladores
Control de errores
"EventSourceArn": "arn:aws:dynamodb:us-east-2:123456789012:table/my-table/
stream/2019-06-10T19:26:16.525",
"FunctionArn": "arn:aws:lambda:us-east-2:123456789012:function:my-function",
"LastModified": 1573243620.0,
"LastProcessingResult": "PROBLEM: Function call failed",
"State": "Updating",
"StateTransitionReason": "User action",
"DestinationConfig": {},
"MaximumRecordAgeInSeconds": 604800,
"BisectBatchOnFunctionError": false,
"MaximumRetryAttempts": 10000
}
Control de errores
La asignación del origen de eventos que lee los registros de la secuencia de DynamoDB invoca la función
de forma sincrónica y reintenta la operación si se producen errores. Si la función se ve limitada o el servicio
de Lambda devuelve un error sin invocar la función, Lambda vuelve a intentarlo hasta que el registro expira
o supera la antigüedad máxima establecida en la asignación del origen de eventos.
Si la función recibe los registros pero devuelve un error, Lambda lo vuelve a intentar hasta que vencen los
registros del lote, se supera la antigüedad máxima o se alcanza la cuota de reintentos especificada. En el
caso de los errores de funciones, también puede configurar la asignación del origen de eventos para que
divida en dos los lotes que presentan errores. Al intentarlo con lotes más pequeños, se aíslan los registros
erróneos y se solucionan problemas relacionadas con el tiempo de espera. Los lotes divididos no se tienen
en cuenta para calcular la cuota de reintentos.
Si las medidas de administración de errores no funcionan, Lambda descarta los registros y sigue
procesando los lotes de la secuencia. Con la configuración predeterminada, esto significa que un registro
221
AWS Lambda Guía para desarrolladores
Métricas de Amazon CloudWatch
erróneo puede bloquear el procesamiento de la partición afectada durante un máximo de one day. Para
evitar esto, configure la asignación del origen de eventos de la función con un número razonable de
reintentos y una antigüedad de registro máxima que se ajuste a su caso de uso.
Para mantener un registro de los lotes descartados, configure un destino de evento fallido. Lambda enviará
un documento a la cola o al tema de destino con información sobre el lote.
{
"requestContext": {
"requestId": "316aa6d0-8154-xmpl-9af7-85d5f4a6bc81",
"functionArn": "arn:aws:lambda:us-east-2:123456789012:function:myfunction",
"condition": "RetryAttemptsExhausted",
"approximateInvokeCount": 1
},
"responseContext": {
"statusCode": 200,
"executedVersion": "$LATEST",
"functionError": "Unhandled"
},
"version": "1.0",
"timestamp": "2019-11-14T00:13:49.717Z",
"DDBStreamBatchInfo": {
"shardId": "shardId-00000001573689847184-864758bb",
"startSequenceNumber": "800000000003126276362",
"endSequenceNumber": "800000000003126276362",
"approximateArrivalOfFirstRecord": "2019-11-14T00:13:19Z",
"approximateArrivalOfLastRecord": "2019-11-14T00:13:19Z",
"batchSize": 1,
"streamArn": "arn:aws:dynamodb:us-east-2:123456789012:table/mytable/
stream/2019-11-14T00:04:06.388"
}
}
Puede utilizar esta información para recuperar los registros afectados de la secuencia y solucionar los
problemas. Los registros reales no están incluidos, por lo que debe procesar este registro y recuperarlos
de la secuencia antes de que venzan y se pierdan.
222
AWS Lambda Guía para desarrolladores
Tutorial
procesando nuevos eventos, puede utilizar la antigüedad del iterador para estimar la latencia entre el
momento en que se añade un registro y el momento en que la función lo procesa.
Una tendencia ascendente en la antigüedad del iterador puede indicar problemas con la función. Para
obtener más información, consulte Trabajar con métricas de funciones de AWS Lambda (p. 464).
Requisitos previos
En este tutorial, se le presuponen algunos conocimientos sobre las operaciones básicas de Lambda y la
consola de Lambda. Si aún no lo ha hecho, siga las instrucciones que se indican en Introducción a AWS
Lambda (p. 3) para crear la primera función de Lambda.
Para seguir los procedimientos de esta guía, necesitará un shell o un terminal de línea de comando donde
pueda ejecutar los comandos. Los comandos aparecen en listas y van precedidos del símbolo del sistema
($) y del nombre del directorio actual, si es aplicable:
Para los comandos largos, se utiliza un carácter de escape (\) para dividir un comando en varias líneas.
En Linux y macOS, use su administrador de shell y paquetes preferido. En Windows 10, puede instalar
Windows Subsystem para Linux para obtener una versión de Ubuntu y Bash integrada con Windows.
Creación de la función
A continuación se muestra código de ejemplo que recibe un evento de DynamoDB como entrada y procesa
los mensajes que contiene. Con fines ilustrativos, el código escribe parte de los datos de los eventos de
entrada en CloudWatch Logs.
223
AWS Lambda Guía para desarrolladores
Tutorial
Note
Para ver código de muestra en otros lenguajes, consulte Código de función de ejemplo (p. 227).
Example index.js
console.log('Loading function');
Example input.txt
{
"Records":[
{
"eventID":"1",
"eventName":"INSERT",
"eventVersion":"1.0",
"eventSource":"aws:dynamodb",
"awsRegion":"us-east-1",
"dynamodb":{
"Keys":{
"Id":{
"N":"101"
}
},
"NewImage":{
"Message":{
"S":"New item!"
},
"Id":{
224
AWS Lambda Guía para desarrolladores
Tutorial
"N":"101"
}
},
"SequenceNumber":"111",
"SizeBytes":26,
"StreamViewType":"NEW_AND_OLD_IMAGES"
},
"eventSourceARN":"stream-ARN"
},
{
"eventID":"2",
"eventName":"MODIFY",
"eventVersion":"1.0",
"eventSource":"aws:dynamodb",
"awsRegion":"us-east-1",
"dynamodb":{
"Keys":{
"Id":{
"N":"101"
}
},
"NewImage":{
"Message":{
"S":"This item has changed"
},
"Id":{
"N":"101"
}
},
"OldImage":{
"Message":{
"S":"New item!"
},
"Id":{
"N":"101"
}
},
"SequenceNumber":"222",
"SizeBytes":59,
"StreamViewType":"NEW_AND_OLD_IMAGES"
},
"eventSourceARN":"stream-ARN"
},
{
"eventID":"3",
"eventName":"REMOVE",
"eventVersion":"1.0",
"eventSource":"aws:dynamodb",
"awsRegion":"us-east-1",
"dynamodb":{
"Keys":{
"Id":{
"N":"101"
}
},
"OldImage":{
"Message":{
"S":"This item has changed"
},
"Id":{
"N":"101"
}
},
"SequenceNumber":"333",
"SizeBytes":38,
"StreamViewType":"NEW_AND_OLD_IMAGES"
225
AWS Lambda Guía para desarrolladores
Tutorial
},
"eventSourceARN":"stream-ARN"
}
]
}
Habilitar secuencias
Anote el ARN del flujo. Lo necesitará en el siguiente paso al asociar el flujo a la función de Lambda. Para
obtener más información acerca de cómo habilitar flujos, consulte Captura de la actividad de las tablas con
flujos de DynamoDB.
226
AWS Lambda Guía para desarrolladores
Código de muestra
Esto crea un mapeo entre el flujo de DynamoDB especificado y la función de Lambda. Puede asociar
un flujo de DynamoDB a varias funciones de Lambda, así como asociar la misma función de Lambda a
varios flujos. Sin embargo, las funciones de Lambda compartirán el desempeño de lectura para el flujo que
comparten.
La lista devuelve todos los mapeos de orígenes de eventos creados, y para cada uno de ellos muestra
el LastProcessingResult, entre otras cosas. Este campo se utiliza para proporcionar un mensaje
informativo en caso de que surja algún problema. Los valores como No records processed (indica
que AWS Lambda no ha comenzado el sondeo o que no hay registros en el flujo) y OK (indica que AWS
Lambda ha leído correctamente los registros del flujo y ha invocado la función de Lambda) indican que no
hay ningún problema. Si hay algún problema, recibirá un mensaje de error.
Si tiene muchos mapeos de origen de eventos, use la función nombrar parámetro para reducir los
resultados.
Prueba de la configuración
Probar la experiencia integral. A medida que se actualiza la tabla, DynamoDB escribe los registros de
eventos en el flujo. AWS Lambda sondea el flujo, detecta nuevos registros en él y ejecuta la función de
Lambda en nombre del usuario pasando eventos a esta.
Temas
• Node.js (p. 227)
• Java 11 (p. 228)
• C# (p. 229)
• Python 3 (p. 229)
• Go (p. 230)
Node.js
En el siguiente ejemplo, se procesan los mensajes de DynamoDB, y registra su contenido.
227
AWS Lambda Guía para desarrolladores
Código de muestra
Example ProcessDynamoDBStream.js
console.log('Loading function');
Comprima el código de muestra para crear un paquete de implementación. Para obtener instrucciones,
consulte Paquete de implementación de AWS Lambda en Node.js (p. 336).
Java 11
El siguiente ejemplo procesa mensajes desde DynamoDB y registra sus contenidos. handleRequest es
el controlador que AWS Lambda invoca y proporciona datos de evento. Este controlador utiliza la clase
DynamodbEvent predefinida, que se define en la biblioteca aws-lambda-java-events.
Example DDBEventProcessor.java
package example;
import com.amazonaws.services.lambda.runtime.Context;
import com.amazonaws.services.lambda.runtime.LambdaLogger;
import com.amazonaws.services.lambda.runtime.RequestHandler;
import com.amazonaws.services.lambda.runtime.events.DynamodbEvent;
import com.amazonaws.services.lambda.runtime.events.DynamodbEvent.DynamodbStreamRecord;
}
return "Successfully processed " + ddbEvent.getRecords().size() + " records.";
}
}
Si el controlador vuelve normalmente sin excepciones, Lambda considera que el lote de registros de
entrada se ha procesado correctamente y empieza a leer nuevos registros en el flujo. Si el controlador
genera una excepción, Lambda considera que el lote de registros de entrada no se ha procesado e invoca
de nuevo la función con el mismo lote de registros.
Dependencias.
• aws-lambda-java-core
• aws-lambda-java-events
Cree el código con las dependencias de la biblioteca de Lambda para crear un paquete de
implementación. Para obtener instrucciones, consulte Paquete de implementación de AWS Lambda en
Java (p. 386).
228
AWS Lambda Guía para desarrolladores
Código de muestra
C#
El siguiente ejemplo procesa mensajes desde DynamoDB y registra sus contenidos.
ProcessDynamoEvent es el controlador que AWS Lambda invoca y proporciona datos de evento.
Este controlador utiliza la clase DynamoDbEvent predefinida, que se define en la biblioteca
Amazon.Lambda.DynamoDBEvents.
Example ProcessingDynamoDBStreams.cs
using System;
using System.IO;
using System.Text;
using Amazon.Lambda.Core;
using Amazon.Lambda.DynamoDBEvents;
using Amazon.Lambda.Serialization.Json;
namespace DynamoDBStreams
{
public class DdbSample
{
private static readonly JsonSerializer _jsonSerializer = new JsonSerializer();
Reemplace Program.cs en un proyecto .NET Core con el ejemplo anterior. Para obtener instrucciones,
consulte AWS Lambda Paquete de implementación en C# (p. 433).
Python 3
En el siguiente ejemplo, se procesan los mensajes de DynamoDB, y registra su contenido.
Example ProcessDynamoDBStream.py
229
AWS Lambda Guía para desarrolladores
Plantilla de muestra
Comprima el código de muestra para crear un paquete de implementación. Para obtener instrucciones,
consulte Paquete de implementación de AWS Lambda en Python (p. 352).
Go
En el siguiente ejemplo, se procesan los mensajes de DynamoDB, y registra su contenido.
Example
import (
"strings"
"github.com/aws/aws-lambda-go/events"
)
Compile el ejecutable con go build y cree un paquete de implementación. Para obtener instrucciones,
consulte Paquete de implementación de AWS Lambda en Go (p. 417).
A continuación, hay una plantilla AWS SAM de muestra para la aplicación del tutorial (p. 223). Copie el
texto siguiente en un archivo .yaml y guárdelo junto al paquete ZIP que ha creado anteriormente. Tenga en
cuenta que los valores de los parámetros Handler y Runtime deben coincidir con los que utilizó cuando
creó la función en la sección anterior.
Example template.yaml
AWSTemplateFormatVersion: '2010-09-09'
Transform: AWS::Serverless-2016-10-31
Resources:
230
AWS Lambda Guía para desarrolladores
EC2
ProcessDynamoDBStream:
Type: AWS::Serverless::Function
Properties:
Handler: handler
Runtime: runtime
Policies: AWSLambdaDynamoDBExecutionRole
Events:
Stream:
Type: DynamoDB
Properties:
Stream: !GetAtt DynamoDBTable.StreamArn
BatchSize: 100
StartingPosition: TRIM_HORIZON
DynamoDBTable:
Type: AWS::DynamoDB::Table
Properties:
AttributeDefinitions:
- AttributeName: id
AttributeType: S
KeySchema:
- AttributeName: id
KeyType: HASH
ProvisionedThroughput:
ReadCapacityUnits: 5
WriteCapacityUnits: 5
StreamSpecification:
StreamViewType: NEW_IMAGE
Para obtener más información sobre cómo empaquetar e implementar una aplicación sin servidor usando
los comandos de empaquetado e implementación, consulte Implementación de aplicaciones sin servidor
en la Guía para desarrolladores de Modelo de aplicación sin servidor de AWS.
Eventos de CloudWatch invoca su función de Lambda de forma asíncrona con el documento de evento de
Amazon EC2.
{
"version": "0",
"id": "b6ba298a-7732-2226-xmpl-976312c1a050",
"detail-type": "EC2 Instance State-change Notification",
"source": "aws.ec2",
"account": "123456798012",
"time": "2019-10-02T17:59:30Z",
"region": "us-east-2",
"resources": [
"arn:aws:ec2:us-east-2:123456798012:instance/i-0c314xmplcd5b8173"
],
"detail": {
231
AWS Lambda Guía para desarrolladores
Permisos
"instance-id": "i-0c314xmplcd5b8173",
"state": "running"
}
}
Para obtener información detallada sobre la configuración de eventos en Eventos de CloudWatch, consulte
Uso de AWS Lambda con Amazon CloudWatch Events (p. 196). Para ver una función de ejemplo que
procesa las notificaciones de instantáneas de Amazon EBS, consulte Amazon CloudWatch Events para
Amazon EBS en Guía del usuario de Amazon EC2 para instancias de Linux.
También puede utilizar AWS SDK para administrar instancias y otros recursos con la API de Amazon EC2.
Para ver un tutorial con una aplicación de ejemplo en C#, consulte Tutorial: Uso de AWS SDK para .NET
para administrar instancias de spot de Amazon EC2 (p. 232).
Permisos
Para procesar eventos del ciclo de vida desde Amazon EC2, Eventos de CloudWatch necesita permiso
para invocar su función. Este permiso proviene de la política basada en recursos (p. 37) de la función. Si
utiliza la consola de Eventos de CloudWatch para configurar un desencadenador de eventos, la consola
actualiza la directiva basada en recursos en su nombre. De lo contrario, agregue una declaración como la
siguiente:
Example Instrucción de una política basada en recursos para notificaciones del ciclo de vida de
Amazon EC2
{
"Sid": "ec2-events",
"Effect": "Allow",
"Principal": {
"Service": "events.amazonaws.com"
},
"Action": "lambda:InvokeFunction",
"Resource": "arn:aws:lambda:us-east-2:12456789012:function:my-function",
"Condition": {
"ArnLike": {
"AWS:SourceArn": "arn:aws:events:us-east-2:12456789012:rule/*"
}
}
}
Si la función utiliza el SDK de AWS para administrar recursos de Amazon EC2, agregue permisos de
Amazon EC2 al rol de ejecución (p. 33) de la función.
232
AWS Lambda Guía para desarrolladores
Tutorial: Instancias de spot
Este tutorial proporciona código que realiza estas tareas y una aplicación de ejemplo que puede ejecutar
localmente o en AWS. Incluye un proyecto de ejemplo que puede implementar en el tiempo de ejecución
de .NET Core 2.1 de AWS Lambda.
Para obtener más información sobre el uso de instancias de spot y prácticas recomendadas, consulte
Instancias de spot en la guía de usuario de Amazon EC2.
Requisitos previos
Para seguir los procedimientos de esta guía, necesitará un shell o un terminal de línea de comando donde
pueda ejecutar los comandos. Los comandos aparecen en listas y van precedidos del símbolo del sistema
($) y del nombre del directorio actual, si es aplicable:
Para los comandos largos, se utiliza un carácter de escape (\) para dividir un comando en varias líneas.
En Linux y macOS, use su administrador de shell y paquetes preferido. En Windows 10, puede instalar
Windows Subsystem para Linux para obtener una versión de Ubuntu y Bash integrada con Windows.
233
AWS Lambda Guía para desarrolladores
Tutorial: Instancias de spot
Este tutorial utiliza código del repositorio de GitHub de la guía para desarrolladores. El repositorio también
contiene scripts auxiliares y archivos de configuración necesarios para seguir sus procedimientos. Clone el
repositorio en github.com/awsdocs/aws-lambda-developer-guide.
• AWS CLI: para implementar la aplicación de muestra en AWS, instale la AWS CLI. La AWS CLI también
proporciona credenciales al código de muestra cuando se ejecuta localmente.
• CLI de .NET Core: para ejecutar y probar el código localmente, instale .NET Core SDK 2.1.
• Herramienta global de .NET Core de Lambda: para crear el paquete de implementación para Lambda,
instale la Herramienta global de .NET Core con la CLI de .NET Core.
El código de este tutorial administra las solicitudes de spot que lanzan instancias Amazon EC2. Para
ejecutar el código localmente, necesita credenciales de SDK con permiso para usar las siguientes API.
• ec2:RequestSpotInstance
• ec2:GetSpotRequestState
• ec2:CancelSpotRequest
• ec2:TerminateInstances
Para ejecutar la aplicación de ejemplo en AWS, necesita permiso para usar Lambda (p. 33) y los siguientes
servicios.
Revise el código
Localice el proyecto de ejemplo en el repositorio de guías en sample-apps/ec2-spot. Este directorio
contiene código de función de Lambda, pruebas, archivos de proyecto, scripts y una plantilla de AWS
CloudFormation.
La clase Function incluye un método FunctionHandler que llama a otros métodos para crear
solicitudes de spot, comprobar su estado y limpiar. Crea un cliente Amazon EC2 con el AWS SDK
para .NET en un constructor estático para permitir que se use en toda la clase.
using Amazon.EC2;
...
public class Function
{
private static AmazonEC2Client ec2Client;
static Function() {
AWSSDKHandler.RegisterXRayForAllServices();
ec2Client = new AmazonEC2Client();
}
234
AWS Lambda Guía para desarrolladores
Tutorial: Instancias de spot
using Amazon;
using Amazon.Util;
using Amazon.EC2;
using Amazon.EC2.Model;
...
public async Task<RequestSpotInstancesResponse> RequestSpotInstance(
string amiId,
string securityGroupName,
InstanceType instanceType,
string spotPrice,
int instanceCount)
{
var request = new RequestSpotInstancesRequest();
request.SpotPrice = spotPrice;
request.InstanceCount = instanceCount;
request.LaunchSpecification = launchSpecification;
return response;
}
...
A continuación, debemos esperar hasta que la solicitud de spot alcance el estado Active antes
de continuar con el último paso. Para determinar el estado de la solicitud de spot, utilice el método
DescribeSpotInstanceRequests para obtener el estado del ID de solicitud de spot que deseamos
monitorizar.
return describeResponse.SpotInstanceRequests[0];
235
AWS Lambda Guía para desarrolladores
Tutorial: Instancias de spot
El paso final consiste en limpiar las instancias y solicitudes. Es importante tanto para cancelar cualquier
solicitud pendiente como para terminar cualquier instancia. Las instancias no terminarán con solo
cancelarse las solicitudes, lo que significa que se le seguirá cobrando por ellas. Si termina las instancias,
es posible que se cancelen las solicitudes de spot, pero hay algunos escenarios (por ejemplo, si usa
solicitudes persistentes), donde terminar las instancias no es suficiente para evitar que la solicitud vuelva
a atenderse. Por lo tanto, se recomienda tanto cancelar cualquier solicitud activa como terminar cualquier
instancia en ejecución.
Puede usar el método CancelSpotInstanceRequests para cancelar una solicitud de spot. En el siguiente
ejemplo se muestra cómo cancelar una solicitud de subasta.
await ec2Client.CancelSpotInstanceRequestsAsync(cancelRequest);
}
$ cd test/ec2Spot.Tests
236
AWS Lambda Guía para desarrolladores
Tutorial: Instancias de spot
2. Utilice la CLI de .NET para ejecutar las pruebas de unidad del proyecto.
La prueba de unidad invoca el método FunctionHandler para crear una solicitud de instancia de spot,
supervisarla y limpiarla. Se implementa en el marco de pruebas XUnit.net.
Implementación de la aplicación
Ejecute el código en Lambda como punto de partida para crear una aplicación sin servidor.
$ export AWS_DEFAULT_REGION=us-east-2
$ ./create-bucket.sh
make_bucket: lambda-artifacts-63d5cbbf18fa5ecc
$ ./deploy.sh
Amazon Lambda Tools for .NET Core applications (3.3.0)
Project Home: https://github.com/aws/aws-extensions-for-dotnet-cli, https://github.com/
aws/aws-lambda-dotnet
237
AWS Lambda Guía para desarrolladores
Tutorial: Instancias de spot
Ver los registros y la información de rastreo para ver el ID de solicitud de spot y la secuencia de llamadas a
Amazon EC2.
Para ver el mapa de servicio, abra la página Service map (Mapa de servicio) en la consola de X-Ray.
238
AWS Lambda Guía para desarrolladores
Tutorial: Instancias de spot
Elija un nodo en el mapa de servicio y, a continuación, elija View traces (Ver seguimientos) para ver una
lista de rastreos. Elija un rastreo de la lista para ver la línea de tiempo de las llamadas que efectuó la
función a Amazon EC2.
239
AWS Lambda Guía para desarrolladores
Tutorial: Instancias de spot
Eliminar recursos
El código proporcionado en este tutorial está diseñado para crear y eliminar solicitudes de instancias de
spot y para terminar las instancias que inician. Sin embargo, si se produce un error, es posible que las
240
AWS Lambda Guía para desarrolladores
ElastiCache
Para limpiar la función de ejemplo y los recursos de soporte, elimine su pila de AWS CloudFormation y el
bucket de artefactos que creó.
$ ./cleanup.sh
Delete deployment artifacts and bucket (lambda-artifacts-63d5cbbf18fa5ecc)?y
delete: s3://lambda-artifacts-63d5cbbf18fa5ecc/ebd38e401cedd7d676d05d22b76f0209
remove_bucket: lambda-artifacts-63d5cbbf18fa5ecc
• Crar un clúster de Amazon ElastiCache en su Amazon Virtual Private Cloud predeterminada. Para
obtener más información acerca de Amazon ElastiCache, consulte Amazon ElastiCache.
• Crear una función de Lambda para obtener acceso al clúster de ElastiCache. Al crear la función de
Lambda debe proporcionar los ID de subred de Amazon VPC, así como un grupo de seguridad de VPC
para que la función de Lambda pueda obtener acceso a los recursos de la VPC. En este tutorial, con
fines ilustrativos, la función de Lambda genera un UUID, lo escribe en la caché y lo recupera de esta.
• Invoque la función de Lambda manualmente y verifique que ha tenido acceso al clúster de ElastiCache
de la VPC.
Para obtener más información sobre el uso de Lambda con Amazon VPC, consulte Configuración de una
función de Lambda para obtener acceso a los recursos de una VPC (p. 81).
Requisitos previos
En este tutorial, se le presuponen algunos conocimientos sobre las operaciones básicas de Lambda y la
consola de Lambda. Si aún no lo ha hecho, siga las instrucciones que se indican en Introducción a AWS
Lambda (p. 3) para crear la primera función de Lambda.
Para seguir los procedimientos de esta guía, necesitará un shell o un terminal de línea de comando donde
pueda ejecutar los comandos. Los comandos aparecen en listas y van precedidos del símbolo del sistema
($) y del nombre del directorio actual, si es aplicable:
241
AWS Lambda Guía para desarrolladores
Creación del rol de ejecución
Para los comandos largos, se utiliza un carácter de escape (\) para dividir un comando en varias líneas.
En Linux y macOS, use su administrador de shell y paquetes preferido. En Windows 10, puede instalar
Windows Subsystem para Linux para obtener una versión de Ubuntu y Bash integrada con Windows.
Example app.py
242
AWS Lambda Guía para desarrolladores
Creación de la función de Lambda
import elasticache_auto_discovery
from pymemcache.client.hash import HashClient
#elasticache settings
elasticache_config_endpoint = "your-elasticache-cluster-endpoint:port"
nodes = elasticache_auto_discovery.discover(elasticache_config_endpoint)
nodes = map(lambda x: (x[1], int(x[2])), nodes)
memcache_client = HashClient(nodes)
#Create a random UUID... this will be the sample element we add to the cache.
uuid_inserted = uuid.uuid4().hex
#Put the UUID to the cache.
memcache_client.set('uuid', uuid_inserted)
#Get item (UUID) from the cache.
uuid_obtained = memcache_client.get('uuid')
if uuid_obtained.decode("utf-8") == uuid_inserted:
# this print should go to the CloudWatch Logs and Lambda console.
print ("Success: Fetched value %s from memcache" %(uuid_inserted))
else:
raise Exception("Value is not the same as we put :(. Expected %s got %s"
%(uuid_inserted, uuid_obtained))
Dependencias.
• pymemcache – El código de función de Lambda utiliza esta biblioteca para crear un HashClient objeto
para enviar y recibir elementos de un memcache.
• elasticache-auto-discovery – La función de Lambda usa esta biblioteca para recibir los nodos del clúster
Amazon ElastiCache.
Instale dependencias con Pip y cree un paquete de implementación. Para obtener instrucciones, consulte
Paquete de implementación de AWS Lambda en Python (p. 352).
Puede encontrar los ID de subred y el ID del grupo de seguridad predeterminado de la VPC en la consola
de VPC.
243
AWS Lambda Guía para desarrolladores
Elastic Load Balancing
Ahora que ha creado una función de Lambda que tiene acceso a un clúster de ElastiCache en la VPC,
puede hacer que la función se invoque en respuesta a eventos. Para obtener información acerca de la
configuración de orígenes de eventos y ver ejemplos, consulte Utilización de AWS Lambda con otros
servicios (p. 163).
Elastic Load Balancing invoca la función de Lambda de forma sincrónica con un evento que contiene el
cuerpo de la solicitud y metadatos.
{
"requestContext": {
"elb": {
"targetGroupArn": "arn:aws:elasticloadbalancing:us-
east-2:123456789012:targetgroup/lambda-279XGJDqGZ5rsrHC2Fjr/49e9d65c45c6791a"
}
},
"httpMethod": "GET",
"path": "/lambda",
"queryStringParameters": {
"query": "1234ABCD"
},
"headers": {
"accept": "text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/
apng,*/*;q=0.8",
"accept-encoding": "gzip",
"accept-language": "en-US,en;q=0.9",
"connection": "keep-alive",
"host": "lambda-alb-123578498.us-east-2.elb.amazonaws.com",
"upgrade-insecure-requests": "1",
"user-agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML,
like Gecko) Chrome/71.0.3578.98 Safari/537.36",
"x-amzn-trace-id": "Root=1-5c536348-3d683b8b04734faae651f476",
"x-forwarded-for": "72.12.164.125",
"x-forwarded-port": "80",
"x-forwarded-proto": "http",
"x-imforwards": "20"
},
244
AWS Lambda Guía para desarrolladores
EFS
"body": "",
"isBase64Encoded": false
}
{
"statusCode": 200,
"statusDescription": "200 OK",
"isBase64Encoded": False,
"headers": {
"Content-Type": "text/html"
},
"body": "<h1>Hello from Lambda!</h1>"
}
Utilice el comando add-permission para añadir una instrucción de permiso a la política basada en
recursos de la función.
Para ver instrucciones sobre cómo configurar el agente de escucha de Balanceador de carga de
aplicaciones, consulte la sección sobre funciones de Lambda como destino en la Guía del usuario de
Application Load Balancers.
El sistema de archivos y la función Lambda deben estar en la misma región. Una función Lambda de
una cuenta puede montar un sistema de archivos en una cuenta diferente. En este caso, configure la
interconexión de VPC entre la función VPC y la VPC del sistema de archivos.
Note
Para configurar una función para que se conecte a un sistema de archivos, consulte Configuración
del acceso al sistema de archivos para las funciones Lambda (p. 91).
245
AWS Lambda Guía para desarrolladores
Conexiones
Amazon EFS es compatible con el bloqueo de archivos para evitar daños si varias funciones intentan
escribir en el mismo sistema de archivos al mismo tiempo. Amazon EFS sigue el protocolo NFS v4.1 para
el bloqueo consultivo y permite a sus aplicaciones utilizar bloqueos de todo el archivo o de intervalos del
tamaño de bytes.
Amazon EFS proporciona opciones para personalizar el sistema de archivos en función de la necesidad de
su aplicación de mantener un alto rendimiento a escala. Hay tres factores principales a tener en cuenta: el
número de conexiones, el rendimiento (en MiB por segundo) y las IOPS.
Cuotas
Para obtener detalles sobre las cuotas y los límites del sistema de archivos, consulte Cuotas para
sistemas de archivos de Amazon EFS en la Guía del usuario de Amazon Elastic File System.
Para evitar problemas con el escalado, el rendimiento y las IOPS, monitorice las métricas que Amazon
EFS envía a Amazon CloudWatch. Para obtener información general sobre la monitorización en Amazon
EFS, consulte Monitorización de Amazon EFS en Guía del usuario de Amazon Elastic File System.
Secciones
• Conexiones (p. 246)
• Rendimiento (p. 246)
• IOPS (p. 247)
Conexiones
Amazon EFS admite hasta 25,000 conexiones por sistema de archivos. Durante la inicialización, cada
instancia de una función crea una única conexión a su sistema de archivos que persiste en todas las
invocaciones. Esto significa que puede alcanzar la concurrencia 25,000 a través de una o más funciones
conectadas a un sistema de archivos. Para limitar el número de conexiones que crea una función, utilice la
concurrencia reservada (p. 62).
Sin embargo, cuando realiza cambios en el código o la configuración de su función a escala, hay un
aumento temporal en el número de instancias de función más allá de la concurrencia actual. Lambda
proporciona nuevas instancias para manejar nuevas solicitudes y hay algún retraso antes de que las
instancias antiguas cierren sus conexiones con el sistema de archivos. Para evitar alcanzar el límite
máximo de conexiones durante una implementación, utilice implementaciones continuas (p. 156). Con las
implementaciones continuas, cambia el tráfico gradualmente a la nueva versión cada vez que realiza un
cambio.
Si se conecta al mismo sistema de archivos desde otros servicios como Amazon EC2, también debe tener
en cuenta el comportamiento de escalado de las conexiones en Amazon EFS. Un sistema de archivos
admite la creación de hasta 3000 conexiones en una ráfaga, después de lo cual admite 500 nuevas
conexiones por minuto. Esto coincide con el comportamiento de escalado en ráfaga (p. 114) en Lambda,
que se aplica a todas las funciones de una región. Pero si están creando conexiones fuera de Lambda, es
posible que sus funciones no puedan escalar a toda velocidad.
Para monitorizar y activar una alarma en las conexiones, utilice la métrica ClientConnections.
Rendimiento
A escala, también es posible superar el rendimiento máximo de un sistema de archivos. En el modo de
ráfaga (predeterminado), un sistema de archivos tiene un bajo rendimiento de referencia que escala
linealmente con su tamaño. Para permitir ráfagas de actividad, el sistema de archivos recibe créditos de
ráfaga que le permiten utilizar 100 MiB/s o más de rendimiento. Los créditos se acumulan continuamente y
se gastan con cada operación de lectura y escritura. Si el sistema de archivos se queda sin créditos, limita
las operaciones de lectura y escritura más allá del rendimiento previsto, lo que puede provocar que las
invocaciones se agoten.
246
AWS Lambda Guía para desarrolladores
IOPS
Note
Si utiliza concurrencia provisionada (p. 62), su función puede consumir créditos de ráfaga incluso
cuando está inactiva. Con la concurrencia aprovisionada, Lambda inicializa las instancias de su
función antes de que se invoque y recicla las instancias cada pocas horas. Si utiliza archivos en
un sistema de archivos adjunto durante la inicialización, esta actividad puede utilizar todos los
créditos de ráfaga.
Para supervisar y activar una alarma en el rendimiento, utilice la métrica BurstCreditBalance. Debería
aumentar cuando la concurrencia de su función es baja y disminuir cuando es alta. Si siempre disminuye
o no se acumula lo suficiente durante la actividad baja para cubrir el tráfico máximo, es posible que tenga
que limitar la concurrencia de su función o habilitar el rendimiento provisionado.
IOPS
Las operaciones de entrada/salida por segundo (IOPS) son una medida del número de operaciones de
lectura y escritura procesadas por el sistema de archivos. En el modo propósito general, IOPS están
limitadas a favor de una latencia más baja, lo que es beneficioso para la mayoría de las aplicaciones.
Para supervisar y alarmar en IOPS en modo propósito general, utilice la métrica PercentIOLimit.
Si esta métrica alcanza el 100 %, su función puede agotar el tiempo de espera en espera de que se
completen las operaciones de lectura y escritura.
Puede crear reglas de AWS IoT para que sus dispositivos interactúen con los servicios de AWS. El motor
de reglas de AWS IoT proporciona un lenguaje basado en SQL para seleccionar datos de cargas de
mensajes y enviar los datos a otros servicios como Amazon S3, Amazon DynamoDB y AWS Lambda.
Cuando quiera invocar otro servicio de AWS o un servicio de terceros, defina una regla para invocar una
función Lambda.
Cuando un mensaje de IoT entrante desencadena la regla, AWS IoT invoca su función Lambda de forma
asíncrona (p. 101) y pasa los datos del mensaje de IoT a la función.
El siguiente ejemplo muestra una lectura de humedad del sensor de un invernadero. Los valores row y
pos identifican la ubicación del sensor. Este evento de ejemplo se basa en el tipo de invernadero de los
Tutoriales de reglas de AWS IoT.
{
"row" : "10",
"pos" : "23",
"moisture" : "75"
}
En la invocación asincrónica, Lambda pone en cola el mensaje y, si la función devuelve un error, lo intenta
de nuevo (p. 119). Configure la función con un destino (p. 104) para conservar los eventos que la función
no puede procesar.
Debe conceder permiso para que el servicio AWS IoT invoque su función de Lambda. Utilice el comando
add-permission para añadir una instrucción de permiso a la política basada en recursos de la función.
247
AWS Lambda Guía para desarrolladores
IoT Events
Para obtener más información acerca de cómo utilizar Lambda con AWS IoT, consulte Creación de una
regla de AWS Lambda.
Para usar AWS IoT Events, defina un modelo de detector, que es un modelo de máquina de estado de
su equipo o proceso. Además de los estados, se definen entradas y eventos para el modelo. También se
definen las acciones que se deben realizar cuando se produce un evento. Utilice una función Lambda para
una acción cuando desee invocar otro servicio de AWS (como Amazon Connect) o realizar acciones en
una aplicación externa (como la aplicación de planificación de recursos empresariales (ERP)).
Cuando se produce el evento, AWS IoT Events invoca su función de Lambda de forma asíncrona.
Proporciona información sobre el modelo del detector y el evento que desencadenó la acción. El siguiente
evento de mensaje de ejemplo se basa en las definiciones del ejemplo paso a paso sencillo de AWS IoT
Events.
{
"event: ":{
"eventName": "myChargedEvent",
"eventTime": 1567797571647,
"payload":{
"detector":{
"detectorModelName": "AWS_IoTEvents_Hello_World1567793458261",
"detectorModelVersion": "4",
"keyValue": "100009"
},
"eventTriggerDetails":{
"triggerType": "Message",
"inputName": "AWS_IoTEvents_HelloWorld_VoltageInput",
"messageId": "64c75a34-068b-4a1d-ae58-c16215dc4efd"
},
"actionExecutionId": "49f0f32f-1209-38a7-8a76-d6ca49dd0bc4",
"state":{
"variables": {},
"stateName": "Charged",
"timers": {}
}
}
}
248
AWS Lambda Guía para desarrolladores
Kinesis Firehose
Debe conceder permiso para que el servicio AWS IoT Events invoque su función de Lambda. Utilice el
comando add-permission para añadir una instrucción de permiso a la política basada en recursos de la
función.
Para obtener más información sobre cómo utilizar Lambda con AWS IoT Events, consulte Uso de AWS IoT
Events con otros servicios.
{
"invocationId": "invoked123",
"deliveryStreamArn": "aws:lambda:events",
"region": "us-west-2",
"records": [
{
"data": "SGVsbG8gV29ybGQ=",
"recordId": "record1",
"approximateArrivalTimestamp": 1510772160000,
"kinesisRecordMetadata": {
"shardId": "shardId-000000000000",
"partitionKey": "4d1ad2b9-24f8-4b9d-a088-76e9947c317a",
249
AWS Lambda Guía para desarrolladores
Flujos de Kinesis
"approximateArrivalTimestamp": "2012-04-23T18:25:43.511Z",
"sequenceNumber": "49546986683135544286507457936321625675700192471156785154",
"subsequenceNumber": ""
}
},
{
"data": "SGVsbG8gV29ybGQ=",
"recordId": "record2",
"approximateArrivalTimestamp": 151077216000,
"kinesisRecordMetadata": {
"shardId": "shardId-000000000001",
"partitionKey": "4d1ad2b9-24f8-4b9d-a088-76e9947c318a",
"approximateArrivalTimestamp": "2012-04-23T19:25:43.511Z",
"sequenceNumber": "49546986683135544286507457936321625675700192471156785155",
"subsequenceNumber": ""
}
}
]
}
Para obtener más información, consulte Transformación de datos de Amazon Kinesis Data Firehose en la
Guía para desarrolladores de Kinesis Data Firehose.
Un flujo de datos de Kinesis es un conjunto de particiones. Cada partición contiene una secuencia de
registros de datos. Un consumidor es una aplicación que procesa los datos procedentes de un flujo de
datos de Kinesis. Puede asignar una función Lambda a un consumidor de rendimiento compartido (iterador
estándar) o a un consumidor de rendimiento dedicado con distribución ramificada mejorada.
Para iteradores estándar, Lambda sondea cada partición de la secuencia de Kinesis en busca de registros
utilizando el protocolo HTTP. El mapeo de origen de eventos comparte el rendimiento de lectura con otros
consumidores de la partición.
Para minimizar la latencia y maximizar el rendimiento de lectura, puede crear un consumidor de flujo de
datos con distribución ramificada mejorada. Los consumidores de flujos obtienen una conexión dedicada a
cada partición que no afecta a las demás aplicaciones que leen el flujo. El rendimiento dedicado puede ser
útil si hay muchas aplicaciones que leen los mismos datos, o si se está reprocesando un flujo con registros
de gran tamaño. Kinesis inserta los registros en Lambda a través de HTTP/2.
Para obtener información detallada sobre los flujos de datos de Kinesis, consulte Lectura de datos de
Amazon Kinesis Data Streams.
Note
Lambda lee registros del flujo de datos e invoca la función sincrónicamente (p. 100) con un evento que
contenga registros de flujo. Lambda lee registros en lotes e invoca la función para procesar registros desde
el lote.
{
"Records": [
{
"kinesis": {
250
AWS Lambda Guía para desarrolladores
Flujos de Kinesis
"kinesisSchemaVersion": "1.0",
"partitionKey": "1",
"sequenceNumber":
"49590338271490256608559692538361571095921575989136588898",
"data": "SGVsbG8sIHRoaXMgaXMgYSB0ZXN0Lg==",
"approximateArrivalTimestamp": 1545084650.987
},
"eventSource": "aws:kinesis",
"eventVersion": "1.0",
"eventID":
"shardId-000000000006:49590338271490256608559692538361571095921575989136588898",
"eventName": "aws:kinesis:record",
"invokeIdentityArn": "arn:aws:iam::123456789012:role/lambda-role",
"awsRegion": "us-east-2",
"eventSourceARN": "arn:aws:kinesis:us-east-2:123456789012:stream/lambda-stream"
},
{
"kinesis": {
"kinesisSchemaVersion": "1.0",
"partitionKey": "1",
"sequenceNumber":
"49590338271490256608559692540925702759324208523137515618",
"data": "VGhpcyBpcyBvbmx5IGEgdGVzdC4=",
"approximateArrivalTimestamp": 1545084711.166
},
"eventSource": "aws:kinesis",
"eventVersion": "1.0",
"eventID":
"shardId-000000000006:49590338271490256608559692540925702759324208523137515618",
"eventName": "aws:kinesis:record",
"invokeIdentityArn": "arn:aws:iam::123456789012:role/lambda-role",
"awsRegion": "us-east-2",
"eventSourceARN": "arn:aws:kinesis:us-east-2:123456789012:stream/lambda-stream"
}
]
}
De forma predeterminada, Lambda llama a su función en cuanto los registros están disponibles en el flujo.
Si el lote que lee desde el flujo solo tiene un registro, Lambda solo envía un registro a la función. Para
evitar invocar a la función con un número de registros pequeño, puede indicar al origen del evento que
almacene en búfer registros durante hasta 5 minutos configurando una ventana de lote. Antes de invocar
a la función, Lambda sigue leyendo registros desde el flujo hasta que haya recopilado un lote completo o
hasta que caduca la ventana de lote.
Si la función devuelve un error, Lambda volverá a intentar ejecutar el lote hasta que el procesamiento
se realice correctamente o los datos caduquen. Para evitar particiones detenidas, puede configurar la
asignación del origen de eventos para que vuelva a intentarlo con un tamaño de lote menor, para que limite
el número de reintentos o para que se descarten los registros que sean muy antiguos. Si desea conservar
los eventos descartados, puede configurar la asignación del origen de eventos para que envíe información
sobre los lotes con errores a una cola de SQS o un tema de SNS.
También puede aumentar la simultaneidad procesando varios lotes de cada partición en paralelo. Lambda
puede procesar hasta 10 lotes en cada partición simultáneamente. Si aumenta el número de lotes
simultáneos en cada partición, Lambda seguirá garantizando que el procesamiento se realiza en orden en
el nivel de la clave de partición.
Secciones
• Configurar su flujo de datos y función. (p. 252)
• Permisos de rol de ejecución (p. 252)
• Configuración de una secuencia como un origen de eventos (p. 253)
• API de mapeo de origen de eventos (p. 254)
251
AWS Lambda Guía para desarrolladores
Configurar su flujo de datos y función.
Para los iteradores estándar, Lambda sondea cada partición del flujo de Kinesis y busca registros una vez
por segundo. Cuando hay más registros disponibles, Lambda sigue procesando lotes hasta que la función
se pone al día con el flujo. El mapeo de origen de eventos comparte el rendimiento de lectura con otros
consumidores de la partición.
Para minimizar la latencia y maximizar el rendimiento de lectura, cree un consumidor de flujo de datos
con distribución ramificada mejorada. Los consumidores con distribución ramificada mejorada obtienen
una conexión dedicada a cada partición que no afecta a las demás aplicaciones que leen el flujo. Los
consumidores de flujos utilizan HTTP/2 para reducir la latencia enviando los registros a Lambda a través
de una conexión de larga duración y mediante la compresión de los encabezados de las solicitudes. Es
posible crear un consumidor de flujos con la API RegisterStreamConsumer de Kinesis.
Para incrementar la velocidad con la que la función procesa los registros, añada particiones al flujo de
datos. Lambda procesa los registros de cada partición por orden. Deja de procesar registros adicionales
en una partición si la función devuelve un error. Al haber más particiones, se procesan más lotes
simultáneamente, lo que reduce el impacto de los errores de simultaneidad.
Si la función no puede aumentar para administrar el número total de lotes simultáneos, solicite un aumento
de cuota (p. 31) o reserve la simultaneidad (p. 62) para la función.
• kinesis:DescribeStream
• kinesis:DescribeStreamSummary
• kinesis:GetRecords
• kinesis:GetShardIterator
• kinesis:ListShards
• kinesis:ListStreams
252
AWS Lambda Guía para desarrolladores
Configuración de una secuencia como un origen de eventos
• kinesis:SubscribeToShard
Para enviar registros de un lote con errores a una cola o un tema, la función necesita permisos adicionales.
Cada servicio de destino requiere un permiso diferente, como se indica a continuación:
Para configurar la función para leer de Kinesis en la consola de Lambda, cree un desencadenador de
Kinesis.
Lambda admite las siguientes opciones para los orígenes de eventos de Kinesis.
Tras procesar cualquier registro existente, la función es alcanzada y continúa procesando registros
nuevos.
253
AWS Lambda Guía para desarrolladores
API de mapeo de origen de eventos
• On-failure destination (Destino en caso de error): cola de SQS o tema de SNS de los registros que no
pueden procesarse. Cuando Lambda descarta un lote de registros porque es demasiado antiguo o se
han agotado todos los reintentos, envía información sobre el lote a la cola o al tema.
• Retry attempts (Número de reintentos): número máximo de reintentos que Lambda realiza cuando la
función devuelve un error. No se aplica a los errores ni las limitaciones de los servicios en los que el lote
no alcanza la función.
• Maximum age of record (Antigüedad máxima del registro): antigüedad máxima de un registro que
Lambda envía a la función.
• Split batch on error (Dividir lote en caso de error): cuando la función devuelve un error, el lote se divide
en dos antes de intentarlo de nuevo.
• Process multiple batches from the same shard concurrently (Lotes simultáneos por partición): procesa
simultáneamente varios lotes de la misma partición.
• Enabled (Habilitado): establecer en true para habilitar la asignación de origen de eventos. Establecer
en false el origen de eventos para dejar de procesar registros. Lambda toma nota del último registro
procesado y sigue procesando desde ese punto cuando se habilita de nuevo.
Note
Kinesis cobra por cada partición y, para una distribución ramificada mejorada, por los datos leídos
desde la frecuencia. Para obtener más información sobre precios, consulte precios de Amazon
Kinesis.
Para administrar la configuración de origen de evento más tarde, elija el desencadenador en el diseñador.
Para crear el mapeo de orígenes de eventos con la AWS CLI, use el comando create-event-source-
mapping. En el siguiente ejemplo, se utiliza la AWS CLI para asignar una función denominada my-
function a un flujo de datos de Kinesis. El flujo de datos se especifica mediante un nombre de recurso
de Amazon (ARN) con un tamaño de lote de 500, comenzando desde una marca temporal en tiempo Unix.
254
AWS Lambda Guía para desarrolladores
API de mapeo de origen de eventos
"DestinationConfig": {},
"MaximumRecordAgeInSeconds": 604800,
"BisectBatchOnFunctionError": false,
"MaximumRetryAttempts": 10000
}
Para utilizar un consumidor, especifique el ARN del consumidor en lugar del ARN del flujo.
Configure otras opciones para personalizar el modo en que se procesan los lotes y especificar cuándo
deben descargarse los registros que no se pueden procesar. En el siguiente ejemplo, se actualiza la
asignación de un origen de eventos para enviar un registro de error a una cola de SQS después de dos
reintentos o si los registros tienen más de una hora de antigüedad.
255
AWS Lambda Guía para desarrolladores
Control de errores
--parallelization-factor 5
Control de errores
La asignación del origen de eventos que lee los registros de la secuencia de Kinesis invoca la función de
forma sincrónica y reintenta la operación si se producen errores. Si la función se ve limitada o el servicio de
Lambda devuelve un error sin invocar la función, Lambda vuelve a intentarlo hasta que el registro expira o
supera la antigüedad máxima establecida en la asignación del origen de eventos.
Si la función recibe los registros pero devuelve un error, Lambda lo vuelve a intentar hasta que vencen los
registros del lote, se supera la antigüedad máxima o se alcanza la cuota de reintentos especificada. En el
caso de los errores de funciones, también puede configurar la asignación del origen de eventos para que
divida en dos los lotes que presentan errores. Al intentarlo con lotes más pequeños, se aíslan los registros
erróneos y se solucionan problemas relacionadas con el tiempo de espera. Los lotes divididos no se tienen
en cuenta para calcular la cuota de reintentos.
Si las medidas de administración de errores no funcionan, Lambda descarta los registros y sigue
procesando los lotes de la secuencia. Con la configuración predeterminada, esto significa que un registro
erróneo puede bloquear el procesamiento de la partición afectada durante un máximo de one week.
Para evitar esto, configure la asignación del origen de eventos de la función con un número razonable de
reintentos y una antigüedad de registro máxima que se ajuste a su caso de uso.
Para mantener un registro de los lotes descartados, configure un destino de evento fallido. Lambda enviará
un documento a la cola o al tema de destino con información sobre el lote.
{
"requestContext": {
"requestId": "c9b8fa9f-5a7f-xmpl-af9c-0c604cde93a5",
"functionArn": "arn:aws:lambda:us-east-2:123456789012:function:myfunction",
"condition": "RetryAttemptsExhausted",
"approximateInvokeCount": 1
},
"responseContext": {
"statusCode": 200,
"executedVersion": "$LATEST",
"functionError": "Unhandled"
},
"version": "1.0",
"timestamp": "2019-11-14T00:38:06.021Z",
"KinesisBatchInfo": {
"shardId": "shardId-000000000001",
256
AWS Lambda Guía para desarrolladores
Métricas de Amazon CloudWatch
"startSequenceNumber": "49601189658422359378836298521827638475320189012309704722",
"endSequenceNumber": "49601189658422359378836298522902373528957594348623495186",
"approximateArrivalOfFirstRecord": "2019-11-14T00:38:04.835Z",
"approximateArrivalOfLastRecord": "2019-11-14T00:38:05.580Z",
"batchSize": 500,
"streamArn": "arn:aws:kinesis:us-east-2:123456789012:stream/mystream"
}
}
Puede utilizar esta información para recuperar los registros afectados de la secuencia y solucionar los
problemas. Los registros reales no están incluidos, por lo que debe procesar este registro y recuperarlos
de la secuencia antes de que venzan y se pierdan.
Una tendencia ascendente en la antigüedad del iterador puede indicar problemas con la función. Para
obtener más información, consulte Trabajar con métricas de funciones de AWS Lambda (p. 464).
Requisitos previos
En este tutorial, se le presuponen algunos conocimientos sobre las operaciones básicas de Lambda y la
consola de Lambda. Si aún no lo ha hecho, siga las instrucciones que se indican en Introducción a AWS
Lambda (p. 3) para crear la primera función de Lambda.
Para seguir los procedimientos de esta guía, necesitará un shell o un terminal de línea de comando donde
pueda ejecutar los comandos. Los comandos aparecen en listas y van precedidos del símbolo del sistema
($) y del nombre del directorio actual, si es aplicable:
257
AWS Lambda Guía para desarrolladores
Tutorial
Para los comandos largos, se utiliza un carácter de escape (\) para dividir un comando en varias líneas.
En Linux y macOS, use su administrador de shell y paquetes preferido. En Windows 10, puede instalar
Windows Subsystem para Linux para obtener una versión de Ubuntu y Bash integrada con Windows.
La política AWSLambdaKinesisExecutionRole tiene permisos que la función necesita para leer elementos
de Kinesis y escribir registros a CloudWatch Logs.
Creación de la función
A continuación se muestra código de ejemplo que recibe un evento de Kinesis como entrada y procesa
los mensajes que contiene. Con fines ilustrativos, el código escribe parte de los datos de los eventos de
entrada en CloudWatch Logs.
Note
Para ver código de muestra en otros lenguajes, consulte Código de función de muestra (p. 261).
Example index.js
console.log('Loading function');
258
AWS Lambda Guía para desarrolladores
Tutorial
{
"Records": [
{
"kinesis": {
"kinesisSchemaVersion": "1.0",
"partitionKey": "1",
"sequenceNumber":
"49590338271490256608559692538361571095921575989136588898",
"data": "SGVsbG8sIHRoaXMgaXMgYSB0ZXN0Lg==",
"approximateArrivalTimestamp": 1545084650.987
},
"eventSource": "aws:kinesis",
"eventVersion": "1.0",
"eventID":
"shardId-000000000006:49590338271490256608559692538361571095921575989136588898",
"eventName": "aws:kinesis:record",
"invokeIdentityArn": "arn:aws:iam::123456789012:role/lambda-kinesis-role",
"awsRegion": "us-east-2",
"eventSourceARN": "arn:aws:kinesis:us-east-2:123456789012:stream/lambda-
stream"
}
]
}
259
AWS Lambda Guía para desarrolladores
Tutorial
"Shards": [
{
"ShardId": "shardId-000000000000",
"HashKeyRange": {
"StartingHashKey": "0",
"EndingHashKey": "340282366920746074317682119384634633455"
},
"SequenceNumberRange": {
"StartingSequenceNumber":
"49591073947768692513481539594623130411957558361251844610"
}
}
],
"StreamARN": "arn:aws:kinesis:us-west-2:123456789012:stream/lambda-stream",
"StreamName": "lambda-stream",
"StreamStatus": "ACTIVE",
"RetentionPeriodHours": 24,
"EnhancedMonitoring": [
{
"ShardLevelMetrics": []
}
],
"EncryptionType": "NONE",
"KeyId": null,
"StreamCreationTimestamp": 1544828156.0
}
}
Utilice el ARN del flujo en el siguiente paso para asociar el flujo a la función de Lambda.
Tenga en cuenta el ID de mapeo para un uso posterior. Para obtener una lista de mapeos de orígenes de
eventos, ejecute el comando list-event-source-mappings.
En la respuesta, puede comprobar que el valor de estado es enabled. Los mapeos de orígenes de
eventos se pueden deshabilitar para poner en pausa temporalmente el sondeo sin perder de registros.
Prueba de la configuración
Para probar el mapeo de origen de eventos, añada los registros de eventos a su flujo de Kinesis. El valor
de --data es una cadena que la CLI codifica en base64 antes de enviarlo a Kinesis. Puede ejecutar el
mismo comando más de una vez para añadir varios registros al flujo.
Lambda utiliza el rol de ejecución para leer los registros desde el flujo. A continuación, se invoca la función
de Lambda y se pasan lotes de registros. La función descodifica los datos de cada registro y los registra,
enviando la salida a CloudWatch Logs. Puede ver los registros en la consola deCloudWatch.
260
AWS Lambda Guía para desarrolladores
Código de muestra
El código de muestra está disponible para los lenguajes que se indican a continuación.
Temas
• Node.js 8 (p. 261)
• Java 11 (p. 261)
• C# (p. 262)
• Python 3 (p. 263)
• Go (p. 263)
Node.js 8
A continuación se muestra código de ejemplo que recibe un evento de Kinesis como entrada y procesa
los mensajes que contiene. Con fines ilustrativos, el código escribe parte de los datos de los eventos de
entrada en CloudWatch Logs.
Example index.js
console.log('Loading function');
Comprima el código de muestra para crear un paquete de implementación. Para obtener instrucciones,
consulte Paquete de implementación de AWS Lambda en Node.js (p. 336).
Java 11
A continuación, se muestra código de ejemplo de Java que recibe datos de registros de eventos de Kinesis
como entrada y los procesa. Con fines ilustrativos, el código escribe parte de los datos de los eventos de
entrada en CloudWatch Logs.
Example ProcessKinesisEvents.java
package example;
import com.amazonaws.services.lambda.runtime.Context;
261
AWS Lambda Guía para desarrolladores
Código de muestra
import com.amazonaws.services.lambda.runtime.RequestHandler;
import com.amazonaws.services.lambda.runtime.events.KinesisEvent;
import com.amazonaws.services.lambda.runtime.events.KinesisEvent.KinesisEventRecord;
Si el controlador vuelve normalmente sin excepciones, Lambda considera que el lote de registros de
entrada se ha procesado correctamente y empieza a leer nuevos registros en el flujo. Si el controlador
genera una excepción, Lambda considera que el lote de registros de entrada no se ha procesado e invoca
de nuevo la función con el mismo lote de registros.
Dependencias.
• aws-lambda-java-core
• aws-lambda-java-events
• aws-java-sdk
Cree el código con las dependencias de la biblioteca de Lambda para crear un paquete de
implementación. Para obtener instrucciones, consulte Paquete de implementación de AWS Lambda en
Java (p. 386).
C#
A continuación, se muestra código de ejemplo de C# que recibe datos de registros de eventos de Kinesis
como entrada y los procesa. Con fines ilustrativos, el código escribe parte de los datos de los eventos de
entrada en CloudWatch Logs.
Example ProcessingKinesisEvents.cs
using System;
using System.IO;
using System.Text;
using Amazon.Lambda.Core;
using Amazon.Lambda.KinesisEvents;
namespace KinesisStreams
{
public class KinesisSample
{
[LambdaSerializer(typeof(JsonSerializer))]
public void HandleKinesisRecord(KinesisEvent kinesisEvent)
{
Console.WriteLine($"Beginning to process {kinesisEvent.Records.Count}
records...");
262
AWS Lambda Guía para desarrolladores
Código de muestra
Reemplace Program.cs en un proyecto .NET Core con el ejemplo anterior. Para obtener instrucciones,
consulte AWS Lambda Paquete de implementación en C# (p. 433).
Python 3
A continuación se muestra código de ejemplo de Python que recibe datos de registros de eventos de
Kinesis como entrada y los procesa. Con fines ilustrativos, el código escribe parte de los datos de los
eventos de entrada en CloudWatch Logs.
Example ProcessKinesisRecords.py
Comprima el código de muestra para crear un paquete de implementación. Para obtener instrucciones,
consulte Paquete de implementación de AWS Lambda en Python (p. 352).
Go
A continuación se muestra código de ejemplo de Go que recibe datos de registros de eventos de Kinesis
como entrada y los procesa. Con fines ilustrativos, el código escribe parte de los datos de los eventos de
entrada en CloudWatch Logs.
Example ProcessKinesisRecords.go
import (
"strings"
"github.com/aws/aws-lambda-go/events"
)
263
AWS Lambda Guía para desarrolladores
Plantilla de muestra
dataText := string(dataBytes)
Compile el ejecutable con go build y cree un paquete de implementación. Para obtener instrucciones,
consulte Paquete de implementación de AWS Lambda en Go (p. 417).
A continuación, hay una plantilla AWS SAM de muestra para la aplicación de Lambda del
tutorial (p. 257). La función y controlador de la plantilla corresponden al código de Node.js. Si utiliza un
código de muestra diferente, actualice los valores en consecuencia.
AWSTemplateFormatVersion: '2010-09-09'
Transform: AWS::Serverless-2016-10-31
Resources:
LambdaFunction:
Type: AWS::Serverless::Function
Properties:
Handler: index.handler
Runtime: nodejs12.x
Timeout: 10
Tracing: Active
Events:
Stream:
Type: Kinesis
Properties:
Stream: !GetAtt stream.Arn
BatchSize: 100
StartingPosition: LATEST
stream:
Type: AWS::Kinesis::Stream
Properties:
ShardCount: 1
Outputs:
FunctionName:
Description: "Function name"
Value: !Ref LambdaFunction
StreamARN:
Description: "Stream ARN"
Value: !GetAtt stream.Arn
La plantilla crea una función de Lambda, un flujo de Kinesis y un mapeo de origen de eventos. El mapeo
de origen de eventos lee del flujo e invoca la función.
Para utilizar un consumidor de flujos HTTP/2 (p. 252), cree el consumidor en la plantilla y configure el
mapeo de origen de eventos para que lea del consumidor en lugar de leer del flujo.
AWSTemplateFormatVersion: '2010-09-09'
Transform: AWS::Serverless-2016-10-31
264
AWS Lambda Guía para desarrolladores
Lex
Para obtener más información sobre cómo empaquetar e implementar una aplicación sin servidor usando
los comandos de empaquetado e implementación, consulte Implementación de aplicaciones sin servidor
en la Guía para desarrolladores de Modelo de aplicación sin servidor de AWS.
Al configurar un bot de Amazon Lex, puede especificar una función de Lambda para llevar a cabo la
validación, el procesamiento o ambos. Para la validación, Amazon Lex invoca la función de Lambda
después de cada respuesta del usuario. La función de Lambda puede validar la respuesta y proporcionar
retroalimentación correctiva al usuario, si es necesario. Para el procesamiento, Amazon Lex invoca la
función de Lambda para procesar la solicitud del usuario una vez que el bot haya recopilado correctamente
toda la información requerida y haya recibido la confirmación del usuario.
Puede administrar la simultaneidad de la función de Lambda (p. 62) para controlar el número máximo de
conversaciones de bot simultáneas que se pueden atender. La API de Amazon Lex devuelve un código de
estado HTTP 429 (Too Many Requests (Demasiadas solicitudes)) si se alcanza la simultaneidad máxima
de la función.
La API devuelve un código de estado HTTP 424 (Dependency Failed Exception (Excepción con error de
dependencia)) si la función Lambda genera una excepción.
265
AWS Lambda Guía para desarrolladores
Lex
El bot de Amazon Lex invoca la función de Lambda de forma síncrona (p. 100). El parámetro de evento
contiene información sobre el bot y el valor de cada ranura del diálogo. El parámetro invocationSource
indica si la función de Lambda debe validar las entradas (DialogCodeHook) o procesar la intención
(FulfillmentCodeHook).
{
"messageVersion": "1.0",
"invocationSource": "FulfillmentCodeHook",
"userId": "ABCD1234",
"sessionAttributes": {
"key1": "value1",
"key2": "value2",
},
"bot": {
"name": "OrderFlowers",
"alias": "prod",
"version": "1"
},
"outputDialogMode": "Text",
"currentIntent": {
"name": "OrderFlowers",
"slots": {
"FlowerType": "lilies",
"PickupDate": "2030-11-08",
"PickupTime": "10:00"
},
"confirmationStatus": "Confirmed"
}
}
Amazon Lex espera una respuesta de una función de Lambda con el siguiente formato: El campo
dialogAction es obligatorio. Los campos sessionAttributes y recentIntentSummaryView son
opcionales.
{
"sessionAttributes": {
"key1": "value1",
"key2": "value2"
...
},
"recentIntentSummaryView": [
{
"intentName": "Name",
"checkpointLabel": "Label",
"slots": {
"slot name": "value",
"slot name": "value"
},
"confirmationStatus": "None, Confirmed, or Denied (intent confirmation, if
configured)",
"dialogActionType": "ElicitIntent, ElicitSlot, ConfirmIntent, Delegate, or Close",
"fulfillmentState": "Fulfilled or Failed",
"slotToElicit": "Next slot to elicit
}
],
"dialogAction": {
"type": "Close",
"fulfillmentState": "Fulfilled",
"message": {
266
AWS Lambda Guía para desarrolladores
Roles y permisos
"contentType": "PlainText",
"content": "Thanks, your pizza has been ordered."
},
"responseCard": {
"version": integer-value,
"contentType": "application/vnd.amazonaws.card.generic",
"genericAttachments": [
{
"title":"card-title",
"subTitle":"card-sub-title",
"imageUrl":"URL of the image to be shown",
"attachmentLinkUrl":"URL of the attachment to be associated with the card",
"buttons":[
{
"text":"button-text",
"value":"Value sent to server on button click"
}
]
}
]
}
}
}
Tenga en cuenta que los campos adicionales necesarios para dialogAction varían según el valor
del campo type. Para obtener más información acerca de los campos de evento y respuesta, consulte
Formato del evento de entrada y de la respuesta de la Lambda en la Guía para desarrolladores de Amazon
Lex. Para ver un tutorial de ejemplo que muestra cómo utilizar Lambda con Amazon Lex, consulte Ejercicio
1: creación de un bot de Amazon Lex mediante un proyecto en la Guía para desarrolladores de Amazon
Lex.
Roles y permisos
Debe configurar un rol vinculado a servicio como rol de ejecución (p. 33) de la función. Amazon Lex define
el rol vinculado a servicio con permisos predefinidos. Al crear un bot de Amazon Lex mediante la consola,
el rol vinculado a servicio se crea automáticamente. Para crear un rol vinculado a servicio con la CLI de
AWS, utilice el comando create-service-linked-role.
{
"Role": {
"AssumeRolePolicyDocument": {
"Version": "2012-10-17",
"Statement": [
{
"Action": "sts:AssumeRole",
"Effect": "Allow",
"Principal": {
"Service": "lex.amazonaws.com"
}
}
]
},
"RoleName": "AWSServiceRoleForLexBots",
"Path": "/aws-service-role/lex.amazonaws.com/",
"Arn": "arn:aws:iam::account-id:role/aws-service-role/lex.amazonaws.com/
AWSServiceRoleForLexBots"
}
267
AWS Lambda Guía para desarrolladores
RDS
Si la función de Lambda utiliza otros servicios de AWS, debe agregar los permisos correspondientes al rol
vinculado a servicio.
Utilice una política de permisos basada en recursos para permitir que la intención de Amazon Lex
invoque la función de Lambda. Si utiliza la consola de Amazon Lex, la política de permisos se crea
automáticamente. En la CLI de AWS, utilice el comando Lambda add-permission para establecer el
permiso. En el ejemplo siguiente, se establece el permiso para la intención OrderFlowers.
{
"Records": [
{
"EventVersion": "1.0",
"EventSubscriptionArn": "arn:aws:sns:us-east-2:123456789012:rds-lambda:21be56ed-
a058-49f5-8c98-aedd2564c486",
"EventSource": "aws:sns",
"Sns": {
"SignatureVersion": "1",
"Timestamp": "2019-01-02T12:45:07.000Z",
"Signature": "tcc6faL2yUC6dgZdmrwh1Y4cGa/ebXEkAi6RibDsvpi+tE/1+82j...65r==",
"SigningCertUrl": "https://sns.us-east-2.amazonaws.com/SimpleNotificationService-
ac565b8b1a6c5d002d285f9598aa1d9b.pem",
"MessageId": "95df01b4-ee98-5cb9-9903-4c221d41eb5e",
"Message": "{\"Event Source\":\"db-instance\",\"Event Time\":\"2019-01-02
12:45:06.000\",\"Identifier Link\":\"https://console.aws.amazon.com/rds/home?region=eu-
west-1#dbinstance:id=dbinstanceid\",\"Source ID\":\"dbinstanceid\",\"Event ID\":\"http://
docs.amazonwebservices.com/AmazonRDS/latest/UserGuide/USER_Events.html#RDS-EVENT-0002\",
\"Event Message\":\"Finished DB Instance backup\"}",
"MessageAttributes": {},
"Type": "Notification",
"UnsubscribeUrl": "https://sns.us-east-2.amazonaws.com/?
Action=Unsubscribe&SubscriptionArn=arn:aws:sns:us-east-2:123456789012:test-
lambda:21be56ed-a058-49f5-8c98-aedd2564c486",
"TopicArn":"arn:aws:sns:us-east-2:123456789012:sns-lambda",
"Subject": "RDS Notification Message"
}
}
]
268
AWS Lambda Guía para desarrolladores
Tutorial: Amazon RDS
Para obtener instrucciones sobre cómo configurar una base de datos de Amazon RDS para enviar
notificaciones, consulte Uso de las notificaciones de eventos de Amazon RDS en la Guía del usuario de
Amazon Relational Database Service.
Para obtener más información sobre cómo utilizar Amazon SNS como disparador, consulte Uso de AWS
Lambda con Amazon SNS (p. 290).
Temas
• Tutorial: Configuración de una función de Lambda para obtener acceso a Amazon RDS en una
Amazon VPC (p. 269)
• Lanzar una instancia del motor de base de datos MySQL de Amazon RDS en la Amazon VPC
predeterminada. En la instancia de MySQL, debe crear una base de datos (ExampleDB) con una tabla
de muestra (Employee). Para obtener más información acerca de Amazon RDS, consulte Amazon RDS.
• Crear una función de Lambda para obtener acceso a la base de datos ExampleDB, crear una tabla
(Employee), añadir algunos registros y recuperar los registros de la tabla.
• Invocar la función de Lambda y verificar los resultados de la consulta. De este modo, se comprueba que
la función de Lambda ha podido tener acceso a la instancia de MySQL de RDS en la VPC.
Para obtener más información sobre el uso de Lambda con Amazon VPC, consulte Configuración de una
función de Lambda para obtener acceso a los recursos de una VPC (p. 81).
Requisitos previos
En este tutorial, se le presuponen algunos conocimientos sobre las operaciones básicas de Lambda y la
consola de Lambda. Si aún no lo ha hecho, siga las instrucciones que se indican en Introducción a AWS
Lambda (p. 3) para crear la primera función de Lambda.
Para seguir los procedimientos de esta guía, necesitará un shell o un terminal de línea de comando donde
pueda ejecutar los comandos. Los comandos aparecen en listas y van precedidos del símbolo del sistema
($) y del nombre del directorio actual, si es aplicable:
Para los comandos largos, se utiliza un carácter de escape (\) para dividir un comando en varias líneas.
En Linux y macOS, use su administrador de shell y paquetes preferido. En Windows 10, puede instalar
Windows Subsystem para Linux para obtener una versión de Ubuntu y Bash integrada con Windows.
269
AWS Lambda Guía para desarrolladores
Tutorial: Amazon RDS
Employee(EmpID, Name)
Donde EmpID es la clave principal. Ahora, debe añadir algunos registros a esta tabla.
En primer lugar, lance una instancia de MySQL de RDS en la VPC predeterminada con la base de datos
ExampleDB. Si ya tiene una instancia de MySQL de RDS ejecutándose en la VPC predeterminada, omita
este paso.
Puede lanzar una instancia de MySQL de RDS utilizando uno de los siguientes métodos:
• Siga las instrucciones de Crear una instancia de base de datos MySQL y conectarse a una base de
datos en una instancia de base de datos MySQL en la Guía del usuario de Amazon RDS.
• Use el siguiente comando: AWS CLI
Anote el nombre de la base de datos, el nombre de usuario y la contraseña. Necesitará la dirección del
cliente (punto de enlace) de la base de datos que puede obtener en la consola de RDS. Puede que tenga
que esperar hasta que el estado de la instancia esté disponible y el valor del punto de enlace aparezca en
la consola.
Example app.py
import sys
import logging
270
AWS Lambda Guía para desarrolladores
Tutorial: Amazon RDS
import rds_config
import pymysql
#rds settings
rds_host = "rds-instance-endpoint"
name = rds_config.db_username
password = rds_config.db_password
db_name = rds_config.db_name
logger = logging.getLogger()
logger.setLevel(logging.INFO)
try:
conn = pymysql.connect(rds_host, user=name, passwd=password, db=db_name,
connect_timeout=5)
except pymysql.MySQLError as e:
logger.error("ERROR: Unexpected error: Could not connect to MySQL instance.")
logger.error(e)
sys.exit()
item_count = 0
Ejecutar pymysql.connect() fuera del controlador permite que la función reutilice la conexión a la base
de datos para un rendimiento mejor.
Dependencias.
• pymysql: el código de la función de Lambda utiliza esta biblioteca para obtener acceso a la instancia de
MySQL (consulte PyMySQL).
Instale dependencias con Pip y cree un paquete de implementación. Para obtener instrucciones, consulte
Paquete de implementación de AWS Lambda en Python (p. 352).
271
AWS Lambda Guía para desarrolladores
S3
Ahora que ha creado una función de Lambda que tiene accede a una base de datos en la VPC,
puede hacer que la función se invoque en respuesta a eventos. Para obtener información acerca de la
configuración de orígenes de eventos y ver ejemplos, consulte Utilización de AWS Lambda con otros
servicios (p. 163).
Si la función de Lambda utiliza el mismo bucket que la activa, podría provocar la ejecución de la
función en un bucle. Por ejemplo, si el bucket activa una función cada vez que se carga un objeto
y la función carga un objeto en el bucket, la función se activa indirectamente a sí misma. Para
evitarlo, utilice dos buckets o configure el desencadenador para que solo se aplique a un prefijo
que se utiliza para los objetos entrantes.
Amazon S3 invoca la función de forma asíncrona (p. 101) con un evento que contiene detalles sobre el
objeto. En el siguiente ejemplo se muestra un evento que envió Amazon S3 cuando se cargó un paquete
de implementación en Amazon S3.
272
AWS Lambda Guía para desarrolladores
Tutorial
"Records": [
{
"eventVersion": "2.1",
"eventSource": "aws:s3",
"awsRegion": "us-east-2",
"eventTime": "2019-09-03T19:37:27.192Z",
"eventName": "ObjectCreated:Put",
"userIdentity": {
"principalId": "AWS:AIDAINPONIXQXHT3IKHL2"
},
"requestParameters": {
"sourceIPAddress": "205.255.255.255"
},
"responseElements": {
"x-amz-request-id": "D82B88E5F771F645",
"x-amz-id-2":
"vlR7PnpV2Ce81l0PRw6jlUpck7Jo5ZsQjryTjKlc5aLWGVHPZLj5NeC6qMa0emYBDXOo6QBU0Wo="
},
"s3": {
"s3SchemaVersion": "1.0",
"configurationId": "828aa6fc-f7b5-4305-8584-487c791949c1",
"bucket": {
"name": "lambda-artifacts-deafc19498e3f2df",
"ownerIdentity": {
"principalId": "A3I5XTEXAMAI3E"
},
"arn": "arn:aws:s3:::lambda-artifacts-deafc19498e3f2df"
},
"object": {
"key": "b21b84d653bb07b05b1e6b33684dc11b",
"size": 1305107,
"eTag": "b21b84d653bb07b05b1e6b33684dc11b",
"sequencer": "0C0F6F405D6ED209E1"
}
}
}
]
}
Para invocar la función, Amazon S3 necesita permiso de la política basada en recursos (p. 37) de la
función. Al configurar un desencadenador de Amazon S3 en la consola de Lambda, esta modifica la
política basada en recursos para permitir a Amazon S3 invocar la función si el nombre del bucket y el ID
de cuenta coinciden. Si configura la notificación en Amazon S3, utilice la API de Lambda para actualizar
la política. También puede utilizar la API de Lambda para conceder permisos a otra cuenta o restringir el
permiso a un alias designado.
Si la función utiliza el SDK de AWS para administrar los recursos de Amazon S3, también necesita
permisos de Amazon S3 en su rol de ejecución (p. 33).
Temas
• Tutorial: uso de AWS Lambda con Amazon S3 (p. 273)
• Código de función de muestra de Amazon S3 (p. 280)
• Plantilla de AWS SAM para una aplicación de Amazon S3 (p. 286)
273
AWS Lambda Guía para desarrolladores
Tutorial
Al completar este tutorial, tendrá los siguientes recursos de Amazon S3, Lambda y IAM en su cuenta.
Recursos de Lambda
Recursos de IAM
• Un rol de ejecución que da permisos que la función de Lambda necesita a través de la política de
permisos asociada a este rol.
Recursos de Amazon S3
• Un bucket de origen con una configuración de notificación que invoca la función de Lambda.
• Un bucket de destino donde la función guarda las imágenes modificadas.
Requisitos previos
En este tutorial, se le presuponen algunos conocimientos sobre las operaciones básicas de Lambda y la
consola de Lambda. Si aún no lo ha hecho, siga las instrucciones que se indican en Introducción a AWS
Lambda (p. 3) para crear la primera función de Lambda.
Para seguir los procedimientos de esta guía, necesitará un shell o un terminal de línea de comando donde
pueda ejecutar los comandos. Los comandos aparecen en listas y van precedidos del símbolo del sistema
($) y del nombre del directorio actual, si es aplicable:
Para los comandos largos, se utiliza un carácter de escape (\) para dividir un comando en varias líneas.
274
AWS Lambda Guía para desarrolladores
Tutorial
En Linux y macOS, use su administrador de shell y paquetes preferido. En Windows 10, puede instalar
Windows Subsystem para Linux para obtener una versión de Ubuntu y Bash integrada con Windows.
El tutorial utiliza comandos de la CLI de AWS para crear e invocar la función de Lambda. Instale la CLI de
AWS y configúrela con sus credenciales de AWS
La política AWSLambdaExecute tiene permisos que la función necesita para administrar objetos en
Amazon S3 y escribir registros a CloudWatch Logs.
Al invocar la función de Lambda manualmente antes de conectarse a Amazon S3, debe pasar los datos
del evento de muestra a la función que especifica el bucket de origen, y HappyFace.jpg como objeto
recién creado, por lo que necesita crear este objeto de muestra primero.
Creación de la función
El siguiente código de ejemplo recibe un evento de Amazon S3 y procesa el mensaje que contiene.
Modifica una imagen en el bucket de origen y guarda la salida en el bucket de destino.
Note
Para ver código de muestra en otros lenguajes, consulte Código de función de muestra de
Amazon S3 (p. 280).
Example index.js
// dependencies
const AWS = require('aws-sdk');
275
AWS Lambda Guía para desarrolladores
Tutorial
try {
const params = {
Bucket: srcBucket,
Key: srcKey
};
var origimage = await s3.getObject(params).promise();
} catch (error) {
console.log(error);
return;
}
// set thumbnail width. Resize will set the height automatically to maintain aspect
ratio.
const width = 200;
// Use the Sharp module to resize the image and save in a buffer.
try {
var buffer = await sharp(origimage.Body).resize(width).toBuffer();
} catch (error) {
console.log(error);
return;
}
276
AWS Lambda Guía para desarrolladores
Tutorial
} catch (error) {
console.log(error);
return;
}
• La función conoce el nombre del bucket de origen y el nombre de la clave de objeto a partir de los datos
del evento que recibe como parámetros. Si el objeto es una imagen .jpg o .png, el código crea una
miniatura y la guarda en el bucket de destino.
• El código presupone que el bucket de destino existe y que su nombre es una concatenación del nombre
del bucket de origen seguido por la cadena -resized. Por ejemplo, si el bucket de origen identificado
en los datos del evento es examplebucket, el código presupone que existe un bucket de destino
denominado examplebucket-resized.
• Para generar el nombre de la clave de la miniatura que crea, el código utiliza la cadena resized-
seguida del nombre de la clave del objeto de origen. Por ejemplo, si la clave del objeto de origen es
sample.jpg, el código crea una objeto de miniatura cuya clave es resized-sample.jpg.
El paquete de implementación es un archivo .zip que contiene el código y las dependencias de la función
de Lambda.
lambda-s3
|- index.js
|- /node_modules/sharp
# /node_modules/...
277
AWS Lambda Guía para desarrolladores
Tutorial
En el caso del parámetro del rol, sustituya la secuencia numérica por el ID de la cuenta de AWS. El
comando del ejemplo anterior especifica un tiempo de espera de 10 segundos como configuración de la
función. En función del tamaño de los objetos que cargue, es posible que necesite para aumentar el tiempo
de espera utilizando el siguiente comando de la AWS CLI.
1. Guarde los siguientes datos del evento de muestra de Amazon S3 en un archivo denominado
inputFile.txt. Deberá actualizar el JSON proporcionando el nombre de sourcebucket y una
clave de objeto .jpg.
{
"Records":[
{
"eventVersion":"2.0",
"eventSource":"aws:s3",
"awsRegion":"us-west-2",
"eventTime":"1970-01-01T00:00:00.000Z",
"eventName":"ObjectCreated:Put",
"userIdentity":{
"principalId":"AIDAJDPLRKLG7UEXAMPLE"
},
"requestParameters":{
"sourceIPAddress":"127.0.0.1"
},
"responseElements":{
"x-amz-request-id":"C3D13FE58DE4C810",
"x-amz-id-2":"FMyUVURIY8/IgAtTv8xRjskZQpcIZ9KG4V5Wp6S7S/JRWeUWerMUE5JgHvANOjpD"
},
"s3":{
"s3SchemaVersion":"1.0",
"configurationId":"testConfigRule",
"bucket":{
"name":"sourcebucket",
"ownerIdentity":{
"principalId":"A3NL1KOZZKExample"
},
"arn":"arn:aws:s3:::sourcebucket"
},
"object":{
"key":"HappyFace.jpg",
"size":1024,
"eTag":"d41d8cd98f00b204e9800998ecf8427e",
"versionId":"096fKKXTRTtl3on89fVO.nfljtsv6qko"
}
}
}
]
}
278
AWS Lambda Guía para desarrolladores
Tutorial
2. Ejecute el siguiente comando Lambda de la CLI de invoke para invocar la función. Tenga en
cuenta que el comando solicita la ejecución asíncrona. También puede invocarla de forma síncrona
especificando RequestResponse como valor del parámetro invocation-type.
• Añadir permisos a la política de acceso de la función de Lambda para permitir que Amazon S3 invoque
la función.
• Añadir la configuración de notificaciones al bucket de origen. En la configuración de notificaciones, debe
proporcionar lo siguiente:
• Tipo de evento para el que desea que Amazon S3 publique eventos. Para este tutorial, debe
especificar el tipo de evento s3:ObjectCreated:* con objeto de que Amazon S3 publique eventos
cuando se creen objetos.
• Función de Lambda que se debe invocar.
Añada la configuración de notificaciones al bucket de origen para solicitar a Amazon S3 que publique los
eventos de creación de objetos en Lambda.
Important
Este procedimiento configura el bucket para invocar su función cada vez que se crea un objeto en
él. Asegúrese de configurar esta opción solo en el bucket de origen y no cree objetos en el bucket
de origen a partir de la función que se activa. De lo contrario, su función podría causar que se
invoque continuamente en bucle (p. 272).
279
AWS Lambda Guía para desarrolladores
Código de muestra
• Nombre – lambda-trigger.
• Eventos – ObjectCreate (All)
• Enviar – Lambda function
• Lambda – CreateThumbnail
Para obtener más información sobre la configuración de eventos, consulte Habilitar notificaciones de
eventos en la Guía del usuario de la consola de Amazon Simple Storage Service.
Prueba de la configuración
Ahora puede probar la configuración como se indica a continuación:
1. Cargue objetos .jpg o .png en el bucket de origen mediante la consola de Amazon S3.
2. Verifique que se crea la miniatura en el bucket de destino mediante la función CreateThumbnail.
3. Ver registros en la consola de CloudWatch.
Temas
• Node.js 12.x (p. 280)
• Java 11 (p. 282)
• Python 3 (p. 285)
Node.js 12.x
El siguiente código de ejemplo recibe un evento de Amazon S3 y procesa el mensaje que contiene.
Cambia el tamaño de una imagen en el bucket de origen y guarda la salida en el bucket de destino.
Example index.js
// dependencies
const AWS = require('aws-sdk');
const util = require('util');
const sharp = require('sharp');
280
AWS Lambda Guía para desarrolladores
Código de muestra
try {
const params = {
Bucket: srcBucket,
Key: srcKey
};
var origimage = await s3.getObject(params).promise();
} catch (error) {
console.log(error);
return;
}
// set thumbnail width. Resize will set the height automatically to maintain aspect
ratio.
const width = 200;
// Use the Sharp module to resize the image and save in a buffer.
try {
var buffer = await sharp(origimage.Body).resize(width).toBuffer();
} catch (error) {
console.log(error);
return;
}
} catch (error) {
console.log(error);
return;
}
281
AWS Lambda Guía para desarrolladores
Código de muestra
};
El paquete de implementación es un archivo .zip que contiene el código y las dependencias de la función
de Lambda.
El tiempo de ejecución de AWS Lambda ya tiene el SDK para JavaScript de AWS en Node.js, por lo
que solo tiene que instalar la biblioteca Sharp. Abra un símbolo del sistema, vaya a examplefolder
e instale las bibliotecas utilizando el comando npm, que forma parte de Node.js. Para Linux, utilice el
siguiente comando.
• La función conoce el nombre del bucket de origen y el nombre de la clave de objeto a partir de los
datos del evento que recibe como parámetros. Si el objeto es una imagen .jpg, el código crea una
miniatura y la guarda en el bucket de destino.
• El código presupone que el bucket de destino existe y que su nombre es una concatenación del
nombre del bucket de origen seguido por la cadena -resized. Por ejemplo, si el bucket de origen
identificado en los datos del evento es examplebucket, el código presupone que existe un bucket
de destino denominado examplebucket-resized.
• Para generar el nombre de la clave de la miniatura que crea, el código utiliza la cadena resized-
seguida del nombre de la clave del objeto de origen. Por ejemplo, si la clave del objeto de origen es
sample.jpg, el código crea una objeto de miniatura cuya clave es resized-sample.jpg.
5. Guarde el archivo como index.js en examplefolder. Cuando realice este paso, tendrá la
siguiente estructura de carpetas:
index.js
/node_modules/sharp
Java 11
A continuación, se muestra un ejemplo de código Java que lee los eventos entrantes de Amazon S3 y crea
una miniatura. Observe que implementa la interfaz RequestHandler proporcionada en la biblioteca aws-
lambda-java-core. Por lo tanto, en el momento de crear una función de Lambda debe especificar la
clase como controlador (es decir, example.handler). Para obtener más información acerca de cómo
utilizar interfaces para proporcionar un controlador, consulte Interfaces de controlador (p. 394).
282
AWS Lambda Guía para desarrolladores
Código de muestra
El tipo S3Event utilizado por el controlador como tipo de entrada es una de las clases predefinidas en la
biblioteca aws-lambda-java-events que proporciona métodos para que se pueda leer fácilmente la
información del evento entrante de Amazon S3. El controlador devuelve una cadena como salida.
Example Handler.java
package example;
import java.awt.Color;
import java.awt.Graphics2D;
import java.awt.RenderingHints;
import java.awt.image.BufferedImage;
import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
import javax.imageio.ImageIO;
import com.amazonaws.AmazonServiceException;
import com.amazonaws.services.lambda.runtime.Context;
import com.amazonaws.services.lambda.runtime.RequestHandler;
import com.amazonaws.services.lambda.runtime.events.S3Event;
import com.amazonaws.services.s3.AmazonS3;
import com.amazonaws.services.s3.event.S3EventNotification.S3EventNotificationRecord;
import com.amazonaws.services.s3.model.GetObjectRequest;
import com.amazonaws.services.s3.model.ObjectMetadata;
import com.amazonaws.services.s3.model.S3Object;
import com.amazonaws.services.s3.AmazonS3ClientBuilder;
283
AWS Lambda Guía para desarrolladores
Código de muestra
+ srcKey);
return "";
}
String imageType = matcher.group(1);
if (!(JPG_TYPE.equals(imageType)) && !(PNG_TYPE.equals(imageType))) {
System.out.println("Skipping non-image " + srcKey);
return "";
}
284
AWS Lambda Guía para desarrolladores
Código de muestra
Amazon S3 invoca la función de Lambda mediante el tipo de invocación Event, en el que AWS Lambda
ejecuta el código de forma asíncrona. No importa lo que se devuelva. Sin embargo, en este caso estamos
implementando una interfaz que obliga a especificar un tipo de retorno, por lo que en este ejemplo el
controlador utiliza String como tipo de retorno.
Dependencias.
• aws-lambda-java-core
• aws-lambda-java-events
• aws-java-sdk
Cree el código con las dependencias de la biblioteca de Lambda para crear un paquete de
implementación. Para obtener instrucciones, consulte Paquete de implementación de AWS Lambda en
Java (p. 386).
Python 3
El siguiente código de ejemplo recibe un evento de Amazon S3 y procesa el mensaje que contiene.
Modifica una imagen en el bucket de origen y guarda la salida en el bucket de destino.
Example lambda_function.py
import boto3
import os
import sys
import uuid
from urllib.parse import unquote_plus
from PIL import Image
import PIL.Image
s3_client = boto3.client('s3')
Note
La biblioteca de imágenes que este código utiliza debe instalarse en un entorno Linux para crear
un paquete de implementación que funcione.
285
AWS Lambda Guía para desarrolladores
Plantilla de muestra
A continuación, hay una plantilla AWS SAM de muestra para la aplicación de Lambda del
tutorial (p. 273). Copie el texto siguiente en un archivo .yaml y guárdelo junto al paquete ZIP que ha
creado anteriormente. Tenga en cuenta que los valores de los parámetros Handler y Runtime deben
coincidir con los que utilizó cuando creó la función en la sección anterior.
Example template.yaml
AWSTemplateFormatVersion: '2010-09-09'
Transform: AWS::Serverless-2016-10-31
Resources:
CreateThumbnail:
Type: AWS::Serverless::Function
Properties:
Handler: handler
Runtime: runtime
Timeout: 60
Policies: AWSLambdaExecute
Events:
CreateThumbnailEvent:
Type: S3
Properties:
Bucket: !Ref SrcBucket
Events: s3:ObjectCreated:*
SrcBucket:
286
AWS Lambda Guía para desarrolladores
Lote S3
Type: AWS::S3::Bucket
Para obtener más información sobre cómo empaquetar e implementar una aplicación sin servidor usando
los comandos de empaquetado e implementación, consulte Implementación de aplicaciones sin servidor
en la Guía para desarrolladores de Modelo de aplicación sin servidor de AWS.
Para ejecutar una operación por lotes, cree untrabajo de operaciones por lotes de Amazon S3. Cuando se
crea el trabajo, se proporciona un manifiesto (la lista de objetos) y se configura la acción a realizar en esos
objetos.
Cuando se inicia el trabajo por lotes, Amazon S3 invoca la función Lambda sincrónicamente (p. 100) para
cada objeto del manifiesto. El parámetro de evento incluye los nombres del bucket y del objeto.
En el ejemplo siguiente se muestra el evento que Amazon S3 envía a la función Lambda de un objeto
denominado customerImage1.jpg en el bucket awsexamplebucket .
{
"invocationSchemaVersion": "1.0",
"invocationId": "YXNkbGZqYWRmaiBhc2RmdW9hZHNmZGpmaGFzbGtkaGZza2RmaAo",
"job": {
"id": "f3cc4f60-61f6-4a2b-8a21-d07600c373ce"
},
"tasks": [
{
"taskId": "dGFza2lkZ29lc2hlcmUK",
"s3Key": "customerImage1.jpg",
"s3VersionId": "1",
"s3BucketArn": "arn:aws:s3:us-east-1:0123456788:awsexamplebucket"
}
]
}
Su función Lambda debe devolver un objeto JSON con los campos tal como se muestran en el siguiente
ejemplo. Puede copiar el parámetro invocationId y taskId desde el parámetro de evento. Puede
devolver una cadena en el resultString. Amazon S3 guarda los valores resultString en el informe
de finalización.
{
"invocationSchemaVersion": "1.0",
"treatMissingKeysAs" : "PermanentFailure",
"invocationId" : "YXNkbGZqYWRmaiBhc2RmdW9hZHNmZGpmaGFzbGtkaGZza2RmaAo",
"results": [
{
"taskId": "dGFza2lkZ29lc2hlcmUK",
287
AWS Lambda Guía para desarrolladores
Invocación de funciones de Lambda desde
operaciones por lotes de Amazon S3
"resultCode": "Succeeded",
"resultString": "["Alice", "Bob"]"
}
]
}
Tenga en cuenta que no puede reutilizar una función Amazon S3 basada en eventos existente para
operaciones por lotes. Esto se debe a que la operación por lotes de Amazon S3 pasa un parámetro de
evento diferente a la función Lambda y espera un mensaje de retorno con una estructura JSON específica.
En la política basada en recursos (p. 37) que cree para el trabajo por lotes de Amazon S3, asegúrese de
establecer permisos para que el trabajo invoque su función Lambda.
En el rol de ejecución (p. 33) de la función, establezca una política de confianza de Amazon S3 para
asumir el rol cuando ejecute la función.
Si su función utiliza SDK de AWS para administrar recursos de Amazon S3, debe agregar permisos de
Amazon S3 a la función de ejecución.
Cuando se ejecuta el trabajo, Amazon S3 inicia varias instancias de función para procesar los objetos de
Amazon S3 en paralelo, hasta el límite de concurrencia (p. 114) de la función. Amazon S3 limita el avance
inicial de instancias para evitar un costo excesivo para trabajos más pequeños.
Para obtener más información acerca de las operaciones por lotes de Amazon S3, consulte Realización de
operaciones por lotes en la Guía para desarrolladores de Amazon S3.
Para obtener un ejemplo de cómo utilizar una función Lambda en operaciones por lotes de Amazon S3,
consulte Invocación de una función Lambda desde las operaciones por lotes de Amazon S3 en la Guía
para desarrolladores de Amazon S3.
{
"Records": [
{
"eventVersion": "1.0",
"ses": {
288
AWS Lambda Guía para desarrolladores
SES
"mail": {
"commonHeaders": {
"from": [
"Jane Doe <janedoe@example.com>"
],
"to": [
"johndoe@example.com"
],
"returnPath": "janedoe@example.com",
"messageId": "<0123456789example.com>",
"date": "Wed, 7 Oct 2015 12:34:56 -0700",
"subject": "Test Subject"
},
"source": "janedoe@example.com",
"timestamp": "1970-01-01T00:00:00.000Z",
"destination": [
"johndoe@example.com"
],
"headers": [
{
"name": "Return-Path",
"value": "<janedoe@example.com>"
},
{
"name": "Received",
"value": "from mailer.example.com (mailer.example.com [203.0.113.1]) by
inbound-smtp.us-west-2.amazonaws.com with SMTP id o3vrnil0e2ic for johndoe@example.com;
Wed, 07 Oct 2015 12:34:56 +0000 (UTC)"
},
{
"name": "DKIM-Signature",
"value": "v=1; a=rsa-sha256; c=relaxed/relaxed; d=example.com;
s=example; h=mime-version:from:date:message-id:subject:to:content-type;
bh=jX3F0bCAI7sIbkHyy3mLYO28ieDQz2R0P8HwQkklFj4=; b=sQwJ+LMe9RjkesGu+vqU56asvMhrLRRYrWCbV"
},
{
"name": "MIME-Version",
"value": "1.0"
},
{
"name": "From",
"value": "Jane Doe <janedoe@example.com>"
},
{
"name": "Date",
"value": "Wed, 7 Oct 2015 12:34:56 -0700"
},
{
"name": "Message-ID",
"value": "<0123456789example.com>"
},
{
"name": "Subject",
"value": "Test Subject"
},
{
"name": "To",
"value": "johndoe@example.com"
},
{
"name": "Content-Type",
"value": "text/plain; charset=UTF-8"
}
],
"headersTruncated": false,
"messageId": "o3vrnil0e2ic28tr"
289
AWS Lambda Guía para desarrolladores
SNS
},
"receipt": {
"recipients": [
"johndoe@example.com"
],
"timestamp": "1970-01-01T00:00:00.000Z",
"spamVerdict": {
"status": "PASS"
},
"dkimVerdict": {
"status": "PASS"
},
"processingTimeMillis": 574,
"action": {
"type": "Lambda",
"invocationType": "Event",
"functionArn": "arn:aws:lambda:us-west-2:012345678912:function:Example"
},
"spfVerdict": {
"status": "PASS"
},
"virusVerdict": {
"status": "PASS"
}
}
},
"eventSource": "aws:ses"
}
]
}
Para obtener más información, consulte Acción de Lambda en la Guía para desarrolladores de Amazon
SES.
Amazon SNS invoca la función de forma asíncrona (p. 101) con un evento que contiene un mensaje y
metadatos.
{
"Records": [
{
"EventVersion": "1.0",
"EventSubscriptionArn": "arn:aws:sns:us-east-2:123456789012:sns-lambda:21be56ed-
a058-49f5-8c98-aedd2564c486",
"EventSource": "aws:sns",
"Sns": {
"SignatureVersion": "1",
"Timestamp": "2019-01-02T12:45:07.000Z",
"Signature": "tcc6faL2yUC6dgZdmrwh1Y4cGa/ebXEkAi6RibDsvpi+tE/1+82j...65r==",
"SigningCertUrl": "https://sns.us-east-2.amazonaws.com/SimpleNotificationService-
ac565b8b1a6c5d002d285f9598aa1d9b.pem",
"MessageId": "95df01b4-ee98-5cb9-9903-4c221d41eb5e",
"Message": "Hello from SNS!",
"MessageAttributes": {
290
AWS Lambda Guía para desarrolladores
Tutorial
"Test": {
"Type": "String",
"Value": "TestString"
},
"TestBinary": {
"Type": "Binary",
"Value": "TestBinary"
}
},
"Type": "Notification",
"UnsubscribeUrl": "https://sns.us-east-2.amazonaws.com/?
Action=Unsubscribe&SubscriptionArn=arn:aws:sns:us-east-2:123456789012:test-
lambda:21be56ed-a058-49f5-8c98-aedd2564c486",
"TopicArn":"arn:aws:sns:us-east-2:123456789012:sns-lambda",
"Subject": "TestInvoke"
}
}
]
}
Para la invocación asíncrona, Lambda pone en cola el mensaje y gestiona los reintentos. Si Amazon
SNS no puede conectar con Lambda o el mensaje se rechaza, lo Amazon SNS reintenta la operación a
intervalos cada vez mayores durante varias horas. Para obtener más información, consulte Fiabilidad en
las preguntas frecuentes de Amazon SNS.
Para poder realizar entregas de Amazon SNS a Lambda entre distintas cuentas, debe autorizar la
invocación de la función de Lambda desde Amazon SNS. A su vez, Amazon SNS debe permitir que la
cuenta de Lambda se suscriba al tema de Amazon SNS. Por ejemplo, si el tema de Amazon SNS está en
la cuenta A y la función de Lambda está en la cuenta B, cada cuenta debe conceder permisos a la otra
para que acceda a sus recursos. Dado que en la consola de AWS no están disponibles todas las opciones
para configurar permisos entre cuentas, se utiliza la CLI de AWS para configurar todo el proceso.
Para obtener más información, consulte Invocación de funciones de Lambda mediante las notificaciones de
Amazon SNS en la Guía para desarrolladores de Amazon Simple Notification Service.
Temas
• Tutorial: uso de AWS Lambda con Amazon Simple Notification Service (p. 291)
• Código de función de ejemplo (p. 294)
Requisitos previos
En este tutorial, se le presuponen algunos conocimientos sobre las operaciones básicas de Lambda y la
consola de Lambda. Si aún no lo ha hecho, siga las instrucciones que se indican en Introducción a AWS
Lambda (p. 3) para crear la primera función de Lambda.
Para seguir los procedimientos de esta guía, necesitará un shell o un terminal de línea de comando donde
pueda ejecutar los comandos. Los comandos aparecen en listas y van precedidos del símbolo del sistema
($) y del nombre del directorio actual, si es aplicable:
291
AWS Lambda Guía para desarrolladores
Tutorial
Para los comandos largos, se utiliza un carácter de escape (\) para dividir un comando en varias líneas.
En Linux y macOS, use su administrador de shell y paquetes preferido. En Windows 10, puede instalar
Windows Subsystem para Linux para obtener una versión de Ubuntu y Bash integrada con Windows.
En el tutorial, se utilizarán dos cuentas. Los comandos de la AWS CLI ilustran esto utilizando dos perfiles
con nombre, cada uno configurado para el uso con una cuenta diferente. Si utiliza perfiles con nombres
distintos, bien el perfil predeterminado o un perfil con nombre, modifique los comandos según sea
necesario.
Anote el ARN del tema que devuelve el comando. Lo necesitará cuando añada permisos a la función de
Lambda para suscribirse al tema.
Para ver código de muestra en otros lenguajes, consulte Código de función de ejemplo (p. 294).
Example index.js
console.log('Loading function');
292
AWS Lambda Guía para desarrolladores
Tutorial
Anote el ARN de la función que devuelve el comando. Lo necesitará cuando añada permisos para permitir
a Amazon SNS que invoque la función.
Desde la cuenta B (01234567891B) añada el permiso de Lambda para permitir la invocación desde
Amazon SNS.
No utilice el parámetro --source-account para añadir una cuenta de origen a la política de Lambda al
añadir la política. La cuenta de origen no es compatible con los orígenes de eventos de Amazon SNS y
dará lugar a la denegación de acceso.
Note
Si la cuenta con el tema de SNS está alojada en una región de registro, debe especificar la
región en la entidad principal. Para ver un ejemplo, consulte Invocación de funciones de Lambda
293
AWS Lambda Guía para desarrolladores
Código de muestra
mediante las notificaciones de Amazon SNS en la Guía para desarrolladores de Amazon Simple
Notification Service.
Probar suscripción
Desde la cuenta A (01234567891A), pruebe la suscripción. Escriba Hello World en un archivo de texto y
guárdelo como message.txt. A continuación, ejecute el siguiente comando:
Esto devolverá un ID de mensaje con un identificador único que indica que el servicio Amazon SNS aceptó
el mensaje. A continuación, Amazon SNS intentará entregarlo a los suscriptores del tema. También puede
proporcionar una cadena JSON directamente al parámetro message, pero si utiliza un archivo de texto,
puede incluir saltos de línea en el mensaje.
Para obtener más información sobre Amazon SNS, consulte ¿Qué es Amazon Simple Notification Service?
Temas
• Node.js 8 (p. 294)
• Java 11 (p. 295)
• Go (p. 295)
• Python 3 (p. 296)
Node.js 8
En el siguiente ejemplo, se procesan los mensajes de Amazon SNS, y registra su contenido.
Example index.js
console.log('Loading function');
294
AWS Lambda Guía para desarrolladores
Código de muestra
Comprima el código de muestra para crear un paquete de implementación. Para obtener instrucciones,
consulte Paquete de implementación de AWS Lambda en Node.js (p. 336).
Java 11
En el siguiente ejemplo, se procesan los mensajes de Amazon SNS, y registra su contenido.
Example LambdaWithSNS.java
package example;
import java.text.SimpleDateFormat;
import java.util.Calendar;
import com.amazonaws.services.lambda.runtime.RequestHandler;
import com.amazonaws.services.lambda.runtime.Context;
import com.amazonaws.services.lambda.runtime.events.SNSEvent;
Dependencias.
• aws-lambda-java-core
• aws-lambda-java-events
Cree el código con las dependencias de la biblioteca de Lambda para crear un paquete de
implementación. Para obtener instrucciones, consulte Paquete de implementación de AWS Lambda en
Java (p. 386).
Go
En el siguiente ejemplo, se procesan los mensajes de Amazon SNS, y registra su contenido.
Example lambda_handler.go
package main
import (
"context"
"fmt"
295
AWS Lambda Guía para desarrolladores
SQS
"github.com/aws/aws-lambda-go/lambda"
"github.com/aws/aws-lambda-go/events"
)
func main() {
lambda.Start(handler)
}
Compile el ejecutable con go build y cree un paquete de implementación. Para obtener instrucciones,
consulte Paquete de implementación de AWS Lambda en Go (p. 417).
Python 3
En el siguiente ejemplo, se procesan los mensajes de Amazon SNS, y registra su contenido.
Example lambda_handler.py
Comprima el código de muestra para crear un paquete de implementación. Para obtener instrucciones,
consulte Paquete de implementación de AWS Lambda en Python (p. 352).
Lambda sondea la cola e invoca la función sincrónicamente (p. 100) con un evento que contenga
mensajes de cola. Lambda lee mensajes en lotes e invoca la función una vez por lote. Cuando la función
procesa correctamente un lote, Lambda elimina sus mensajes de la cola. En el ejemplo siguiente se
muestra un evento para un lote de dos mensajes.
{
"Records": [
{
"messageId": "059f36b4-87a3-44ab-83d2-661975830a7d",
"receiptHandle": "AQEBwJnKyrHigUMZj6rYigCgxlaS3SLy0a...",
296
AWS Lambda Guía para desarrolladores
SQS
Para las colas FIFO, los registros contienen atributos adicionales relacionados con la deduplicación y la
secuenciación.
{
"Records": [
{
"messageId": "11d6ee51-4cc7-4302-9e22-7cd8afdaadf5",
"receiptHandle": "AQEBBX8nesZEXmkhsmZeyIE8iQAMig7qw...",
"body": "Test message.",
"attributes": {
"ApproximateReceiveCount": "1",
"SentTimestamp": "1573251510774",
"SequenceNumber": "18849496460467696128",
"MessageGroupId": "1",
"SenderId": "AIDAIO23YVJENQZJOL4VO",
"MessageDeduplicationId": "1",
"ApproximateFirstReceiveTimestamp": "1573251510774"
},
"messageAttributes": {},
"md5OfBody": "e4e68fb7bd0e697a0ae8f1bb342846b3",
"eventSource": "aws:sqs",
"eventSourceARN": "arn:aws:sqs:us-east-2:123456789012:fifo.fifo",
"awsRegion": "us-east-2"
}
]
}
Cuando Lambda lee un lote, los mensajes se mantienen en la cola, pero se ocultan durante el tiempo de
espera de visibilidad de la cola. Cuando la función procesa correctamente un lote, Lambda elimina sus
297
AWS Lambda Guía para desarrolladores
Escalado y procesamiento
mensajes de la cola. Si la función se limita (p. 114), devuelve un error o no responde, el mensaje se hace
visible de nuevo. Todos los mensajes de un lote con errores volverán a la cola, por lo que el código de su
función debe ser capaz de procesar el mismo mensaje varias veces sin efectos secundarios.
Escalado y procesamiento
Para las colas estándar, Lambda utiliza el sondeo largo para sondear una cola hasta que se active.
Cuando los mensajes están disponibles, Lambda lee hasta 5 lotes y los envía a su función. Si los mensajes
siguen estando disponibles, Lambda aumenta el número de procesos que son lotes de lectura hasta 60
instancias más por minuto. El número máximo de lotes que se pueden procesar simultáneamente mediante
un mapeo de origen de eventos es 1000.
Para colas FIFO, Lambda envía mensajes a su función en el orden en que los recibe. Cuando se envía
un mensaje a una cola FIFO, se especifica un ID de grupo de mensajes. Amazon SQS garantiza que los
mensajes del mismo grupo se entreguen a Lambda en orden. Lambda ordena los mensajes en grupos y
envía sólo un lote a la vez por grupo. Si la función devuelve un error, todos los reintentos se realizan en los
mensajes afectados antes de que Lambda reciba mensajes adicionales del mismo grupo.
Su función puede escalar simultáneamente al número de grupos de mensajes activos. Para obtener más
información, consulte SQS FIFO como fuente de eventos en el blog de informática de AWS.
Para dar tiempo al tiempo de función a procesar cada lote de registros, configure el tiempo de espera de
la visibilidad de la cola hasta al menos 6 veces el tiempo de espera (p. 54) que configure en su función. El
tiempo adicional permitirá a Lambda volver a intentar realizar los procesos en caso de que la ejecución de
la función se vea limitada debido al procesamiento de un lote anterior.
Si el procesamiento de un mensaje da error repetidas veces, Amazon SQS podrá enviar dicho mensaje a
una cola de mensajes fallidos. Cuando su función devuelve un error, Lambda lo deja en la cola. Después
de que se supera el tiempo de espera de visibilidad, Lambda recibe el mensaje de nuevo. Para enviar
mensajes a una segunda cola después de recibir varias veces, configure una cola de mensajes fallidos en
la cola de origen.
Note
• sqs:ReceiveMessage
• sqs:DeleteMessage
• sqs:GetQueueAttributes
298
AWS Lambda Guía para desarrolladores
Configuración de una cola como origen de eventos
Para obtener más información, consulte Rol de ejecución de AWS Lambda (p. 33).
Para configurar la función para leer de Amazon SQS en la consola de Lambda, cree un desencadenador
de SQS.
Lambda admite las siguientes opciones para los orígenes de eventos de Amazon SQS.
• SQS queue (Cola de SQS): la cola de Amazon SQS desde la que leer registros.
• Batch size (Tamaño del lote): el número de elementos que leer de la cola en cada lote, hasta 10. El
evento podría contener menos elementos si el lote que Lambda lee de la cola tuviera menos elementos.
• Enabled (Habilitado): establecer en true para habilitar la asignación de origen de eventos. Establecer en
false para detener el procesamiento de registros.
Note
Amazon SQS tiene una capa gratuita permanente para las solicitudes. Más allá de la capa
gratuita, Amazon SQS cobra por cada millón de solicitudes. Mientras el mapeo de origen de
eventos está activa, Lambda realiza solicitudes a la cola para obtener elementos. Para obtener
más información sobre precios, consulte precios de Amazon Simple Queue Service.
Para administrar la configuración de origen de evento más tarde, elija el desencadenador en el diseñador.
Configure el tiempo de espera de la función para que disponga de tiempo suficiente para procesar todo
un lote de elementos. Si elementos tardan mucho tiempo en procesarse, elija un tamaño de lote más
pequeño. Un tamaño de lote amplio puede mejorar la eficiencia para cargas de trabajo que son muy
rápidas o tienen mucha administración. Sin embargo, si la función devuelve un error, todos los elementos
del lote vuelven a la cola. Si configura la simultaneidad reservada (p. 62) en la función, establezca al
menos 5 ejecuciones simultáneas para reducir la posibilidad de errores de límite cuando Lambda invoque
la función.
299
AWS Lambda Guía para desarrolladores
Tutorial
En el siguiente ejemplo se utiliza la AWS CLI para asignar una función llamada my-function a una cola
de Amazon SQS especificada mediante su nombre de recurso de Amazon (ARN), con un tamaño de lote
de 5.
Requisitos previos
En este tutorial, se le presuponen algunos conocimientos sobre las operaciones básicas de Lambda y la
consola de Lambda. Si aún no lo ha hecho, siga las instrucciones que se indican en Introducción a AWS
Lambda (p. 3) para crear la primera función de Lambda.
Para seguir los procedimientos de esta guía, necesitará un shell o un terminal de línea de comando donde
pueda ejecutar los comandos. Los comandos aparecen en listas y van precedidos del símbolo del sistema
($) y del nombre del directorio actual, si es aplicable:
Para los comandos largos, se utiliza un carácter de escape (\) para dividir un comando en varias líneas.
En Linux y macOS, use su administrador de shell y paquetes preferido. En Windows 10, puede instalar
Windows Subsystem para Linux para obtener una versión de Ubuntu y Bash integrada con Windows.
300
AWS Lambda Guía para desarrolladores
Tutorial
Creación de la función
A continuación se muestra código de ejemplo que recibe un evento de Amazon SQS como entrada y
procesa los mensajes que contiene. Con fines ilustrativos, el código escribe parte de los datos de los
eventos de entrada en CloudWatch Logs.
Note
Para ver código de muestra en otros lenguajes, consulte Código de función de ejemplo de
Amazon SQS (p. 303).
Example index.js
Prueba de la función
Invoque la función de Lambda manualmente mediante el comando invoke de la CLI de AWS Lambda y
un evento de Amazon Simple Queue Service de muestra.
Si el controlador vuelve normalmente sin excepciones, Lambda considera que el mensaje se ha procesado
correctamente y empieza a leer nuevos mensajes en la cola. Una vez que un mensaje se procesa
correctamente, se elimina automáticamente de la cola. Si el controlador genera una excepción, Lambda
considera que la entrada de mensajes no se ha procesado e invoca de nuevo la función con el mismo lote
de mensajes.
{
"Records": [
{
301
AWS Lambda Guía para desarrolladores
Tutorial
"messageId": "059f36b4-87a3-44ab-83d2-661975830a7d",
"receiptHandle": "AQEBwJnKyrHigUMZj6rYigCgxlaS3SLy0a...",
"body": "test",
"attributes": {
"ApproximateReceiveCount": "1",
"SentTimestamp": "1545082649183",
"SenderId": "AIDAIENQZJOLO23YVJ4VO",
"ApproximateFirstReceiveTimestamp": "1545082649185"
},
"messageAttributes": {},
"md5OfBody": "098f6bcd4621d373cade4e832627b4f6",
"eventSource": "aws:sqs",
"eventSourceARN": "arn:aws:sqs:us-east-2:123456789012:my-queue",
"awsRegion": "us-east-2"
}
]
}
1. Inicie sesión en la Consola de administración de AWS y abra la consola de Amazon SQS en https://
console.aws.amazon.com/sqs/.
2. En la consola de Amazon SQS, cree una cola.
3. Escriba o registre el ARN (nombre del recurso de Amazon) de la cola de identificación. Lo necesitará
en el siguiente paso al asociar la cola a la función Lambda.
Crear un mapeo de origen de eventos en AWS Lambda. Este mapeo de origen de eventos asocia la cola
de Amazon SQS a la función de Lambda. Una vez creado este mapeo de origen de eventos, AWS Lambda
comienza a sondear la cola.
Probar la experiencia integral. A medida que se actualiza la cola, Amazon Simple Queue Service escribe
mensajes en la cola. AWS Lambda sondea la cola, detecta nuevos registros y ejecuta la función de
Lambda en su nombre pasando los eventos a la función, en este caso mensajes de Amazon SQS.
302
AWS Lambda Guía para desarrolladores
Código de muestra
La lista devuelve todos los mapeos de orígenes de eventos creados, y para cada uno de ellos muestra
el LastProcessingResult, entre otras cosas. Este campo se utiliza para proporcionar un mensaje
informativo en caso de que surja algún problema. Los valores como No records processed (indica
que AWS Lambda no ha comenzado el sondeo o que no hay registros en la cola) y OK (indica que AWS
Lambda ha leído correctamente los registros de la cola y ha invocado la función de Lambda) indican que
no hay ningún problema. Si hay algún problema, recibirá un mensaje de error.
Prueba de la configuración
Ahora puede probar la configuración como se indica a continuación:
1. En la consola de Amazon SQSpuede enviar mensajes a la cola. Amazon SQS escribe registros de estas
acciones en la cola.
2. AWS Lambda sondea la cola y, cuando detecta actualizaciones, invoca la función de Lambda pasando
los datos de eventos que encuentra en la cola.
3. La función ejecuta y crea logs en Amazon CloudWatch. Puede verificar los registros reportados en la
consola de Amazon CloudWatch.
Temas
• Node.js (p. 303)
• Java (p. 304)
• C# (p. 304)
• Go (p. 305)
• Python (p. 306)
Node.js
A continuación se muestra código de ejemplo que recibe un mensaje de evento de Amazon SQS como
entrada y lo procesa. Con fines ilustrativos, el código escribe parte de los datos de los eventos de entrada
en CloudWatch Logs.
event.Records.forEach(function(record) {
var body = record.body;
console.log(body);
303
AWS Lambda Guía para desarrolladores
Código de muestra
});
callback(null, "message");
};
Comprima el código de muestra para crear un paquete de implementación. Para obtener instrucciones,
consulte Paquete de implementación de AWS Lambda en Node.js (p. 336).
Java
A continuación se muestra código Java de ejemplo que recibe un mensaje de evento de Amazon SQS
como entrada y lo procesa. Con fines ilustrativos, el código escribe parte de los datos de los eventos de
entrada en CloudWatch Logs.
Example Handler.java
package example;
import com.amazonaws.services.lambda.runtime.Context;
import com.amazonaws.services.lambda.runtime.RequestHandler;
import com.amazonaws.services.lambda.runtime.events.SQSEvent;
import com.amazonaws.services.lambda.runtime.events.SQSEvent.SQSMessage;
Dependencias.
• aws-lambda-java-core
• aws-lambda-java-events
Cree el código con las dependencias de la biblioteca de Lambda para crear un paquete de
implementación. Para obtener instrucciones, consulte Paquete de implementación de AWS Lambda en
Java (p. 386).
C#
A continuación se muestra código C# de ejemplo que recibe un mensaje de evento de Amazon SQS como
entrada y lo procesa. Con fines ilustrativos, el código escribe parte de los datos de los eventos de entrada
en la consola.
Example ProcessingSQSRecords.cs
[assembly: LambdaSerializer(typeof(Amazon.Lambda.Serialization.Json.JsonSerializer))]
namespace SQSLambdaFunction
304
AWS Lambda Guía para desarrolladores
Código de muestra
{
public class SQSLambdaFunction
{
public string HandleSQSEvent(SQSEvent sqsEvent, ILambdaContext context)
{
Console.WriteLine($"Beginning to process {sqsEvent.Records.Count} records...");
Console.WriteLine($"Record Body:");
Console.WriteLine(record.Body);
}
Console.WriteLine("Processing complete.");
Reemplace Program.cs en un proyecto .NET Core con el ejemplo anterior. Para obtener instrucciones,
consulte AWS Lambda Paquete de implementación en C# (p. 433).
Go
A continuación se muestra código Go de ejemplo que recibe un mensaje de evento de Amazon SQS como
entrada y lo procesa. Con fines ilustrativos, el código escribe parte de los datos de los eventos de entrada
en CloudWatch Logs.
En el código, handler es el controlador. Este controlador utiliza la clase SQSEvent predefinida, que se
define en la biblioteca aws-lambda-go-events.
Example ProcessSQSRecords.go
package main
import (
"context"
"fmt"
"github.com/aws/aws-lambda-go/events"
"github.com/aws/aws-lambda-go/lambda"
)
return nil
}
func main() {
lambda.Start(handler)
}
Compile el ejecutable con go build y cree un paquete de implementación. Para obtener instrucciones,
consulte Paquete de implementación de AWS Lambda en Go (p. 417).
305
AWS Lambda Guía para desarrolladores
Plantilla de muestra
Python
A continuación se muestra código de ejemplo de Python que acepta un registro de Amazon SQS como
entrada y lo procesa. Con fines ilustrativos, el código escribe parte de los datos de los eventos de entrada
en CloudWatch Logs.
Siga las instrucciones para crear un paquete de implementación para la función de AWS Lambda.
Example ProcessSQSRecords.py
Comprima el código de muestra para crear un paquete de implementación. Para obtener instrucciones,
consulte Paquete de implementación de AWS Lambda en Python (p. 352).
A continuación, hay una plantilla AWS SAM de muestra para la aplicación de Lambda del
tutorial (p. 300). Copie el texto siguiente en un archivo .yaml y guárdelo junto al paquete ZIP que ha
creado anteriormente. Tenga en cuenta que los valores de los parámetros Handler y Runtime deben
coincidir con los que utilizó cuando creó la función en la sección anterior.
Example template.yaml
AWSTemplateFormatVersion: '2010-09-09'
Transform: AWS::Serverless-2016-10-31
Description: Example of processing messages on an SQS queue with Lambda
Resources:
MySQSQueueFunction:
Type: AWS::Serverless::Function
Properties:
Handler: index.handler
Runtime: nodejs12.x
Events:
MySQSEvent:
Type: SQS
Properties:
Queue: !GetAtt MySqsQueue.Arn
BatchSize: 10
MySqsQueue:
Type: AWS::SQS::Queue
Para obtener más información sobre cómo empaquetar e implementar una aplicación sin servidor usando
los comandos de empaquetado e implementación, consulte Implementación de aplicaciones sin servidor
en la Guía para desarrolladores de Modelo de aplicación sin servidor de AWS.
306
AWS Lambda Guía para desarrolladores
Step Functions
Step Functions invoca su función con un documento de evento que defina. Puede crear un estado de tarea
que invoque su función con la entrada a la máquina de estado o cualquier documento JSON.
{
"max-depth": 10,
"current-depth": 0,
"error-rate": 0.05
}
Step Functions facilita volver a intentar ejecuciones que producen error (p. 308) o ramificar la lógica de la
aplicación en función del resultado de una invocación.
Secciones
• Configuración de una máquina de estado como un origen de eventos (p. 307)
• Gestión de errores de función y servicio (p. 308)
• AWS CloudFormation y AWS SAM (p. 309)
"Invoke": {
"Type": "Task",
"Resource": "arn:aws:states:::lambda:invoke",
"Parameters": {
"FunctionName": "arn:aws:lambda:us-east-2:123456789012:function:my-function:1",
"Payload": {
"max-depth": 10,
"current-depth": 0,
"error-rate": 0.05
}
},
"Next": "NEXT_STATE",
307
AWS Lambda Guía para desarrolladores
Gestión de errores de función y servicio
"TimeoutSeconds": 25
}
Permisos
Su máquina de estado necesita permiso para llamar a la API de Lambda para invocar una función.
Para concederle permiso, agregue la política administrada AWSLambdaRole o una política
insertada con ámbito de función en su rol. Para obtener más información, consulte Cómo funciona
AWS Step Functions con IAM en la Guía para desarrolladores de AWS Step Functions.
"InvocationType": "Event"
En lugar de codificar de forma rígida la carga del evento en la definición de máquina de estado, puede
usar la entrada de la ejecución de la máquina de estado. En el ejemplo siguiente se utiliza la entrada
especificada cuando ejecuta la máquina de estado como carga del evento:
"Payload.$": "$"
También puede invocar una función de forma asíncrona y esperar a que realice una
devolución de llamada con AWS SDK. Para ello, establezca el recurso del estado en
arn:aws:states:::lambda:invoke.waitForTaskToken. Para obtener más información, consulte
Invocar Lambda con Step Functions en la Guía para desarrolladores de AWS Step Functions.
En el ejemplo siguiente se muestra una tarea de invocación que reintenta las excepciones de la API de
Lambda en la serie 5XX (ServiceException), los aceleradores (TooManyRequestsException),
los errores de tiempo de ejecución (Lambda.Unknown) y un error definido por función denominado
function.MaxDepthError. También captura un error llamado function.DoublesRolledError y
continúa a un estado llamado CaughtException cuando se produce.
"Invoke": {
"Type": "Task",
"Resource": "arn:aws:states:::lambda:invoke",
"Retry": [
{
"ErrorEquals": [
"function.MaxDepthError",
"Lambda.TooManyRequestsException",
"Lambda.ServiceException",
"Lambda.Unknown"
],
"MaxAttempts": 5
}
],
"Catch": [
{
"ErrorEquals": [ "function.DoublesRolledError" ],
308
AWS Lambda Guía para desarrolladores
AWS CloudFormation y AWS SAM
"Next": "CaughtException"
}
],
"Parameters": {
"FunctionName": "arn:aws:lambda:us-east-2:123456789012:function:my-function:1",
...
Para capturar o volver a intentar errores de función, cree un tipo de error personalizado. El nombre
del tipo de error debe coincidir con errorType de la respuesta de error con formato que Lambda
devuelve cuando se genera un error. Para obtener detalles sobre cómo generar errores en cada lenguaje
compatible, consulte los temas siguientes:
Para obtener más información sobre la gestión de errores en Step Functions, consulte Control de las
condiciones de error con una máquina de estado de Step Functions en la Guía para desarrolladores de
AWS Step Functions.
Example template.yml
AWSTemplateFormatVersion: '2010-09-09'
Transform: 'AWS::Serverless-2016-10-31'
Description: An AWS Lambda application that uses AWS Step Functions.
Resources:
statemachine:
Type: AWS::Serverless::StateMachine
Properties:
DefinitionSubstitutions:
FunctionArn: !GetAtt function.Arn
Payload: |
{
"max-depth": 5,
"current-depth": 0,
"error-rate": 0.2
}
Definition:
StartAt: Invoke
States:
Invoke:
Type: Task
Resource: arn:aws:states:::lambda:invoke
Parameters:
FunctionName: "${FunctionArn}"
Payload: "${Payload}"
309
AWS Lambda Guía para desarrolladores
AWS CloudFormation y AWS SAM
InvocationType: Event
Retry:
- ErrorEquals:
- function.MaxDepthError
- function.MaxDepthError
- Lambda.TooManyRequestsException
- Lambda.ServiceException
- Lambda.Unknown
IntervalSeconds: 1
MaxAttempts: 5
Catch:
- ErrorEquals:
- function.DoublesRolledError
Next: CaughtException
- ErrorEquals:
- States.ALL
Next: UncaughtException
Next: Success
CaughtException:
Type: Pass
Result: The function returned an error.
End: true
UncaughtException:
Type: Pass
Result: Invocation failed.
End: true
Success:
Type: Pass
Result: Invocation succeeded!
End: true
Events:
scheduled:
Type: Schedule
Properties:
Description: Run every minute
Schedule: rate(1 minute)
Type: STANDARD
Policies:
- AWSLambdaRole
...
310
AWS Lambda Guía para desarrolladores
X-Ray
Si ha habilitado el rastreo de X-Ray en un servicio que invoca su función, Lambda envía rastreos a X-
Ray automáticamente. El servicio ascendente, como Amazon API Gateway, o una aplicación alojada en
Amazon EC2 que está instrumentada con el SDK de X-Ray, muestra las solicitudes entrantes y agrega un
encabezado de rastreo que indica Lambda que envíe rastreos o no.
Para rastrear solicitudes que no tienen un encabezado de rastreo, habilite el rastreo activo en la
configuración de la función.
Precios
X-Ray tiene una capa gratuita permanente Más allá del umbral de la capa gratuita, X-Ray realiza
cargos por almacenamiento y recuperación del seguimiento. Consulte Precios de AWS X-Ray
para obtener más información.
Su función necesita permiso para cargar datos de rastreo en X-Ray. Cuando habilita el rastreo activo en la
Lambda consola, Lambda agrega los permisos necesarios al rol de ejecución (p. 33) de la función. De lo
contrario, agregue la política AWSXRayDaemonWriteAccess al rol de ejecución.
X-Ray aplica un algoritmo de muestreo para garantizar que el rastreo sea eficiente, al tiempo que
proporciona una muestra representativa de las solicitudes a las que sirve la aplicación. La regla de
muestreo predeterminada es 1 solicitud por segundo y un 5 por ciento de las solicitudes adicionales.
311
AWS Lambda Guía para desarrolladores
Permisos de rol de ejecución
En X-Ray, un seguimiento registra información sobre una solicitud procesada por uno o varios servicios.
Los servicios registran segmentos que contienen capas de subsegmentos. Lambda registra un segmento
para el servicio de Lambda que maneja la solicitud de invocación y otro para el trabajo realizado por
la función. El segmento de función viene con subsegmentos para Initialization, Invocation y
Overhead.
En el ejemplo siguiente se muestra un seguimiento con 2 segmentos. Ambos se llaman my-function, pero
uno es tipo AWS::Lambda y el otro es AWS::Lambda::Function. El segmento de función se expande
para mostrar sus subsegmentos.
Important
En Lambda, puede usar el SDK de X-Ray para extender el subsegmento Invocation con
subsegmentos adicionales para llamadas descendentes, anotaciones y metadatos. No se
puede acceder al segmento de función directamente o grabar trabajo hecho fuera del ámbito de
invocación del controlador.
Consulte los siguientes temas para obtener una introducción específica del seguimiento en Lambda:
Para obtener una lista completa de los servicios que admiten instrumentación activa, consulte Servicios de
AWS admitidos en la Guía para desarrolladores de AWS X-Ray.
Secciones
• Permisos de rol de ejecución (p. 312)
• El demonio de AWS X-Ray (p. 313)
• Habilitación del seguimiento activo con la API de Lambda (p. 313)
• Habilitación del seguimiento activo con AWS CloudFormation (p. 313)
• xray:PutTraceSegments
312
AWS Lambda Guía para desarrolladores
El demonio de AWS X-Ray
• xray:PutTelemetryRecords
El tiempo de ejecución de Lambda permite al demonio hasta un 3 por ciento de la memoria configurada de
su función o 16 MB, lo que sea mayor. Si su función se queda sin memoria durante la invocación, el tiempo
de ejecución termina el proceso del demonio primero para liberar memoria.
Para obtener más información, consulte El demonio de X-Ray en la Guía para desarrolladores de X-Ray.
El siguiente comando de la AWS CLI de ejemplo habilita el rastreo activo en una función llamada «my-
function».
El modo de seguimiento forma parte de la configuración específica de la versión, que se bloquea cuando
se publica una versión de la función. No se puede cambiar el modo de seguimiento de una versión
publicada.
Resources:
function:
Type: AWS::Lambda::Function
Properties:
TracingConfig:
Mode: Active
313
AWS Lambda Guía para desarrolladores
Habilitación del seguimiento
activo con AWS CloudFormation
...
Resources:
function:
Type: AWS::Serverless::Function
Properties:
Tracing: Active
...
314
AWS Lambda Guía para desarrolladores
Node.js
• blank-nodejs: una función de Node.js que muestra el uso de registro, las variables de entorno, el
seguimiento de AWS X-Ray, las capas, las pruebas de unidad y el SDK de AWS.
• nodejs-apig: una función con un punto de enlace de API público que procesa un evento desde API
Gateway y devuelve una respuesta HTTP.
• rds-mysql: una función que transmite consultas a una base de datos MySQL para RDS. Este
ejemplo incluye una VPC privada y una instancia de base de datos configurada con una contraseña
en AWS Secrets Manager.
• efs-nodejs: una función que utiliza un sistema de archivos de Amazon EFS en una Amazon VPC.
Este ejemplo incluye una VPC, un sistema de archivos, objetivos de montaje y un punto de acceso
configurados para su uso con Lambda.
• list-manager: una función procesa eventos de un flujo de datos de Amazon Kinesis y actualiza listas
agregadas en Amazon DynamoDB. La función almacena un registro de cada evento en una base de
datos MySQL for RDS en una VPC privada. Este ejemplo incluye una VPC privada con un punto de
enlace de la VPC para DynamoDB y una instancia de base de datos.
• error-processor: una función Node.js genera errores para un porcentaje especificado de solicitudes.
Una suscripción de CloudWatch Logs invoca una segunda función cuando se registra un error.
La función de procesador utiliza el SDK de AWS para recopilar detalles sobre la solicitud y
almacenarlos en un bucket de Amazon S3.
Python
• blank-python: una función de Python que muestra el uso del registro, las variables de entorno, el
seguimiento de AWS X-Ray, las capas, las pruebas unitarias y el SDK de AWS.
Ruby
• blank-ruby: una función de Ruby que muestra el uso del registro, las variables de entorno, el
seguimiento de AWS X-Ray, las pruebas de unidad y el SDK de AWS.
Java
• blank-java: función de Java que muestra el uso de bibliotecas de Java de Lambda, el registro, las
variables de entorno, las capas, el seguimiento de AWS X-Ray, las pruebas unitarias y el SDK de
AWS.
315
AWS Lambda Guía para desarrolladores
Función en blanco
• java-basic: función de Java mínima con pruebas unitarias y configuración de registro de variables.
• java-events: función de Java mínima que utiliza la biblioteca aws-lambda-java-events (p. 386) con
tipos de eventos que no requieren el SDK de AWS como dependencia, como Amazon API Gateway.
• java-events-v1sdk: función de Java que utiliza la biblioteca aws-lambda-java-events (p. 386)
con tipos de eventos que requieren el SDK de AWS como dependencia (Amazon Simple Storage
Service, Amazon DynamoDB y Amazon Kinesis).
• s3-java: función de Java que procesa los eventos de notificación de Amazon S3 y utiliza Java Class
Library (JCL) para crear miniaturas de los archivos de imagen cargados.
Go
• blank-go: una función de Go que muestra el uso de las bibliotecas de Go de Lambda, el registro, las
variables de entorno y el SDK de AWS.
C#
• blank-csharp: una función de C# que muestra el uso de las bibliotecas de .NET de Lambda, el
registro, las variables de entorno, el seguimiento de AWS X-Ray, las pruebas de unidad y el SDK de
AWS.
• ec2-spot: una función que administra las solicitudes de instancia de spot en Amazon EC2.
PowerShell
• blank-powershell: una función de PowerShell que muestra el uso de registro, las variables de
entorno y el SDK de AWS.
Para implementar una aplicación de ejemplo, siga las instrucciones de su archivo README. Para obtener
más información sobre la arquitectura y los casos de uso de una aplicación, lea los temas de este capítulo.
Temas
• Aplicación de ejemplo de función en blanco para AWS Lambda (p. 316)
• Aplicación de ejemplo de procesamiento de errores para AWS Lambda (p. 323)
• Aplicación de ejemplo de List manager para AWS Lambda (p. 327)
316
AWS Lambda Guía para desarrolladores
Arquitectura y código de controlador
Las variantes de esta aplicación de ejemplo están disponibles para los siguientes idiomas:
Variantes
• Node.js: blank-nodejs.
• Python: blank-python.
• Ruby: blank-ruby.
• Java: blank-java.
• Go: blank-go.
• C#: blank-csharp.
• PowerShell: blank-powershell.
Los ejemplos de este tema resaltan el código de la versión Node.js, pero los detalles son generalmente
aplicables a todas las variantes.
Puede implementar el ejemplo en unos minutos con la AWS CLI y con AWS CloudFormation. Siga las
instrucciones del archivo README para descargarla, configurarla e implementarla en su cuenta.
Secciones
• Arquitectura y código de controlador (p. 317)
• Automatización de implementación con AWS CloudFormation y la AWS CLI (p. 318)
• Instrumentación con el AWS X-Ray (p. 321)
• Administración de dependencias con capas (p. 322)
• AWS Lambda: ejecuta el código de la función, envía los registros de CloudWatch Logs y envía los datos
de rastreo a X-Ray. La función también llama a la API de Lambda para obtener detalles sobre las cuotas
y el uso de la cuenta en la región actual.
• AWS X-Ray: recopila datos de rastreo, indexa los rastros para las búsquedas y genera un mapa de
servicio.
• Amazon CloudWatch: almacena registros y métricas.
• AWS Identity and Access Management (IAM): otorga el permiso.
• Amazon Simple Storage Service(Amazon S3): almacena el paquete de implementación de la función
durante la implementación.
• AWS CloudFormation: crea los recursos de la aplicación e implementa el código de la función.
317
AWS Lambda Guía para desarrolladores
Automatización de implementación con
AWS CloudFormation y la AWS CLI
Se aplican cargos estándar por cada servicio. Para obtener más información, consulte Precios de AWS.
El código de función muestra un flujo de trabajo básico para procesar un evento. El controlador toma un
evento de Amazon Simple Queue Service (Amazon SQS) como entrada e itera a través de los registros
que contiene, registrando el contenido de cada mensaje. Registra el contenido del evento, el objeto
de contexto y las variables de entorno. Luego realiza una llamada con el SDK de AWS y devuelve la
respuesta al tiempo de ejecución de Lambda.
// Handler
exports.handler = async function(event, context) {
event.Records.forEach(record => {
console.log(record.body)
})
console.log('## ENVIRONMENT VARIABLES: ' + serialize(process.env))
console.log('## CONTEXT: ' + serialize(context))
console.log('## EVENT: ' + serialize(event))
return getAccountSettings()
}
Los tipos de entrada/salida para el controlador y el soporte para la programación asíncrona varían según
el tiempo de ejecución. En este ejemplo, el método del controlador es async, por lo que en Node.js esto
implica que debe devolver una promesa al tiempo de ejecución. El tiempo de ejecución de Lambda espera
a que se resuelva la promesa y devuelve la respuesta al invocador. Si el código de función o el SDK de
AWS del cliente devuelven un error, el tiempo de ejecución formatea el error en un documento JSON y lo
devuelve.
La aplicación de ejemplo no incluye una cola de Amazon SQS para enviar eventos, pero usa un evento de
Amazon SQS (event.json) para ilustrar cómo se procesan los eventos. Para agregar una cola de Amazon
SQS a la aplicación, consulte Uso de AWS Lambda con Amazon SQS (p. 296).
318
AWS Lambda Guía para desarrolladores
Automatización de implementación con
AWS CloudFormation y la AWS CLI
La plantilla de aplicación utiliza un tipo de recurso Modelo de aplicación sin servidor de AWS (AWS
SAM) para definir el modelo. AWS SAM simplifica la creación de plantillas para aplicaciones sin servidor
automatizando la definición de roles de ejecución, API y otros recursos.
La plantilla define los recursos de la pila de aplicaciones. Esto incluye la función, su rol de ejecución y una
capa de Lambda que proporciona las dependencias de biblioteca de la función. La pila no incluye el bucket
que AWS CLI utiliza durante la implementación o el grupo de registro de CloudWatch Logs.
AWSTemplateFormatVersion: '2010-09-09'
Transform: 'AWS::Serverless-2016-10-31'
Description: An AWS Lambda application that calls the Lambda API.
Resources:
function:
Type: AWS::Serverless::Function
Properties:
Handler: index.handler
Runtime: nodejs12.x
CodeUri: function/.
Description: Call the AWS Lambda API
Timeout: 10
# Function's execution role
Policies:
- AWSLambdaBasicExecutionRole
- AWSLambdaReadOnlyAccess
- AWSXrayWriteOnlyAccess
Tracing: Active
Layers:
- !Ref libs
libs:
Type: AWS::Serverless::LayerVersion
Properties:
LayerName: blank-nodejs-lib
Description: Dependencies for the blank sample app.
319
AWS Lambda Guía para desarrolladores
Automatización de implementación con
AWS CloudFormation y la AWS CLI
ContentUri: lib/.
CompatibleRuntimes:
- nodejs12.x
Al implementar la aplicación, AWS CloudFormation aplica la transformación AWS SAM a la plantilla para
generar una plantilla de AWS CloudFormation con tipos estándar como AWS::Lambda::Function y
AWS::IAM::Role.
{
"AWSTemplateFormatVersion": "2010-09-09",
"Description": "An AWS Lambda application that calls the Lambda API.",
"Resources": {
"function": {
"Type": "AWS::Lambda::Function",
"Properties": {
"Layers": [
{
"Ref": "libs32xmpl61b2"
}
],
"TracingConfig": {
"Mode": "Active"
},
"Code": {
"S3Bucket": "lambda-artifacts-6b000xmpl1e9bf2a",
"S3Key": "3d3axmpl473d249d039d2d7a37512db3"
},
"Description": "Call the AWS Lambda API",
"Tags": [
{
"Value": "SAM",
"Key": "lambda:createdBy"
}
],
En este ejemplo, la propiedad Code especifica un objeto en un bucket de Amazon S3. Esto corresponde a
la ruta local de la propiedad CodeUri en la plantilla de proyecto:
CodeUri: function/.
Para cargar los archivos de proyecto en Amazon S3, el script de implementación utiliza los comandos
de la AWS CLI. El comando cloudformation package preprocesa la plantilla, carga artefactos y
reemplaza rutas locales por ubicaciones de objetos de Amazon S3. El comando cloudformation
deploy implementa la plantilla procesada con un conjunto de cambios de AWS CloudFormation.
#!/bin/bash
set -eo pipefail
ARTIFACT_BUCKET=$(cat bucket-name.txt)
aws cloudformation package --template-file template.yml --s3-bucket $ARTIFACT_BUCKET --
output-template-file out.yml
aws cloudformation deploy --template-file out.yml --stack-name blank-nodejs --capabilities
CAPABILITY_NAMED_IAM
La primera vez que ejecuta este script, crea una pila de AWS CloudFormation denominada blank-
nodejs. Si realiza cambios en el código de función o en la plantilla, puede ejecutarlo de nuevo para
actualizar la pila.
320
AWS Lambda Guía para desarrolladores
Instrumentación con el AWS X-Ray
El primer nodo de servicio (AWS::Lambda) representa el servicio de Lambda, que valida la solicitud de
invocación y la envía a la función. El segundo nodo, AWS::Lambda::Function, representa la función en
sí.
Para registrar detalles adicionales, la función de ejemplo utiliza el SDK de X-Ray. Con cambios mínimos en
el código de función, el SDK de X-Ray registra detalles sobre las llamadas realizadas con el SDK de AWS
a los servicios de AWS.
La instrumentación del cliente de SDK de AWS agrega un nodo adicional al mapa de servicio y más
detalles en los registros de seguimiento. En este ejemplo, el mapa de servicio muestra la función de
ejemplo que llama a la API de Lambda para obtener detalles sobre el almacenamiento y el uso de
simultaneidad en la región actual.
321
AWS Lambda Guía para desarrolladores
Administración de dependencias con capas
El registro de seguimiento muestra detalles de tiempo para la invocación, con subsegmentos para
la inicialización de funciones, la invocación y la sobrecarga. El subsegmento de invocación tiene un
subsegmento para la llamada del SDK de AWS a la operación de la API GetAccountSettings.
Resources:
function:
Type: AWS::Serverless::Function
Properties:
Handler: index.handler
Runtime: nodejs12.x
CodeUri: function/.
Description: Call the AWS Lambda API
Timeout: 10
# Function's execution role
Policies:
- AWSLambdaBasicExecutionRole
- AWSLambdaReadOnlyAccess
- AWSXrayWriteOnlyAccess
Tracing: Active
Layers:
- !Ref libs
libs:
Type: AWS::Serverless::LayerVersion
Properties:
LayerName: blank-nodejs-lib
Description: Dependencies for the blank sample app.
ContentUri: lib/.
CompatibleRuntimes:
322
AWS Lambda Guía para desarrolladores
Procesador de errores
- nodejs12.x
El script 2-build-layer.sh instala las dependencias de la función con npm y las coloca en una carpeta
con la estructura requerida por el tiempo de ejecución de Lambda (p. 79).
#!/bin/bash
set -eo pipefail
mkdir -p lib/nodejs
rm -rf node_modules lib/nodejs/node_modules
npm install --production
mv node_modules lib/nodejs/
La primera vez que implemente la aplicación de ejemplo, la AWS CLI empaqueta por separado la capa del
código de función e implementa ambos. En las siguientes implementaciones, el archivo de capas solo se
carga si ha cambiado el contenido de la carpeta lib.
323
AWS Lambda Guía para desarrolladores
Arquitectura y estructura de eventos
Puede implementar el ejemplo en unos minutos con la AWS CLI y con AWS CloudFormation. Para
descargarlo, configurarlo e implementarlo en su cuenta, siga las instrucciones del archivo README.
Secciones
• Arquitectura y estructura de eventos (p. 324)
• Instrumentación con AWS X-Ray (p. 325)
• Plantilla de AWS CloudFormation y recursos adicionales (p. 326)
• AWS Lambda: ejecuta el código de la función, envía los registros de CloudWatch Logs y envía los datos
de rastreo a X-Ray.
• Amazon CloudWatch Logs: recopila los registros e invoca una función cuando una entrada de registro
coincide con un patrón de filtro.
• AWS X-Ray: recopila datos de rastreo, indexa los rastros para las búsquedas y genera un mapa de
servicio.
• Amazon Simple Storage Service (Amazon S3): almacena los artefactos de implementación y la salida de
la aplicación.
Una función de Lambda en la aplicación genera errores de forma aleatoria. Cuando CloudWatch Logs
detecta la palabra ERROR en los registros de la función, envía un evento a la función de procesamiento
para su procesamiento.
{
"awslogs": {
"data": "H4sIAAAAAAAAAHWQT0/DMAzFv0vEkbLYcdJkt4qVXmCDteIAm1DbZKjS
+kdpB0Jo350MhsQFyVLsZ+unl/fJWjeO5asrPgbH5..."
}
}
Una vez descodificados, los datos contienen información sobre el evento del registro. La función utiliza
estos detalles para identificar el flujo de registros y analiza el mensaje del registro para obtener el ID de la
solicitud que ha provocado el error.
{
"messageType": "DATA_MESSAGE",
"owner": "123456789012",
"logGroup": "/aws/lambda/lambda-error-processor-randomerror-1GD4SSDNACNP4",
"logStream": "2019/04/04/[$LATEST]63311769a9d742f19cedf8d2e38995b9",
"subscriptionFilters": [
"lambda-error-processor-subscription-15OPDVQ59CG07"
],
"logEvents": [
{
"id": "34664632210239891980253245280462376874059932423703429141",
"timestamp": 1554415868243,
324
AWS Lambda Guía para desarrolladores
Instrumentación con AWS X-Ray
"message": "2019-04-04T22:11:08.243Z\t1d2c1444-efd1-43ec-
b16e-8fb2d37508b8\tERROR\n"
}
]
}
La función de procesamiento utiliza la información del evento de CloudWatch Logs para descargar el flujo
de registros y el rastro de X-Ray completos para una solicitud que ha provocado un error. Almacena ambos
en un bucket de Amazon S3. Para permitir que finalicen el flujo de registros y tiempo de rastreo, la función
espera un breve periodo de tiempo antes de acceder a los datos.
Las dos funciones de Node.js están configuradas para el rastreo activo en la plantilla y se instrumentan
con el SDK de AWS X-Ray para Node.js en el código. Con el rastreo activo, las etiquetas Lambda añaden
un encabezado de rastreo a las solicitudes entrantes y envían un rastro con los datos de tiempo a X-Ray.
Además, la función de generación de errores aleatorios utiliza el SDK de X-Ray para registrar el ID de la
solicitud y la información del usuario en las anotaciones. Las anotaciones se asocian al rastro y se pueden
utilizar para localizar el rastro de una solicitud específica.
325
AWS Lambda Guía para desarrolladores
Plantilla de AWS CloudFormation y recursos adicionales
instrumentados con el SDK de X-Ray, para descargar el rastro y el flujo de registros. A continuación,
los almacena en el bucket de salida. El SDK de X-Ray registra estas llamadas, que aparecen como
subsegmentos en el rastro.
• Rol de ejecución: rol de IAM que concede a las funciones permiso para tener acceso a otros servicios de
AWS.
• Función iniciadora: función adicional que invoca la función de generación de errores aleatorios para
crear un grupo de registros.
• Recurso personalizado: recurso personalizado de AWS CloudFormation que invoca la función iniciadora
durante la implementación para asegurarse de que el grupo de registros existe.
• Suscripción a CloudWatch Logs: suscripción al flujo de registros que activa la función de procesamiento
cuando se registra la palabra ERROR.
• Política basada en recursos: instrucción de permisos para la función de procesamiento que permite a
CloudWatch Logs invocarla.
• Bucket de Amazon S3: ubicación de almacenamiento para la salida de la función de procesamiento.
Para solucionar una limitación de la integración de Lambda con AWS CloudFormation, la plantilla crea una
función adicional que se ejecuta durante las implementaciones. Todas las funciones de Lambda vienen
con un grupo de registros de CloudWatch Logs que almacena la salida de sus ejecuciones. Sin embargo,
el grupo de registros no se crea hasta que la función se invoca por primera vez.
Para crear la suscripción, que depende de la existencia del grupo de registros, la aplicación utiliza una
tercera función de Lambda para invocar la función de generación de errores aleatorios. La plantilla incluye
el código de la función iniciadora insertado. Un recurso de AWS CloudFormation personalizado la llama
durante la implementación. Las propiedades DependsOn permiten asegurarse de que el flujo de registros y
la política basada en recursos se han creado antes de la suscripción.
326
AWS Lambda Guía para desarrolladores
List manager
Los clientes envían registros a una secuencia de Kinesis, que los almacena y los pone a disposición para
su procesamiento. La secuencia de Kinesis se utiliza como una cola para almacenar en búfer registros
hasta que se puedan procesar. A diferencia de una cola de Amazon SQS, los registros de una secuencia
de Kinesis no se eliminan después de procesarlos, por lo que varios consumidores pueden procesar los
mismos datos. Los registros de Kinesis también se procesan en orden, mientras que los elementos de cola
se pueden entregar fuera de orden. Los registros se eliminan de la secuencia después de 7 días.
Además de la función que procesa eventos, la aplicación incluye una segunda función para realizar tareas
administrativas en la base de datos. El código de la función está disponible en los siguientes archivos:
• Procesador: processor/index.js
• Administrador de base de datos: dbadmin/index.js
Puede implementar el ejemplo en unos minutos con la AWS CLI y con AWS CloudFormation. Para
descargarlo, configurarlo e implementarlo en su cuenta, siga las instrucciones del archivo README.
Secciones
• Arquitectura y estructura de eventos (p. 328)
• Instrumentación con AWS X-Ray (p. 329)
• Plantillas de AWS CloudFormation y recursos adicionales (p. 331)
327
AWS Lambda Guía para desarrolladores
Arquitectura y estructura de eventos
Precios
La aplicación procesa documentos JSON de clientes que contienen la información necesaria para
actualizar una lista. Es compatible con dos tipos de listas: recuento y clasificación. Un recuento contiene
valores que se agregan al valor actual para una clave si existe. Cada entrada procesada para un usuario
aumenta el valor de una clave en la tabla especificada.
{
"title": "stats",
"user": "bill",
"type": "tally",
"entries": {
"xp": 83
}
}
Una clasificación contiene una lista de entradas donde el valor es el orden en el que se clasifican. Una
clasificación se puede actualizar con diferentes valores que sobrescriben el valor actual, en lugar de
incrementarlo. En el siguiente ejemplo se muestra una clasificación de películas favoritas:
{
"title": "favorite movies",
"user": "mike",
"type": "rank",
"entries": {
"blade runner": 1,
"the empire strikes back": 2,
"alien": 3
}
}
Un mapeo de origen de eventos (p. 109) de Lambda lee registros de la secuencia en lotes e invoca la
función de procesador. El evento que recibió el controlador de funciones contiene una matriz de objetos
328
AWS Lambda Guía para desarrolladores
Instrumentación con AWS X-Ray
que contienen detalles sobre un registro, como cuándo se recibió, detalles sobre la secuencia y una
representación codificada del documento de registro original.
{
"Records": [
{
"kinesis": {
"kinesisSchemaVersion": "1.0",
"partitionKey": "0",
"sequenceNumber": "49598630142999655949899443842509554952738656579378741250",
"data":
"eyJ0aXRsZSI6ICJmYXZvcml0ZSBtb3ZpZXMiLCAidXNlciI6ICJyZGx5c2N0IiwgInR5cGUiOiAicmFuayIsICJlbnRyaWVzIjoge
"approximateArrivalTimestamp": 1570667770.615
},
"eventSource": "aws:kinesis",
"eventVersion": "1.0",
"eventID":
"shardId-000000000000:49598630142999655949899443842509554952738656579378741250",
"eventName": "aws:kinesis:record",
"invokeIdentityArn": "arn:aws:iam::123456789012:role/list-manager-
processorRole-7FYXMPLH7IUS",
"awsRegion": "us-east-2",
"eventSourceARN": "arn:aws:kinesis:us-east-2:123456789012:stream/list-manager-
stream-87B3XMPLF1AZ"
},
...
Cuando se descodifican, los datos contienen un registro. La función utiliza el registro para actualizar la
lista del usuario y una lista de agregación que almacena los valores acumulados en todos los usuarios.
También almacena una copia del evento en la base de datos de la aplicación.
La función de Node.js está configurada para realizar un seguimiento activo de la plantilla y se instrumenta
con SDK de AWS X-Ray para Node.js en el código. El SDK de X-Ray registra un subsegmento para cada
llamada realizada con un cliente de AWS SDK o MySQL.
329
AWS Lambda Guía para desarrolladores
Instrumentación con AWS X-Ray
La función utiliza AWS SDK for JavaScript in Node.js para leer y escribir en dos tablas para cada registro.
La tabla principal almacena el estado actual de cada combinación de nombre de lista y usuario. La tabla
agregada almacena listas que combinan datos de varios usuarios.
330
AWS Lambda Guía para desarrolladores
Plantillas de AWS CloudFormation y recursos adicionales
Recursos de aplicaciones
• Rol de ejecución: rol de IAM que concede a las funciones permiso para tener acceso a otros servicios de
AWS.
• Mapeo de origen de eventos de Lambda: lee registros de la secuencia de datos e invoca la función.
Una segunda plantilla, template-vpcrds.yml, crea los recursos de la base de datos y Amazon VPC. Aunque
es posible crear todos los recursos en una plantilla, separarlos facilita la limpieza de la aplicación y permite
que la base de datos se reutilice con varias aplicaciones.
Recursos de infraestructura
• VPC: una red de nube virtual privada con subredes privadas, una tabla de enrutamiento y un punto de
enlace de la VPC que permite que la función se comunique con DynamoDB sin una conexión a Internet.
• Base de datos: una instancia de base de datos de Amazon RDS y un grupo de subredes que la conecta
a la VPC.
331
AWS Lambda Guía para desarrolladores
Las funciones de Lambda utilizan un rol de ejecución (p. 33) para obtener permiso para escribir registros
en Amazon CloudWatch Logs y para tener acceso a otros servicios y recursos. Si aún no tiene un rol de
ejecución para el desarrollo de funciones, cree uno.
Puede agregar permisos al rol más tarde o cambiarlo por otro rol específico para una sola función.
332
AWS Lambda Guía para desarrolladores
La consola crea una función de Lambda con un único archivo de origen denominado index.js. Puede
editar este archivo y agregar más archivos en el editor de código (p. 7) integrado. Para guardar los
cambios, elija Save. A continuación, para ejecutar el código, elija Test (Probar).
Note
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 más información, consulte Trabajar con funciones de AWS Lambda en la
Guía del usuario de AWS Cloud9.
El archivo index.js exporta una función denominada handler que toma un objeto de evento y un objeto
context. Esta es la función de controlador (p. 334) a la que llama Lambda cuando se invoca la función. El
tiempo de ejecución de la función de Node.js 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 index.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 archivo ZIP que contiene el código de su 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 (p. 336) y actualizando el
código en la línea de comandos.
Note
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.
• blank-nodejs: una función de Node.js que muestra el uso de registro, las variables de entorno,
el seguimiento de AWS X-Ray, las capas, las pruebas de unidad y el SDK de AWS.
• nodejs-apig: una función con un punto de enlace de API público que procesa un evento desde
API Gateway y devuelve una respuesta HTTP.
• rds-mysql: una función que transmite consultas a una base de datos MySQL para RDS. Este
ejemplo incluye una VPC privada y una instancia de base de datos configurada con una
contraseña en AWS Secrets Manager.
• efs-nodejs: una función que utiliza un sistema de archivos de Amazon EFS en una Amazon
VPC. Este ejemplo incluye una VPC, un sistema de archivos, objetivos de montaje y un punto
de acceso configurados para su uso con Lambda.
• list-manager: una función procesa eventos de un flujo de datos de Amazon Kinesis y actualiza
listas agregadas en Amazon DynamoDB. La función almacena un registro de cada evento en
una base de datos MySQL for RDS en una VPC privada. Este ejemplo incluye una VPC privada
con un punto de enlace de la VPC para DynamoDB y una instancia de base de datos.
• error-processor: una función Node.js genera errores para un porcentaje especificado de
solicitudes. Una suscripción de CloudWatch Logs invoca una segunda función cuando se
registra un error. La función de procesador utiliza el SDK de AWS para recopilar detalles sobre
la solicitud y almacenarlos en un bucket de Amazon S3.
333
AWS Lambda Guía para desarrolladores
Controlador
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 (p. 338) 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.
Temas
• Controlador de la función AWS Lambda en Node.js (p. 334)
• Paquete de implementación de AWS Lambda en Node.js (p. 336)
• Objeto context de AWS Lambda en Node.js (p. 338)
• Registro de funciones AWS Lambda en Node.js (p. 339)
• Errores de funciones AWS Lambda en Node.js (p. 342)
• Instrumentación del código Node.js en AWS Lambda (p. 344)
La siguiente función de ejemplo registra el contenido del objeto de evento y devuelve la ubicación de los
registros.
Example index.js
Al configurar una función (p. 54), el valor del controlador es el nombre del archivo y el nombre de un
módulo del controlador exportado, separados por un punto. El valor predeterminado en la consola y para
ejemplos de esta guía es index.handler. Esto indica el módulo handler que index.js exporta.
El tiempo de ejecución pasa tres argumentos al método del controlador. El primer argumento es el objeto
event, que contiene información del invoker. El invocador pasa esta información como una cadena con
formato JSON cuando llama a Invoke (p. 587) y el tiempo de ejecución la convierte en un objeto. Cuando
un servicio de AWS invoca su función, la estructura de eventos varía por servicio (p. 163).
El segundo argumento es el objeto context (p. 338), que incluye información sobre la invocación,
la función y el entorno de ejecución. En el ejemplo anterior, la función obtiene el nombre de flujo de
registro (p. 339) del objeto context y lo devuelve al invocador.
El tercer argumento, callback, es una función a la que puede llamar en los controladores no
asincrónicos (p. 335) para enviar una respuesta. La función de devolución de llamada toma dos
argumentos: un Error y una respuesta. Cuando lo llama, Lambda espera a que el bucle de evento esté
vacío y luego devuelve la respuesta o error al invocador. El objeto de respuesta debe ser compatible con
JSON.stringify.
En los controladores asincrónicos, debe devolver una respuesta, un error o una promesa al tiempo de
ejecución en lugar de usar callback.
334
AWS Lambda Guía para desarrolladores
Controladores asincrónicos
Controladores asincrónicos
En las funciones asincrónicas, puede utilizar return y throw para enviar una respuesta o un error,
respectivamente. Las funciones deben usar la palabra clave async para utilizar estos métodos a fin de
devolver una respuesta o error.
Si su código realiza una tarea asíncrona, devuelva una promesa para asegurarse que termina de
ejecutarse. Al resolver o rechazar la promesa, Lambda envía la respuesta o error al invocador.
Para las bibliotecas que devuelven una promesa, puede devolver esa promesa directamente al tiempo de
ejecución.
Controladores no asincrónicos
La siguiente función de ejemplo comprueba una URL y devuelve el código de estado al invocador.
En los controladores no asincrónicos, la ejecución de la función prosigue hasta que el bucle de eventos
está vacío o se agota el tiempo de espera de la función. La respuesta no se envía al invoker hasta que
todas las tareas de bucle de eventos hayan terminado. Si el tiempo de espera de la función se agota,
335
AWS Lambda Guía para desarrolladores
Paquete de implementación
se devolverá un error en su lugar. Puede configurar el tiempo de ejecución para enviar la respuesta
inmediatamente estableciendo context.callbackWaitsForEmptyEventLoop (p. 338) en false.
En el siguiente ejemplo, la respuesta de Amazon S3 se devolverá al invocador tan pronto como esté
disponible. El tiempo de espera que se ejecuta en el bucle de eventos se ha detenido y continuará
ejecutándose la próxima vez que se invoque la función.
Si utiliza el editor de consola (p. 7) de Lambda para crear la función, la consola administra el paquete de
implementación. Puede utilizar este método siempre y cuando no tenga que añadir ninguna biblioteca.
También puede utilizarlo para actualizar una función que ya tenga bibliotecas en el paquete de
implementación, siempre y cuando el tamaño total no supere el 3 MB.
Note
Para que el tamaño del paquete de implementación sea reducido, empaquete las dependencias
de la función en capas. Las capas le permiten administrar las dependencias de forma
independiente, pueden utilizarlas varias funciones y pueden compartirse con otras cuentas. Para
obtener más información, consulte Capas de AWS Lambda (p. 76).
Secciones
• Actualización de una función sin dependencias (p. 336)
• Actualización de una función con dependencias adicionales (p. 337)
336
AWS Lambda Guía para desarrolladores
Actualización de una función con dependencias adicionales
~/my-function
### index.js
### node_modules
### async
### async-listener
### atomic-batcher
### aws-sdk
### aws-xray-sdk
### aws-xray-sdk-core
337
AWS Lambda Guía para desarrolladores
Contexto
"FunctionName": "my-function",
"FunctionArn": "arn:aws:lambda:us-east-2:123456789012:function:my-function",
"Runtime": "nodejs12.x",
"Role": "arn:aws:iam::123456789012:role/lambda-role",
"Handler": "index.handler",
"CodeSha256": "Qf0hMc1I2di6YFMi9aXm3JtGTmcDbjniEuiYonYptAk=",
"Version": "$LATEST",
"TracingConfig": {
"Mode": "Active"
},
"RevisionId": "983ed1e3-ca8e-434b-8dc1-7d72ebadd83d",
...
}
Además del código y las bibliotecas, su paquete de implementación también puede incluir archivos
ejecutables y otros recursos. Para obtener más información, consulte los siguientes temas:
Métodos de context
Propiedades de context
338
AWS Lambda Guía para desarrolladores
Registro
• client.app_version_code
• client.app_package_name
• env.platform_version
• env.platform
• env.make
• env.model
• env.locale
• Custom: valores personalizados que establece la aplicación móvil.
• callbackWaitsForEmptyEventLoop: configúrelo en false para enviar la respuesta de forma
inmediata cuando se ejecuta la devolución de llamada (p. 335), en lugar de esperar a que el bucle de
eventos de Node.js esté vacío. Si esto es false, los eventos pendientes siguen ejecutándose durante el
siguiente periodo de invocación.
La siguiente función de ejemplo registra información de contexto y devuelve la ubicación de los registros.
Para generar registros desde el código de las funciones, puede utilizar los métodos del objeto de la
consola o cualquier biblioteca de registro que escriba en stdout o en stderr. En el siguiente ejemplo, se
registran los valores de las variables de entorno y el objeto de evento.
339
AWS Lambda Guía para desarrolladores
Visualización de registros en la
Consola de administración de AWS
"NODE_PATH": "/opt/nodejs/node10/node_modules:/opt/nodejs/node_modules:/var/runtime/
node_modules",
...
}
2019-06-07T19:11:20.563Z c793869b-ee49-115b-a5b6-4fd21e8dedac INFO EVENT
{
"key": "value"
}
2019-06-07T19:11:20.564Z c793869b-ee49-115b-a5b6-4fd21e8dedac WARN Event not processed.
END RequestId: c793869b-ee49-115b-a5b6-4fd21e8dedac
REPORT RequestId: c793869b-ee49-115b-a5b6-4fd21e8dedac Duration: 128.83 ms Billed Duration:
200 ms Memory Size: 128 MB Max Memory Used: 74 MB Init Duration: 166.62 ms XRAY TraceId:
1-5d9d007f-0a8c7fd02xmpl480aed55ef0 SegmentId: 3d752xmpl1bbe37e Sampled: true
El tiempo de ejecución de Node.js registra las líneas START, END y REPORT de cada invocación. Se agrega
una marca de tiempo, un ID de solicitud y el nivel de registro en cada entrada registrada por la función. La
línea del informe proporciona los siguientes detalles.
Registro de informes
Puede ver los registros en la consola de Lambda o en la de CloudWatch Logs, o bien en la línea de
comandos.
Secciones
• Visualización de registros en la Consola de administración de AWS (p. 340)
• Mediante AWS CLI (p. 341)
• Eliminación de registros (p. 342)
340
AWS Lambda Guía para desarrolladores
Mediante AWS CLI
Cada flujo de registro se corresponde con una instancia de su función (p. 132). Los nuevos flujos aparecen
cuando se actualiza la función y cuando se crean más instancias para atendar varias invocaciones
simultáneas. Para buscar los registros de invocaciones específicas, puede instrumentar la función con
X-Ray y registrar los detalles sobre el flujo de registro y la solicitud en el registro de seguimiento. Para
obtener una aplicación de ejemplo que correlacione registros y rastros de seguimiento con X-Ray, consulte
Aplicación de ejemplo de procesamiento de errores para AWS Lambda (p. 323).
La utilidad base64 está disponible en Linux, MacOS y Ubuntu en Windows. Para el sistema operativo
macOS, el comando es base64 -D.
Para obtener eventos de registro completos desde la línea de comandos, puede incluir el nombre del
flujo de registros en la salida de la función, como se muestra en el ejemplo anterior. El siguiente script de
ejemplo invoca una función denominada my-function y descarga los últimos cinco eventos de registro.
#!/bin/bash
aws lambda invoke --function-name my-function --payload '{"key": "value"}' out
sed -i'' -e 's/"//g' out
sleep 15
aws logs get-log-events --log-group-name /aws/lambda/my-function --log-stream-name $(cat
out) --limit 5
El script utiliza sed para eliminar las comillas del archivo de salida y permanece inactivo durante
15 segundos para dar tiempo a que los registros estén disponibles. La salida incluye la respuesta de
Lambda y la salida del comando get-log-events.
$ ./get-logs.sh
{
"StatusCode": 200,
"ExecutedVersion": "$LATEST"
341
AWS Lambda Guía para desarrolladores
Eliminación de registros
}
{
"events": [
{
"timestamp": 1559763003171,
"message": "START RequestId: 4ce9340a-b765-490f-ad8a-02ab3415e2bf Version:
$LATEST\n",
"ingestionTime": 1559763003309
},
{
"timestamp": 1559763003173,
"message": "2019-06-05T19:30:03.173Z\t4ce9340a-b765-490f-ad8a-02ab3415e2bf
\tINFO\tENVIRONMENT VARIABLES\r{\r \"AWS_LAMBDA_FUNCTION_VERSION\": \"$LATEST\",\r ...",
"ingestionTime": 1559763018353
},
{
"timestamp": 1559763003173,
"message": "2019-06-05T19:30:03.173Z\t4ce9340a-b765-490f-ad8a-02ab3415e2bf
\tINFO\tEVENT\r{\r \"key\": \"value\"\r}\n",
"ingestionTime": 1559763018353
},
{
"timestamp": 1559763003218,
"message": "END RequestId: 4ce9340a-b765-490f-ad8a-02ab3415e2bf\n",
"ingestionTime": 1559763018353
},
{
"timestamp": 1559763003218,
"message": "REPORT RequestId: 4ce9340a-b765-490f-ad8a-02ab3415e2bf\tDuration:
26.73 ms\tBilled Duration: 100 ms \tMemory Size: 128 MB\tMax Memory Used: 75 MB\t\n",
"ingestionTime": 1559763018353
}
],
"nextForwardToken": "f/34783877304859518393868359594929986069206639495374241795",
"nextBackwardToken": "b/34783877303811383369537420289090800615709599058929582080"
}
Eliminación de registros
Los grupos de registros no se eliminan automáticamente al eliminar una función. Para evitar los registros
de almacenamiento de forma indefinida, elimine el grupo de registros o configure un periodo de retención
después del cual los registros se eliminarán automáticamente.
Este código da como resultado un error de referencia. Lambda detecta el error y genera un documento
JSON con campos para el mensaje de error, el tipo y el seguimiento de la pila.
{
"errorType": "ReferenceError",
342
AWS Lambda Guía para desarrolladores
Errores
Cuando se invoca la función desde la línea de comandos, la AWS CLI divide la respuesta en dos
documentos. Para indicar que se ha producido un error en la función, la respuesta que se muestra en el
terminal incluye un campo FunctionError. La respuesta o el error que devuelve la función se escribe en
el archivo de salida.
$ cat out.json
{"errorType":"ReferenceError","errorMessage":"x is not defined","trace":["ReferenceError:
x is not defined"," at Runtime.exports.handler (/var/task/index.js:2:3)"," at
Runtime.handleOnce (/var/runtime/Runtime.js:63:25)"," at process._tickCallback (internal/
process/next_tick.js:68:7)"]}
Note
El código de estado 200 (correcto) de la respuesta de Lambda indica que no hubo ningún error
en la solicitud que envió a Lambda. Para ver los problemas que generan un código de estado de
error, consulte Errors (p. 589).
Lambda también registra hasta 256 KB del objeto de error en los registros de la función. Para ver los
registros cuando realice la invocación de la función desde la línea de comandos, utilice la opción --log-
type y descodifique la cadena base64 de la respuesta.
Para obtener más información acerca de los registros, consulte Registro de funciones AWS Lambda en
Node.js (p. 339).
En función del origen de eventos, AWS Lambda podría volver a intentar la ejecución de la función de
Lambda que ha generado un error. Por ejemplo, si Kinesis es el origen de eventos, AWS Lambda reintenta
la invocación que produce errores hasta que la función de Lambda se ejecute correctamente o hasta que
los registros del flujo caduquen. Para obtener más información acerca de los reintentos, consulte Control
de errores y reintentos automáticos en AWS Lambda (p. 119).
343
AWS Lambda Guía para desarrolladores
Tracing
Para rastrear solicitudes que no tienen un encabezado de rastreo, habilite el rastreo activo en la
configuración de la función.
Precios
X-Ray tiene una capa gratuita permanente Más allá del umbral de la capa gratuita, X-Ray realiza
cargos por almacenamiento y recuperación del seguimiento. Consulte Precios de AWS X-Ray
para obtener más información.
Su función necesita permiso para cargar datos de rastreo en X-Ray. Cuando habilita el rastreo activo en la
Lambda consola, Lambda agrega los permisos necesarios al rol de ejecución (p. 33) de la función. De lo
contrario, agregue la política AWSXRayDaemonWriteAccess al rol de ejecución.
344
AWS Lambda Guía para desarrolladores
Tracing
X-Ray aplica un algoritmo de muestreo para garantizar que el rastreo sea eficiente, al tiempo que
proporciona una muestra representativa de las solicitudes a las que sirve la aplicación. La regla de
muestreo predeterminada es 1 solicitud por segundo y un 5 por ciento de las solicitudes adicionales.
Cuando el rastreo activo está habilitado, Lambda registra el rastreo de un subconjunto de invocaciones.
Lambda registra dos segmentos, lo que crea dos nodos en el mapa de servicio. El primer nodo representa
el servicio de Lambda que recibe la solicitud de invocación. El tiempo de ejecución (p. 19) de la función
registra el segundo nodo.
Puede instrumentar su código de controlador para registrar metadatos y rastrear llamadas descendentes.
Para registrar detalles sobre las llamadas que su controlador realiza a otros recursos y servicios, use
el SDK para Node.js de X-Ray. Para obtener el SDK, agregue el paquete aws-xray-sdk-core a las
dependencias de su aplicación.
Example blank-nodejs/package.json
{
"name": "blank-nodejs",
"version": "1.0.0",
"private": true,
"devDependencies": {
"aws-sdk": "2.631.0",
"jest": "25.4.0"
},
"dependencies": {
"aws-xray-sdk-core": "1.1.2"
},
"scripts": {
"test": "jest"
}
}
Para instrumentar clientes SDK de AWS, ajuste la biblioteca de aws-sdk con el método captureAWS.
// Handler
exports.handler = async function(event, context) {
event.Records.forEach(record => {
345
AWS Lambda Guía para desarrolladores
Habilitación del seguimiento activo con la API de Lambda
...
En el ejemplo siguiente se muestra un seguimiento con 2 segmentos. Ambos se llaman my-function, pero
uno es tipo AWS::Lambda y el otro es AWS::Lambda::Function. El segmento de función se expande
para mostrar sus subsegmentos.
El primer segmento representa la solicitud de invocación procesada por el servicio Lambda. El segundo
segmento registra el trabajo realizado por la función. El segmento de la función tiene 3 subsegmentos.
También puede instrumentar clientes HTTP, registrar consultas SQL y crear subsegmentos personalizados
con anotaciones y metadatos. Para obtener más información, consulte SDK de X-Ray para Node.js en la
Guía para desarrolladores de AWS X-Ray.
Secciones
• Habilitación del seguimiento activo con la API de Lambda (p. 346)
• Habilitación del seguimiento activo con AWS CloudFormation (p. 347)
• Almacenamiento de dependencias en tiempo de ejecución en una capa (p. 347)
El siguiente comando de la AWS CLI de ejemplo habilita el rastreo activo en una función llamada «my-
function».
346
AWS Lambda Guía para desarrolladores
Habilitación del seguimiento
activo con AWS CloudFormation
El modo de seguimiento forma parte de la configuración específica de la versión, que se bloquea cuando
se publica una versión de la función. No se puede cambiar el modo de seguimiento de una versión
publicada.
Resources:
function:
Type: AWS::Lambda::Function
Properties:
TracingConfig:
Mode: Active
...
Resources:
function:
Type: AWS::Serverless::Function
Properties:
Tracing: Active
...
Resources:
function:
Type: AWS::Serverless::Function
Properties:
CodeUri: function/.
Tracing: Active
347
AWS Lambda Guía para desarrolladores
Almacenamiento de dependencias
en tiempo de ejecución en una capa
Layers:
- !Ref libs
...
libs:
Type: AWS::Serverless::LayerVersion
Properties:
LayerName: blank-nodejs-lib
Description: Dependencies for the blank sample app.
ContentUri: lib/.
CompatibleRuntimes:
- nodejs12.x
Con esta configuración, solo actualiza la capa de la biblioteca si se modifican las dependencias del tiempo
de ejecución. El paquete de implementación de funciones solo contiene su código. Cuando actualiza el
código de la función, el tiempo de carga es mucho más rápido que si incluye dependencias en el paquete
de implementación.
Para crear una capa de dependencias, es necesario realizar cambios en la compilación para generar el
archivo de capas antes de la implementación. Para ver un ejemplo de trabajo, consulte la aplicación de
ejemplo blank-nodejs .
348
AWS Lambda Guía para desarrolladores
Las funciones de Lambda utilizan un rol de ejecución (p. 33) para obtener permiso para escribir registros
en Amazon CloudWatch Logs y para tener acceso a otros servicios y recursos. Si aún no tiene un rol de
ejecución para el desarrollo de funciones, cree uno.
Puede agregar permisos al rol más tarde o cambiarlo por otro rol específico para una sola función.
349
AWS Lambda Guía para desarrolladores
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 (p. 7) integrado. Para guardar los
cambios, elija Save. A continuación, para ejecutar el código, elija Test (Probar).
Note
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 más información, consulte Trabajar con funciones de AWS 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 (p. 351) 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 archivo ZIP que contiene el código de su 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 (p. 352) y actualizando el
código en la línea de comandos.
Note
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.
• blank-python: una función de Python que muestra el uso del registro, las variables de 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 (p. 355) 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.
Temas
350
AWS Lambda Guía para desarrolladores
Controlador
• event: AWS Lambda utiliza este parámetro para pasar datos de eventos al controlador. Este parámetro
suele ser del tipo dict de Python. También puede ser del tipo list, str, int, float, o NoneType.
Cuando se invoca una función, se determina el contenido y la estructura del evento. Cuando un servicio
de AWS invoca su función, la estructura del evento varía en función del servicio. Para obtener más
información, consulte Utilización de AWS Lambda con otros servicios (p. 163).
• context: AWS Lambda utiliza este parámetro para proporcionar información sobre el tiempo de
ejecución al controlador. Para obtener más información, consulte Objeto context de AWS Lambda en
Python (p. 355).
• Si lo desea, el controlador puede devolver un valor. Lo que sucede con el valor devuelto depende del
tipo de invocación que se utilice al invocar la función de Lambda:
• Si se utiliza el tipo de invocación RequestResponse (ejecución síncrona), AWS Lambda devuelve
el resultado de la llamada a la función de Python al cliente que invoca la función de Lambda (en la
respuesta HTTP a la solicitud de invocación, serializada en JSON). Por ejemplo, la consola de AWS
Lambda utiliza el tipo de invocación RequestResponse, por lo que al invocar la función utilizando la
consola, esta mostrará el valor devuelto.
• Si el controlador devuelve objetos que no se pueden serializar con json.dumps, el tiempo de
ejecución devuelve un error.
• Si el controlador devuelve None, al igual que hacen las funciones de Python sin una instrucción
return, el runtime devuelve null.
• Si se utiliza el tipo de invocación Event (ejecución asíncrona), el valor se descarta.
Este ejemplo tiene una función denominada my_handler. La función devuelve un mensaje que contiene
los datos del evento que recibió como entrada.
351
AWS Lambda Guía para desarrolladores
Paquete de implementación
Si utiliza el editor de consola (p. 7) de Lambda para crear la función, la consola administra el paquete de
implementación. Puede utilizar este método siempre y cuando no tenga que añadir ninguna biblioteca.
También puede utilizarlo para actualizar una función que ya tenga bibliotecas en el paquete de
implementación, siempre y cuando el tamaño total no supere el 3 MB.
Note
Puede utilizar el comando build de la CLI de AWS SAM para crear un paquete de
implementación para el código y las dependencias de la función de Python. La CLI de AWS SAM
también proporciona una opción para crear el paquete de implementación dentro de una imagen
de Docker que es compatible con el entorno de ejecución de Lambda. Para obtener instrucciones,
consulte el tema relacionado con la creación de aplicaciones con dependencias en la guía para
desarrolladores de AWS SAM.
Secciones
• Requisitos previos (p. 352)
• Actualización de una función sin dependencias (p. 352)
• Actualización de una función con dependencias adicionales (p. 353)
• Con un entorno virtual (p. 354)
Requisitos previos
En estas instrucciones se da por hecho que ya tiene una función. Si no ha creado aún una función,
consulte Creación de funciones de Lambda con Python (p. 349).
Para seguir los procedimientos de esta guía, necesitará un shell o un terminal de línea de comando donde
pueda ejecutar los comandos. Los comandos aparecen en listas y van precedidos del símbolo del sistema
($) y del nombre del directorio actual, si es aplicable:
Para los comandos largos, se utiliza un carácter de escape (\) para dividir un comando en varias líneas.
En Linux y macOS, use su administrador de shell y paquetes preferido. En Windows 10, puede instalar
Windows Subsystem para Linux para obtener una versión de Ubuntu y Bash integrada con Windows.
352
AWS Lambda Guía para desarrolladores
Actualización de una función con dependencias adicionales
Para las bibliotecas que utilizan módulos de extensión escritos en C o C++, cree el paquete de
implementación en un entorno de Amazon Linux. Puede utilizar el comando de compilación de la
CLI de SAM, que utiliza Docker, o crear el paquete de implementación en Amazon EC2 o AWS
CodeBuild.
En el ejemplo siguiente se muestra cómo crear un paquete de implementación que incluya una biblioteca
de gráficos común denominada Pillow.
1. Instale las bibliotecas en un nuevo directorio package local del proyecto con la opción --target de
pip.
Note
Para que --target funcione en sistemas basados en Debian como Ubuntu, es posible que
también tenga que transferir la marca --system para evitar errores distutils.
2. Cree un archivo ZIP de las dependencias.
~/my-function$ cd package
353
AWS Lambda Guía para desarrolladores
Con un entorno virtual
~/my-function/package$ cd $OLDPWD
~/my-function$ zip -g function.zip lambda_function.py
adding: lambda_function.py (deflated 56%)
Note
En Python 3.3 y posteriores, puede utilizar el módulo venv integrado para crear un entorno
virtual, en lugar de instalar virtualenv.
2. Active el entorno.
354
AWS Lambda Guía para desarrolladores
Contexto
(v-env) ~/my-function$
~/my-function$ cd v-env/lib/python3.8/site-packages
~/my-function/v-env/lib/python3.8/site-packages$ zip -r9 ${OLDPWD}/function.zip .
adding: easy_install.py (deflated 17%)
adding: PIL/ (stored 0%)
adding: PIL/.libs/ (stored 0%)
adding: PIL/.libs/libfreetype-7ce95de6.so.6.16.1 (deflated 65%)
adding: PIL/.libs/libjpeg-3fe7dfc0.so.9.3.0 (deflated 72%)
...
~/my-function/v-env/lib/python3.8/site-packages$ cd $OLDPWD
~/my-function$ zip -g function.zip lambda_function.py
adding: lambda_function.py (deflated 56%)
355
AWS Lambda Guía para desarrolladores
Contexto
Métodos de context
Propiedades de context
En el siguiente ejemplo se muestra una función de controlador que registra información de context.
Example handler.py
import time
def get_my_log_stream(event, context):
print("Log stream name:", context.log_stream_name)
print("Log group name:", context.log_group_name)
print("Request ID:",context.aws_request_id)
print("Mem. limits(MB):", context.memory_limit_in_mb)
# Code will execute quickly, so we add a 1 second intentional delay so you can see that
in time remaining value.
time.sleep(1)
print("Time remaining (MS):", context.get_remaining_time_in_millis())
Además de las opciones que se enumeran anteriormente, también puede utilizar el SDK de AWS X-Ray
para Instrumentación del código Python en AWS Lambda (p. 361) a fin de identificar las rutas de código
críticas, rastrear su desempeño y capturar los datos para su análisis.
356
AWS Lambda Guía para desarrolladores
Registro
Para generar registros desde el código de su función, puede utilizar el método print o cualquier biblioteca
de registro que escriba en stdout o en stderr. En el siguiente ejemplo, se registran los valores de las
variables de entorno y el objeto de evento.
Example lambda_function.py
import os
El tiempo de ejecución de Python registra las líneas START, END y REPORT de cada invocación. La línea
del informe proporciona los siguientes detalles.
Registro de informes
Puede ver los registros en la consola de Lambda o en la de CloudWatch Logs, o bien en la línea de
comandos.
357
AWS Lambda Guía para desarrolladores
Visualización de registros en la
Consola de administración de AWS
Secciones
• Visualización de registros en la Consola de administración de AWS (p. 358)
• Mediante AWS CLI (p. 358)
• Eliminación de registros (p. 360)
• Biblioteca de registro (p. 360)
Cada flujo de registro se corresponde con una instancia de su función (p. 132). Los nuevos flujos aparecen
cuando se actualiza la función y cuando se crean más instancias para atendar varias invocaciones
simultáneas. Para buscar los registros de invocaciones específicas, puede instrumentar la función con
X-Ray y registrar los detalles sobre el flujo de registro y la solicitud en el registro de seguimiento. Para
obtener una aplicación de ejemplo que correlacione registros y rastros de seguimiento con X-Ray, consulte
Aplicación de ejemplo de procesamiento de errores para AWS Lambda (p. 323).
La utilidad base64 está disponible en Linux, MacOS y Ubuntu en Windows. Para el sistema operativo
macOS, el comando es base64 -D.
358
AWS Lambda Guía para desarrolladores
Mediante AWS CLI
Para obtener eventos de registro completos desde la línea de comandos, puede incluir el nombre del
flujo de registros en la salida de la función, como se muestra en el ejemplo anterior. El siguiente script de
ejemplo invoca una función denominada my-function y descarga los últimos cinco eventos de registro.
#!/bin/bash
aws lambda invoke --function-name my-function --payload '{"key": "value"}' out
sed -i'' -e 's/"//g' out
sleep 15
aws logs get-log-events --log-group-name /aws/lambda/my-function --log-stream-name $(cat
out) --limit 5
El script utiliza sed para eliminar las comillas del archivo de salida y permanece inactivo durante
15 segundos para dar tiempo a que los registros estén disponibles. La salida incluye la respuesta de
Lambda y la salida del comando get-log-events.
$ ./get-logs.sh
{
"StatusCode": 200,
"ExecutedVersion": "$LATEST"
}
{
"events": [
{
"timestamp": 1559763003171,
"message": "START RequestId: 4ce9340a-b765-490f-ad8a-02ab3415e2bf Version:
$LATEST\n",
"ingestionTime": 1559763003309
},
{
"timestamp": 1559763003173,
"message": "2019-06-05T19:30:03.173Z\t4ce9340a-b765-490f-ad8a-02ab3415e2bf
\tINFO\tENVIRONMENT VARIABLES\r{\r \"AWS_LAMBDA_FUNCTION_VERSION\": \"$LATEST\",\r ...",
"ingestionTime": 1559763018353
},
{
"timestamp": 1559763003173,
"message": "2019-06-05T19:30:03.173Z\t4ce9340a-b765-490f-ad8a-02ab3415e2bf
\tINFO\tEVENT\r{\r \"key\": \"value\"\r}\n",
"ingestionTime": 1559763018353
},
{
"timestamp": 1559763003218,
"message": "END RequestId: 4ce9340a-b765-490f-ad8a-02ab3415e2bf\n",
"ingestionTime": 1559763018353
},
{
"timestamp": 1559763003218,
"message": "REPORT RequestId: 4ce9340a-b765-490f-ad8a-02ab3415e2bf\tDuration:
26.73 ms\tBilled Duration: 100 ms \tMemory Size: 128 MB\tMax Memory Used: 75 MB\t\n",
"ingestionTime": 1559763018353
}
],
"nextForwardToken": "f/34783877304859518393868359594929986069206639495374241795",
"nextBackwardToken": "b/34783877303811383369537420289090800615709599058929582080"
}
359
AWS Lambda Guía para desarrolladores
Eliminación de registros
Eliminación de registros
Los grupos de registros no se eliminan automáticamente al eliminar una función. Para evitar los registros
de almacenamiento de forma indefinida, elimine el grupo de registros o configure un periodo de retención
después del cual los registros se eliminarán automáticamente.
Biblioteca de registro
Para obtener registros más detallados, utilice la biblioteca de registro.
import os
import logging
logger = logging.getLogger()
logger.setLevel(logging.INFO)
Este código da como resultado un error de nombre. Lambda detecta el error y genera un documento JSON
con campos para el mensaje de error, el tipo y el seguimiento de la pila.
360
AWS Lambda Guía para desarrolladores
Tracing
{
"errorMessage": "name 'x' is not defined",
"errorType": "NameError",
"stackTrace": [
" File \"/var/task/error_function.py\", line 2, in lambda_handler\n return x +
10\n"
]
}
Cuando se invoca la función desde la línea de comandos, la AWS CLI divide la respuesta en dos
documentos. Para indicar que se ha producido un error en la función, la respuesta que se muestra en el
terminal incluye un campo FunctionError. La respuesta o el error que devuelve la función se escribe en
el archivo de salida.
$ cat out.json
{"errorMessage": "name 'x' is not defined", "errorType": "NameError", "stackTrace": ["
File \"/var/task/error_function.py\", line 2, in lambda_handler\n return x + 10\n"]}
Note
El código de estado 200 (correcto) de la respuesta de Lambda indica que no hubo ningún error
en la solicitud que envió a Lambda. Para ver los problemas que generan un código de estado de
error, consulte Errors (p. 589).
Lambda también registra hasta 256 KB del objeto de error en los registros de la función. Para ver los
registros cuando realice la invocación de la función desde la línea de comandos, utilice la opción --log-
type y descodifique la cadena base64 de la respuesta.
Para obtener más información acerca de los registros, consulte Registro de funciones de AWS Lambda en
Python (p. 357).
361
AWS Lambda Guía para desarrolladores
Tracing
Para rastrear solicitudes que no tienen un encabezado de rastreo, habilite el rastreo activo en la
configuración de la función.
Precios
X-Ray tiene una capa gratuita permanente Más allá del umbral de la capa gratuita, X-Ray realiza
cargos por almacenamiento y recuperación del seguimiento. Consulte Precios de AWS X-Ray
para obtener más información.
Su función necesita permiso para cargar datos de rastreo en X-Ray. Cuando habilita el rastreo activo en la
Lambda consola, Lambda agrega los permisos necesarios al rol de ejecución (p. 33) de la función. De lo
contrario, agregue la política AWSXRayDaemonWriteAccess al rol de ejecución.
X-Ray aplica un algoritmo de muestreo para garantizar que el rastreo sea eficiente, al tiempo que
proporciona una muestra representativa de las solicitudes a las que sirve la aplicación. La regla de
muestreo predeterminada es 1 solicitud por segundo y un 5 por ciento de las solicitudes adicionales.
Cuando el rastreo activo está habilitado, Lambda registra el rastreo de un subconjunto de invocaciones.
Lambda registra dos segmentos, lo que crea dos nodos en el mapa de servicio. El primer nodo representa
el servicio de Lambda que recibe la solicitud de invocación. El tiempo de ejecución (p. 19) de la función
registra el segundo nodo.
362
AWS Lambda Guía para desarrolladores
Tracing
Puede instrumentar su código de controlador para registrar metadatos y rastrear llamadas descendentes.
Para registrar detalles sobre las llamadas que su controlador realiza a otros recursos y servicios, use el
SDK de X-Ray para Python. Para obtener el SDK, agregue el paquete aws-xray-sdk a las dependencias
de su aplicación.
Example blank-python/function/requirements.txt
jsonpickle==1.3
aws-xray-sdk==2.4.3
Para instrumentar clientes SDK de AWS, aplique un parche a la biblioteca de boto3 con el módulo
aws_xray_sdk.core.
import boto3
from aws_xray_sdk.core import xray_recorder
from aws_xray_sdk.core import patch_all
logger = logging.getLogger()
logger.setLevel(logging.INFO)
patch_all()
client = boto3.client('lambda')
client.get_account_settings()
En el ejemplo siguiente se muestra un seguimiento con 2 segmentos. Ambos se llaman my-function, pero
uno es tipo AWS::Lambda y el otro es AWS::Lambda::Function. El segmento de función se expande
para mostrar sus subsegmentos.
363
AWS Lambda Guía para desarrolladores
Habilitación del seguimiento activo con la API de Lambda
El primer segmento representa la solicitud de invocación procesada por el servicio Lambda. El segundo
segmento registra el trabajo realizado por la función. El segmento de la función tiene 3 subsegmentos.
También puede instrumentar clientes HTTP, registrar consultas SQL y crear subsegmentos personalizados
con anotaciones y metadatos. Para obtener más información, vea SDK de X-Ray para Python en la Guía
para desarrolladores de AWS X-Ray.
Secciones
• Habilitación del seguimiento activo con la API de Lambda (p. 364)
• Habilitación del seguimiento activo con AWS CloudFormation (p. 365)
• Almacenamiento de dependencias en tiempo de ejecución en una capa (p. 365)
El siguiente comando de la AWS CLI de ejemplo habilita el rastreo activo en una función llamada «my-
function».
364
AWS Lambda Guía para desarrolladores
Habilitación del seguimiento
activo con AWS CloudFormation
El modo de seguimiento forma parte de la configuración específica de la versión, que se bloquea cuando
se publica una versión de la función. No se puede cambiar el modo de seguimiento de una versión
publicada.
Resources:
function:
Type: AWS::Lambda::Function
Properties:
TracingConfig:
Mode: Active
...
Resources:
function:
Type: AWS::Serverless::Function
Properties:
Tracing: Active
...
Resources:
function:
Type: AWS::Serverless::Function
Properties:
CodeUri: function/.
Tracing: Active
Layers:
- !Ref libs
...
libs:
Type: AWS::Serverless::LayerVersion
365
AWS Lambda Guía para desarrolladores
Almacenamiento de dependencias
en tiempo de ejecución en una capa
Properties:
LayerName: blank-python-lib
Description: Dependencies for the blank-python sample app.
ContentUri: package/.
CompatibleRuntimes:
- python3.8
Con esta configuración, solo actualiza la capa de la biblioteca si se modifican las dependencias del tiempo
de ejecución. El paquete de implementación de funciones solo contiene su código. Cuando actualiza el
código de la función, el tiempo de carga es mucho más rápido que si incluye dependencias en el paquete
de implementación.
Para crear una capa de dependencias, es necesario realizar cambios en la compilación para generar el
archivo de capas antes de la implementación. Para ver un ejemplo de trabajo, consulte la aplicación de
ejemplo blank-python.
366
AWS Lambda Guía para desarrolladores
Las funciones de Lambda utilizan un rol de ejecución (p. 33) para obtener permiso para escribir registros
en Amazon CloudWatch Logs y para tener acceso a otros servicios y recursos. Si aún no tiene un rol de
ejecución para el desarrollo de funciones, cree uno.
Puede agregar permisos al rol más tarde o cambiarlo por otro rol específico para una sola función.
367
AWS Lambda Guía para desarrolladores
La consola crea una función de Lambda con un único archivo de origen denominado
lambda_function.rb. Puede editar este archivo y agregar más archivos en el editor de código (p. 7)
integrado. Para guardar los cambios, elija Save. A continuación, para ejecutar el código, elija Test (Probar).
Note
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 más información, consulte Trabajar con funciones de AWS Lambda en la
Guía del usuario de AWS Cloud9.
Cada vez que guarde el código de la función, la consola de Lambda crea un paquete de implementación,
que es un archivo ZIP que contiene el código de su 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 (p. 370) y actualizando el
código en la línea de comandos.
Note
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.
• blank-ruby: una función de Ruby que muestra el uso del registro, las variables de entorno, el
seguimiento de AWS X-Ray, las pruebas de unidad 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 (p. 371) 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.
Temas
• Controlador de funciones de AWS Lambda en Ruby (p. 369)
• Paquete de implementación de AWS Lambda en Ruby (p. 370)
368
AWS Lambda Guía para desarrolladores
Controlador
Example function.rb
require 'json'
También puede definir su método de controlador en una clase. En el siguiente ejemplo se define
un método de controlador llamado process en una clase llamada Handler en un módulo llamado
LambdaFunctions.
Example source.rb
module LambdaFunctions
class Handler
def self.process(event:,context:)
"Hello!"
end
end
end
Los dos objetos que el controlador acepta son el evento de invocación y el contexto. El evento es un
objeto Ruby que contiene la carga que proporciona el invocador. Si la carga es un documento JSON, el
objeto de evento es un hash de Ruby. De lo contrario, es una cadena. Este objeto de contexto (p. 371)
tiene métodos y propiedades que facilitan información acerca de la invocación, la función y el entorno de
ejecución.
El controlador de la función se ejecuta cada vez que se invoca la función de Lambda. El código estático
fuera del controlador se ejecuta una vez por instancia de la función. Si su controlador utiliza recursos como
clientes de SDK y conexiones de bases de datos, puede crearlos fuera del método de controlador para
volver a utilizarlos en varias invocaciones.
Cada instancia de la función permite procesar varios eventos de invocación, pero solo procesa un evento
cada vez. El número de instancias que procesan un evento en un momento dado es la simultaneidad de la
función. Para obtener más información acerca del contexto de ejecución de Lambda, consulte Contexto de
ejecución de AWS Lambda (p. 132).
369
AWS Lambda Guía para desarrolladores
Paquete de implementación
Si utiliza el editor de consola (p. 7) de Lambda para crear la función, la consola administra el paquete de
implementación. Puede utilizar este método siempre y cuando no tenga que añadir ninguna biblioteca.
También puede utilizarlo para actualizar una función que ya tenga bibliotecas en el paquete de
implementación, siempre y cuando el tamaño total no supere el 3 MB.
Note
Para que el tamaño del paquete de implementación sea reducido, empaquete las dependencias
de la función en capas. Las capas le permiten administrar las dependencias de forma
independiente, pueden utilizarlas varias funciones y pueden compartirse con otras cuentas. Para
obtener más información, consulte Capas de AWS Lambda (p. 76).
Secciones
• Actualización de una función sin dependencias (p. 370)
• Actualización de una función con dependencias adicionales (p. 371)
370
AWS Lambda Guía para desarrolladores
Actualización de una función con dependencias adicionales
--path instala las gemas en el directorio del proyecto en lugar de en la ubicación del sistema, y
establece este como la ruta predeterminada para las futuras instalaciones. Para instalar luego gemas
globalmente, utilice la opción --system.
2. Cree un archivo ZIP.
371
AWS Lambda Guía para desarrolladores
Registro
Métodos de context
Propiedades de context
Para generar registros desde el código de su función puede utilizar instrucciones puts o cualquier
biblioteca de registro que escriba en stdout o en stderr. En el siguiente ejemplo, se registran los
valores de las variables de entorno y el objeto de evento.
Example lambda_function.rb
# lambda_function.rb
# lambda_function.rb
require 'logger'
372
AWS Lambda Guía para desarrolladores
Registro
logger.info('## EVENT')
logger.info(event)
event.to_a
end
La consola de Lambda muestra el resultado del registro cuando prueba una función en la página de
configuración de la función. Para ver los registros de todas las invocaciones, utilice la consola de
CloudWatch Logs.
Cada flujo de registro se corresponde con una instancia de su función (p. 132). Los nuevos flujos aparecen
cuando se actualiza la función y cuando se crean más instancias para atendar varias invocaciones
simultáneas. Para buscar los registros de invocaciones específicas, puede instrumentar la función con
X-Ray y registrar los detalles sobre el flujo de registro y la solicitud en el registro de seguimiento. Para
obtener una aplicación de ejemplo que correlacione registros y rastros de seguimiento con X-Ray, consulte
Aplicación de ejemplo de procesamiento de errores para AWS Lambda (p. 323).
Para obtener los registros de una invocación desde la línea de comandos, utilice la opción --log-type.
La respuesta incluye un campo LogResult que contiene hasta 4 KB de registros con codificación base64
a partir de la invocación.
La utilidad base64 está disponible en Linux, MacOS y Ubuntu en Windows. Para el sistema operativo
macOS, el comando es base64 -D.
Los grupos de registros no se eliminan automáticamente al eliminar una función. Para evitar los registros
de almacenamiento de forma indefinida, elimine el grupo de registros o configure un periodo de retención
después del cual los registros se eliminarán automáticamente.
373
AWS Lambda Guía para desarrolladores
Visualización de registros en la
Consola de administración de AWS
El tiempo de ejecución de Ruby registra las líneas START, END y REPORT de cada invocación. La línea del
informe proporciona los siguientes detalles.
Registro de informes
Puede ver los registros en la consola de Lambda o en la de CloudWatch Logs, o bien en la línea de
comandos.
Secciones
• Visualización de registros en la Consola de administración de AWS (p. 358)
• Mediante AWS CLI (p. 358)
• Eliminación de registros (p. 360)
374
AWS Lambda Guía para desarrolladores
Mediante AWS CLI
Cada flujo de registro se corresponde con una instancia de su función (p. 132). Los nuevos flujos aparecen
cuando se actualiza la función y cuando se crean más instancias para atendar varias invocaciones
simultáneas. Para buscar los registros de invocaciones específicas, puede instrumentar la función con
X-Ray y registrar los detalles sobre el flujo de registro y la solicitud en el registro de seguimiento. Para
obtener una aplicación de ejemplo que correlacione registros y rastros de seguimiento con X-Ray, consulte
Aplicación de ejemplo de procesamiento de errores para AWS Lambda (p. 323).
La utilidad base64 está disponible en Linux, MacOS y Ubuntu en Windows. Para el sistema operativo
macOS, el comando es base64 -D.
Para obtener eventos de registro completos desde la línea de comandos, puede incluir el nombre del
flujo de registros en la salida de la función, como se muestra en el ejemplo anterior. El siguiente script de
ejemplo invoca una función denominada my-function y descarga los últimos cinco eventos de registro.
#!/bin/bash
aws lambda invoke --function-name my-function --payload '{"key": "value"}' out
sed -i'' -e 's/"//g' out
sleep 15
aws logs get-log-events --log-group-name /aws/lambda/my-function --log-stream-name $(cat
out) --limit 5
375
AWS Lambda Guía para desarrolladores
Eliminación de registros
El script utiliza sed para eliminar las comillas del archivo de salida y permanece inactivo durante
15 segundos para dar tiempo a que los registros estén disponibles. La salida incluye la respuesta de
Lambda y la salida del comando get-log-events.
$ ./get-logs.sh
{
"StatusCode": 200,
"ExecutedVersion": "$LATEST"
}
{
"events": [
{
"timestamp": 1559763003171,
"message": "START RequestId: 4ce9340a-b765-490f-ad8a-02ab3415e2bf Version:
$LATEST\n",
"ingestionTime": 1559763003309
},
{
"timestamp": 1559763003173,
"message": "2019-06-05T19:30:03.173Z\t4ce9340a-b765-490f-ad8a-02ab3415e2bf
\tINFO\tENVIRONMENT VARIABLES\r{\r \"AWS_LAMBDA_FUNCTION_VERSION\": \"$LATEST\",\r ...",
"ingestionTime": 1559763018353
},
{
"timestamp": 1559763003173,
"message": "2019-06-05T19:30:03.173Z\t4ce9340a-b765-490f-ad8a-02ab3415e2bf
\tINFO\tEVENT\r{\r \"key\": \"value\"\r}\n",
"ingestionTime": 1559763018353
},
{
"timestamp": 1559763003218,
"message": "END RequestId: 4ce9340a-b765-490f-ad8a-02ab3415e2bf\n",
"ingestionTime": 1559763018353
},
{
"timestamp": 1559763003218,
"message": "REPORT RequestId: 4ce9340a-b765-490f-ad8a-02ab3415e2bf\tDuration:
26.73 ms\tBilled Duration: 100 ms \tMemory Size: 128 MB\tMax Memory Used: 75 MB\t\n",
"ingestionTime": 1559763018353
}
],
"nextForwardToken": "f/34783877304859518393868359594929986069206639495374241795",
"nextBackwardToken": "b/34783877303811383369537420289090800615709599058929582080"
}
Eliminación de registros
Los grupos de registros no se eliminan automáticamente al eliminar una función. Para evitar los registros
de almacenamiento de forma indefinida, elimine el grupo de registros o configure un periodo de retención
después del cual los registros se eliminarán automáticamente.
Example function.rb
376
AWS Lambda Guía para desarrolladores
Errores
Este código da como resultado un error de tipo. Lambda detecta el error y genera un documento JSON con
campos para el mensaje de error, el tipo y el seguimiento de la pila.
{
"errorMessage": "no implicit conversion of String into Integer",
"errorType": "Function<TypeError>",
"stackTrace": [
"/var/task/function.rb:3:in `first'",
"/var/task/function.rb:3:in `handler'"
]
}
Cuando se invoca la función desde la línea de comandos, la AWS CLI divide la respuesta en dos
documentos. Para indicar que se ha producido un error en la función, la respuesta que se muestra en el
terminal incluye un campo FunctionError. La respuesta o el error que devuelve la función se escribe en
el archivo de salida.
$ cat out.json
{"errorMessage":"no implicit conversion of String into
Integer","errorType":"Function<TypeError>","stackTrace":["/var/task/function.rb:3:in
`first'","/var/task/function.rb:3:in `handler'"]}
Note
El código de estado 200 (correcto) de la respuesta de Lambda indica que no hubo ningún error
en la solicitud que envió a Lambda. Para ver los problemas que generan un código de estado de
error, consulte Errors (p. 589).
Lambda también registra hasta 256 KB del objeto de error en los registros de la función. Para ver los
registros cuando realice la invocación de la función desde la línea de comandos, utilice la opción --log-
type y descodifique la cadena base64 de la respuesta.
377
AWS Lambda Guía para desarrolladores
Tracing
Para obtener más información acerca de los registros, consulte Registro de funciones de AWS Lambda en
Ruby (p. 372).
En función del origen de eventos, AWS Lambda podría volver a intentar la ejecución de la función de
Lambda que ha generado un error. Por ejemplo, si Kinesis es el origen de eventos, AWS Lambda reintenta
la invocación que produce errores hasta que la función de Lambda se ejecute correctamente o hasta que
los registros del flujo caduquen. Para obtener más información acerca de los reintentos, consulte Control
de errores y reintentos automáticos en AWS Lambda (p. 119).
Para rastrear solicitudes que no tienen un encabezado de rastreo, habilite el rastreo activo en la
configuración de la función.
378
AWS Lambda Guía para desarrolladores
Tracing
Precios
X-Ray tiene una capa gratuita permanente Más allá del umbral de la capa gratuita, X-Ray realiza
cargos por almacenamiento y recuperación del seguimiento. Consulte Precios de AWS X-Ray
para obtener más información.
Su función necesita permiso para cargar datos de rastreo en X-Ray. Cuando habilita el rastreo activo en la
Lambda consola, Lambda agrega los permisos necesarios al rol de ejecución (p. 33) de la función. De lo
contrario, agregue la política AWSXRayDaemonWriteAccess al rol de ejecución.
X-Ray aplica un algoritmo de muestreo para garantizar que el rastreo sea eficiente, al tiempo que
proporciona una muestra representativa de las solicitudes a las que sirve la aplicación. La regla de
muestreo predeterminada es 1 solicitud por segundo y un 5 por ciento de las solicitudes adicionales.
Cuando el rastreo activo está habilitado, Lambda registra el rastreo de un subconjunto de invocaciones.
Lambda registra dos segmentos, lo que crea dos nodos en el mapa de servicio. El primer nodo representa
el servicio de Lambda que recibe la solicitud de invocación. El tiempo de ejecución (p. 19) de la función
registra el segundo nodo.
Puede instrumentar su código de controlador para registrar metadatos y rastrear llamadas descendentes.
Para registrar detalles sobre las llamadas que su controlador realiza a otros recursos y servicios, use el
SDK de X-Ray para Ruby. Para obtener el SDK, agregue el paquete aws-xray-sdk a las dependencias
de su aplicación.
Example blank-ruby/function/Gemfile
# Gemfile
source 'https://rubygems.org'
# lambda_function.rb
require 'logger'
require 'json'
require 'aws-sdk-lambda'
$client = Aws::Lambda::Client.new()
$client.get_account_settings()
379
AWS Lambda Guía para desarrolladores
Habilitación del seguimiento activo con la API de Lambda
require 'aws-xray-sdk/lambda'
En el ejemplo siguiente se muestra un seguimiento con 2 segmentos. Ambos se llaman my-function, pero
uno es tipo AWS::Lambda y el otro es AWS::Lambda::Function. El segmento de función se expande
para mostrar sus subsegmentos.
El primer segmento representa la solicitud de invocación procesada por el servicio Lambda. El segundo
segmento registra el trabajo realizado por la función. El segmento de la función tiene 3 subsegmentos.
También puede instrumentar clientes HTTP, registrar consultas SQL y crear subsegmentos personalizados
con anotaciones y metadatos. Para obtener más información, consulte SDK de X-Ray para Ruby en Guía
para desarrolladores de AWS X-Ray.
Secciones
• Habilitación del seguimiento activo con la API de Lambda (p. 380)
• Habilitación del seguimiento activo con AWS CloudFormation (p. 381)
• Almacenamiento de dependencias en tiempo de ejecución en una capa (p. 381)
380
AWS Lambda Guía para desarrolladores
Habilitación del seguimiento
activo con AWS CloudFormation
El siguiente comando de la AWS CLI de ejemplo habilita el rastreo activo en una función llamada «my-
function».
El modo de seguimiento forma parte de la configuración específica de la versión, que se bloquea cuando
se publica una versión de la función. No se puede cambiar el modo de seguimiento de una versión
publicada.
Resources:
function:
Type: AWS::Lambda::Function
Properties:
TracingConfig:
Mode: Active
...
Resources:
function:
Type: AWS::Serverless::Function
Properties:
Tracing: Active
...
Resources:
function:
Type: AWS::Serverless::Function
381
AWS Lambda Guía para desarrolladores
Almacenamiento de dependencias
en tiempo de ejecución en una capa
Properties:
CodeUri: function/.
Tracing: Active
Layers:
- !Ref libs
...
libs:
Type: AWS::Serverless::LayerVersion
Properties:
LayerName: blank-ruby-lib
Description: Dependencies for the blank-ruby sample app.
ContentUri: lib/.
CompatibleRuntimes:
- ruby2.5
Con esta configuración, solo actualiza la capa de la biblioteca si se modifican las dependencias del tiempo
de ejecución. El paquete de implementación de funciones solo contiene su código. Cuando actualiza el
código de la función, el tiempo de carga es mucho más rápido que si incluye dependencias en el paquete
de implementación.
Para crear una capa de dependencias, es necesario realizar cambios en la compilación para generar el
archivo de capas antes de la implementación. Para ver un ejemplo de trabajo, consulte la aplicación de
ejemplo blank-ruby.
382
AWS Lambda Guía para desarrolladores
Runtimes de Java
Las funciones de Lambda utilizan un rol de ejecución (p. 33) para obtener permiso para escribir registros
en Amazon CloudWatch Logs y para tener acceso a otros servicios y recursos. Si aún no tiene un rol de
ejecución para el desarrollo de funciones, cree uno.
Puede agregar permisos al rol más tarde o cambiarlo por otro rol específico para una sola función.
383
AWS Lambda Guía para desarrolladores
Aplicaciones de ejemplo
La consola crea una función de Lambda con una clase de controlador denominada Hello. Dado que Java
es un lenguaje compilado, no puede ver ni editar el código fuente en la consola de Lambda, pero puede
modificar su configuración, invocarla y configurar disparadores.
Note
Para comenzar con el desarrollo de aplicaciones en su entorno local, implemente una de las
aplicaciones de ejemplo (p. 384) disponibles en el repositorio de GitHub de esta guía.
La clase Hello cuenta con una función denominada handleRequest que toma un objeto de evento
y un objeto context. Esta es la función de controlador (p. 392) a la que llama Lambda cuando se
invoca la función. El tiempo de ejecución de la función de Java 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
example.Hello::handleRequest.
Para actualizar el código de la función, cree un paquete de implementación, que es un archivo 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 (p. 386) y actualizando el código en la línea de
comandos.
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 (p. 396) 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.
Temas
• Aplicaciones de ejemplo de Java para AWS Lambda (p. 384)
• Paquete de implementación de AWS Lambda en Java (p. 386)
• Controlador de funciones de AWS Lambda Java (p. 392)
• Objeto context de AWS Lambda en Java (p. 396)
• Registro de funciones de AWS Lambda en Java (p. 398)
• Errores de la función AWS Lambda en Java (p. 404)
• Instrumentación del código Java en AWS Lambda (p. 409)
• Creación de un paquete de implementación con Eclipse (p. 414)
384
AWS Lambda Guía para desarrolladores
Aplicaciones de ejemplo
• blank-java: función de Java que muestra el uso de bibliotecas de Java de Lambda, el registro, las
variables de entorno, las capas, el seguimiento de AWS X-Ray, las pruebas unitarias y el SDK de AWS.
• java-basic: función de Java mínima con pruebas unitarias y configuración de registro de variables.
• java-events: función de Java mínima que utiliza la biblioteca aws-lambda-java-events (p. 386) con tipos
de eventos que no requieren el SDK de AWS como dependencia, como Amazon API Gateway.
• java-events-v1sdk: función de Java que utiliza la biblioteca aws-lambda-java-events (p. 386) con tipos
de eventos que requieren el SDK de AWS como dependencia (Amazon Simple Storage Service, Amazon
DynamoDB y Amazon Kinesis).
• s3-java: función de Java que procesa los eventos de notificación de Amazon S3 y utiliza Java Class
Library (JCL) para crear miniaturas de los archivos de imagen cargados.
Utilice la aplicación de ejemplo de blank-java para aprender los conceptos básicos o como punto
de partida para su propia aplicación. Muestra el uso de las bibliotecas Java de Lambda, las variables
de entorno, el SDK de AWS y el SDK de AWS X-Ray. Utiliza una capa de Lambda para empaquetar
sus dependencias por separado del código de función, lo que acelera los tiempos de implementación
cuando está iterando en su código de función. El proyecto requiere una configuración mínima y se puede
implementar desde la línea de comandos en menos de un minuto.
385
AWS Lambda Guía para desarrolladores
Paquete de implementación
import com.amazonaws.services.lambda.runtime.events.DynamodbEvent;
import com.amazonaws.services.lambda.runtime.events.DynamodbEvent.DynamodbStreamRecord;
import com.amazonaws.services.dynamodbv2.model.Record;
...
// Handler value: example.HandlerDynamoDB
public class HandlerDynamoDB implements RequestHandler<DynamodbEvent, String>{
private static final Logger logger = LoggerFactory.getLogger(HandlerDynamoDB.class);
Gson gson = new GsonBuilder().setPrettyPrinting().create();
@Override
public String handleRequest(DynamodbEvent event, Context context)
{
String response = new String("200 OK");
for (DynamodbStreamRecord record : event.getRecords()){
logger.info(record.getEventID());
logger.info(record.getEventName());
logger.info(record.getDynamodb().toString());
}
...
Para conocer más detalles, consulte los otros temas de este capítulo.
386
AWS Lambda Guía para desarrolladores
Paquete de implementación
Gradle
dependencies {
implementation 'com.amazonaws:aws-lambda-java-core:1.2.1'
implementation 'com.amazonaws:aws-lambda-java-events:2.2.9'
runtimeOnly 'com.amazonaws:aws-lambda-java-log4j2:1.2.0'
}
Maven
<dependencies>
<dependency>
<groupId>com.amazonaws</groupId>
<artifactId>aws-lambda-java-core</artifactId>
<version>1.2.1</version>
</dependency>
<dependency>
<groupId>com.amazonaws</groupId>
<artifactId>aws-lambda-java-events</artifactId>
<version>2.2.9</version>
</dependency>
<dependency>
<groupId>com.amazonaws</groupId>
<artifactId>aws-lambda-java-log4j2</artifactId>
<version>1.2.0</version>
</dependency>
</dependencies>
Para crear un paquete de implementación, compile el código de función y las dependencias en un único
archivo ZIP o Java Archive (JAR). En el caso de Gradle, use el tipo de compilación Zip (p. 388). En el
caso de Maven, use el complemento Maven Shade (p. 388).
Note
Para que el tamaño del paquete de implementación sea reducido, empaquete las dependencias
de la función en capas. Las capas le permiten administrar las dependencias de forma
independiente, pueden utilizarlas varias funciones y pueden compartirse con otras cuentas. Para
obtener más información, consulte Capas de AWS Lambda (p. 76).
Puede cargar el paquete de implementación a través de la consola de Lambda, la API de Lambda o AWS
SAM.
Secciones
• Compilación de un paquete de implementación con Gradle (p. 388)
• Compilación de un paquete de implementación con Maven (p. 388)
• Carga de un paquete de implementación con la API de Lambda (p. 390)
• Carga de un paquete de implementación con AWS SAM (p. 391)
387
AWS Lambda Guía para desarrolladores
Compilación de un paquete de implementación con Gradle
dependencies {
implementation platform('software.amazon.awssdk:bom:2.10.73')
implementation 'software.amazon.awssdk:lambda'
implementation 'com.amazonaws:aws-lambda-java-core:1.2.1'
implementation 'com.amazonaws:aws-lambda-java-events:2.2.9'
implementation 'com.google.code.gson:gson:2.8.6'
implementation 'org.apache.logging.log4j:log4j-api:2.13.0'
implementation 'org.apache.logging.log4j:log4j-core:2.13.0'
runtimeOnly 'org.apache.logging.log4j:log4j-slf4j18-impl:2.13.0'
runtimeOnly 'com.amazonaws:aws-lambda-java-log4j2:1.2.0'
testImplementation 'org.junit.jupiter:junit-jupiter-api:5.6.0'
testRuntimeOnly 'org.junit.jupiter:junit-jupiter-engine:5.6.0'
}
Lambda carga los archivos JAR en orden alfabético Unicode. Si hay varios archivos JAR en la carpeta lib
que contienen la misma clase, se utiliza el primero. Puede utilizar el siguiente script de shell para identificar
las clases duplicadas.
Example test-zip.sh
mkdir -p expanded
unzip path/to/my/function.zip -d expanded
find ./expanded/lib -name '*.jar' | xargs -n1 zipinfo -1 | grep '.*.class' | sort | uniq -c
| sort
<plugin>
388
AWS Lambda Guía para desarrolladores
Compilación de un paquete de implementación con Maven
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-shade-plugin</artifactId>
<version>3.2.2</version>
<configuration>
<createDependencyReducedPom>false</createDependencyReducedPom>
</configuration>
<executions>
<execution>
<phase>package</phase>
<goals>
<goal>shade</goal>
</goals>
</execution>
</executions>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-shade-plugin</artifactId>
<version>3.2.2</version>
<configuration>
<createDependencyReducedPom>false</createDependencyReducedPom>
</configuration>
<executions>
<execution>
<phase>package</phase>
<goals>
<goal>shade</goal>
</goals>
<configuration>
389
AWS Lambda Guía para desarrolladores
Carga de un paquete de
implementación con la API de Lambda
<transformers>
<transformer
implementation="com.github.edwgiz.maven_shade_plugin.log4j2_cache_transformer.PluginsCacheFileTransfor
</transformer>
</transformers>
</configuration>
</execution>
</executions>
<dependencies>
<dependency>
<groupId>com.github.edwgiz</groupId>
<artifactId>maven-shade-plugin.log4j2-cachefile-transformer</artifactId>
<version>2.13.0</version>
</dependency>
</dependencies>
</plugin>
390
AWS Lambda Guía para desarrolladores
Carga de un paquete de implementación con AWS SAM
"Mode": "Active"
},
"RevisionId": "983ed1e3-ca8e-434b-8dc1-7d72ebadd83d",
...
}
Puede utilizar este método para cargar paquetes de funciones hasta alcanzar 250 MB (descomprimidos).
Example template.yml
AWSTemplateFormatVersion: '2010-09-09'
Transform: 'AWS::Serverless-2016-10-31'
Description: An AWS Lambda application that calls the Lambda API.
Resources:
function:
Type: AWS::Serverless::Function
Properties:
CodeUri: build/distributions/java-basic.zip
Handler: example.Handler
Runtime: java8
Description: Java function
MemorySize: 512
Timeout: 10
# Function's execution role
Policies:
- AWSLambdaBasicExecutionRole
- AWSLambdaReadOnlyAccess
- AWSXrayWriteOnlyAccess
- AWSLambdaVPCAccessExecutionRole
Tracing: Active
Para crear la función, utilice los comandos package y deploy. Estos comandos son personalizaciones de
la CLI de AWS. Contienen otros comandos que van a cargar el paquete de implementación en Amazon S3,
reescribir la plantilla con el URI del objeto y actualizar el código de la función.
El siguiente script de ejemplo ejecuta una compilación de Gradle y carga el paquete de implementación
que crea. Crea una pila de AWS CloudFormation la primera vez que la ejecuta. Si la pila ya existe, el script
la actualiza.
Example deploy.sh
#!/bin/bash
set -eo pipefail
aws cloudformation package --template-file template.yml --s3-bucket MY_BUCKET --output-
template-file out.yml
aws cloudformation deploy --template-file out.yml --stack-name java-basic --capabilities
CAPABILITY_NAMED_IAM
391
AWS Lambda Guía para desarrolladores
Controlador
• blank-java: función de Java que muestra el uso de bibliotecas de Java de Lambda, el registro, las
variables de entorno, las capas, el seguimiento de AWS X-Ray, las pruebas unitarias y el SDK de AWS.
• java-basic: función de Java mínima con pruebas unitarias y configuración de registro de variables.
• java-events: función de Java mínima que utiliza la biblioteca aws-lambda-java-events (p. 386) con tipos
de eventos que no requieren el SDK de AWS como dependencia, como Amazon API Gateway.
• java-events-v1sdk: función de Java que utiliza la biblioteca aws-lambda-java-events (p. 386) con tipos
de eventos que requieren el SDK de AWS como dependencia (Amazon Simple Storage Service, Amazon
DynamoDB y Amazon Kinesis).
• s3-java: función de Java que procesa los eventos de notificación de Amazon S3 y utiliza Java Class
Library (JCL) para crear miniaturas de los archivos de imagen cargados.
Example Handler.java
package example;
import com.amazonaws.services.lambda.runtime.Context
import com.amazonaws.services.lambda.runtime.RequestHandler
import com.amazonaws.services.lambda.runtime.LambdaLogger
...
El entorno de ejecución de Lambda (p. 130) recibe un evento como una cadena con formato JSON y lo
convierte en un objeto. Pasa el objeto del evento al controlador de la función junto con un objeto contextual
que proporciona detalles sobre la invocación y la función. Es usted quien debe decirle al entorno de
ejecución qué método va a invocar estableciendo el parámetro del controlador en la configuración de la
función.
Formatos de controlador
392
AWS Lambda Guía para desarrolladores
Elección de los tipos de entrada y salida
• package.Class: formato abreviado para las funciones que implementan una interfaz de
controlador (p. 394). Por ejemplo: example.Handler.
Puede agregar un código de inicialización (p. 20) fuera del método del controlador para reutilizar los
recursos en diferentes invocaciones. Cuando el entorno de ejecución carga el controlador, ejecuta código
estático y el constructor de clases. Los recursos que se crean durante la inicialización permanecen en la
memoria entre las invocaciones y el controlador puede reutilizarlos miles de veces.
En el siguiente ejemplo, el registrador, el serializador y el cliente del SDK de AWS se crean cuando la
función sirve su primer evento. Los eventos que esta misma instancia de la función sirve posteriormente
son mucho más rápidos porque esos recursos ya existen.
El repositorio de GitHub para esta guía contiene aplicaciones de ejemplo fáciles de implementar en las
que se muestran diferentes tipos de controladores. Para obtener más información, consulte el final de este
tema (p. 395).
Secciones
• Elección de los tipos de entrada y salida (p. 393)
• Interfaces de controlador (p. 394)
• Ejemplo de código del controlador (p. 395)
{
"temperatureK": 281,
"windKmh": -3,
"humidityPct": 0.55,
"pressureHPa": 1020
}
393
AWS Lambda Guía para desarrolladores
Interfaces de controlador
Sin embargo, el valor de cada campo debe ser una cadena o un número. Si el evento contiene un campo
que tiene un objeto como valor, el entorno de ejecución no puede deserializarlo y devuelve un error.
Elija un tipo de entrada que funcione con los datos del evento que procesa la función. Puede utilizar un tipo
básico, un tipo genérico o un tipo bien definido.
Tipos de entrada
• Integer, Long, Double, etc.: el evento es un número sin formato adicional; por ejemplo, 3.5. El
entorno de ejecución convierte el valor en un objeto del tipo especificado.
• String: el evento es una cadena JSON, incluidas las comillas; por ejemplo, "My string.". El tiempo
de ejecución convierte el valor (sin comillas) en un objeto String.
• Type, Map<String,Type>, etc.: el evento es un objeto JSON. El entorno de ejecución lo deserializa en
un objeto del tipo especificado o una interfaz.
• List<Integer>, List<String>, List<Object>, etc.: el evento es una matriz JSON. El entorno de
ejecución lo deserializa en un objeto del tipo especificado o una interfaz.
• InputStream: el evento es cualquier tipo JSON. El entorno de ejecución pasa una secuencia de bytes
del documento al controlador sin modificaciones. Usted deserializa la entrada y escribe la salida en una
secuencia de salida.
• Tipo de biblioteca: en el caso de los eventos enviados por los servicios de AWS, utilice los tipos de la
biblioteca aws-lambda-java-events (p. 386).
Si define su propio tipo de entrada, debería ser un objeto Java estándar (POJO) mutable y deserializable,
con un constructor predeterminado y unas propiedades predeterminadas para cada campo del evento. Las
claves del evento que no se asignan a una propiedad, así como las propiedades que no están incluidas en
el evento, se eliminan sin errores.
El tipo de salida puede ser un objeto o void. El entorno de ejecución serializa los valores devueltos en
texto. Si la salida es un objeto con campos, el entorno de ejecución lo serializa en un documento JSON. Si
se trata de un tipo que encapsula un valor primitivo, el tiempo de ejecución devuelve una representación de
texto de ese valor.
Interfaces de controlador
La biblioteca aws-lambda-java-core define dos interfaces para los métodos de controlador. Utilice las
interfaces proporcionadas para simplificar la configuración del controlador y validar la firma del método del
controlador en tiempo de compilación.
• com.amazonaws.services.lambda.runtime.RequestHandler
• com.amazonaws.services.lambda.runtime.RequestStreamHandler
La interfaz RequestHandler es un tipo genérico que toma dos parámetros: el tipo de entrada y el tipo de
salida. Los dos tipos deben ser objetos. Cuando se utiliza esta interfaz, el entorno de ejecución de Java
deserializa el evento en un objeto con el tipo de entrada y serializa la salida en texto. Utilice esta interfaz si
la serialización integrada funcione con los tipos de entrada y salida.
394
AWS Lambda Guía para desarrolladores
Ejemplo de código del controlador
Para usar su propia serialización, implemente la interfaz RequestStreamHandler. Con esta interfaz,
Lambda pasa al controlador una secuencia de entrada y otra secuencia de salida. El controlador lee los
bytes de la secuencia de entrada, escribe en la secuencia de salida y devuelve void.
En el ejemplo siguiente se utilizan unos tipos de lectores y escritores almacenados en el búfer para trabajar
con las secuencias de entrada y salida. Utiliza la biblioteca Gson para la serialización y la deserialización.
Example HandlerStream.java
import com.amazonaws.services.lambda.runtime.Context
import com.amazonaws.services.lambda.runtime.RequestStreamHandler
import com.amazonaws.services.lambda.runtime.LambdaLogger
...
// Handler value: example.HandlerStream
public class HandlerStream implements RequestStreamHandler {
Gson gson = new GsonBuilder().setPrettyPrinting().create();
@Override
public void handleRequest(InputStream inputStream, OutputStream outputStream, Context
context) throws IOException
{
LambdaLogger logger = context.getLogger();
BufferedReader reader = new BufferedReader(new InputStreamReader(inputStream,
Charset.forName("US-ASCII")));
PrintWriter writer = new PrintWriter(new BufferedWriter(new
OutputStreamWriter(outputStream, Charset.forName("US-ASCII"))));
try
{
HashMap event = gson.fromJson(reader, HashMap.class);
logger.log("STREAM TYPE: " + inputStream.getClass().toString());
logger.log("EVENT TYPE: " + event.getClass().toString());
writer.write(gson.toJson(event));
if (writer.checkError())
{
logger.log("WARNING: Writer encountered an error.");
}
}
catch (IllegalStateException | JsonSyntaxException exception)
{
logger.log(exception.toString());
}
finally
{
reader.close();
writer.close();
}
}
}
• blank-java: función de Java que muestra el uso de bibliotecas de Java de Lambda, el registro, las
variables de entorno, las capas, el seguimiento de AWS X-Ray, las pruebas unitarias y el SDK de AWS.
• java-basic: función de Java mínima con pruebas unitarias y configuración de registro de variables.
• java-events: función de Java mínima que utiliza la biblioteca aws-lambda-java-events (p. 386) con tipos
de eventos que no requieren el SDK de AWS como dependencia, como Amazon API Gateway.
395
AWS Lambda Guía para desarrolladores
Contexto
• java-events-v1sdk: función de Java que utiliza la biblioteca aws-lambda-java-events (p. 386) con tipos
de eventos que requieren el SDK de AWS como dependencia (Amazon Simple Storage Service, Amazon
DynamoDB y Amazon Kinesis).
• s3-java: función de Java que procesa los eventos de notificación de Amazon S3 y utiliza Java Class
Library (JCL) para crear miniaturas de los archivos de imagen cargados.
Las aplicaciones blank-java y s3-java toman un evento de un servicio de AWS como entrada y
devuelven una cadena. La aplicación java-basic contiene varios tipos de controladores:
Para probar diferentes tipos de controlador, solo tiene que cambiar el valor del controlador en la plantilla de
AWS SAM. Para obtener instrucciones detalladas, consulte el archivo readme (léame) de la aplicación de
ejemplo.
Métodos de context
En el ejemplo siguiente, se muestra una función que utiliza el objeto contextual para acceder al registrador
de Lambda.
Example Handler.java
package example;
396
AWS Lambda Guía para desarrolladores
Contexto
import com.amazonaws.services.lambda.runtime.Context
import com.amazonaws.services.lambda.runtime.RequestHandler
import com.amazonaws.services.lambda.runtime.LambdaLogger
...
La interfaz del objeto contextual está disponible en la biblioteca aws-lambda-java-core. Puede implementar
esta interfaz para crear una clase contextual para las pruebas. En el ejemplo siguiente, se muestra una
clase contextual que devuelve valores ficticios para la mayoría de las propiedades y un registrador de
pruebas en funcionamiento.
Example src/test/java/example/TestContext.java
package example;
import com.amazonaws.services.lambda.runtime.Context;
import com.amazonaws.services.lambda.runtime.CognitoIdentity;
import com.amazonaws.services.lambda.runtime.ClientContext;
import com.amazonaws.services.lambda.runtime.LambdaLogger
397
AWS Lambda Guía para desarrolladores
Contexto en aplicaciones de ejemplo
}
...
public LambdaLogger getLogger(){
return new TestLogger();
}
Para obtener más información sobre los registros, consulte Registro de funciones de AWS Lambda en
Java (p. 398).
• blank-java: función de Java que muestra el uso de bibliotecas de Java de Lambda, el registro, las
variables de entorno, las capas, el seguimiento de AWS X-Ray, las pruebas unitarias y el SDK de AWS.
• java-basic: función de Java mínima con pruebas unitarias y configuración de registro de variables.
• java-events: función de Java mínima que utiliza la biblioteca aws-lambda-java-events (p. 386) con tipos
de eventos que no requieren el SDK de AWS como dependencia, como Amazon API Gateway.
• java-events-v1sdk: función de Java que utiliza la biblioteca aws-lambda-java-events (p. 386) con tipos
de eventos que requieren el SDK de AWS como dependencia (Amazon Simple Storage Service, Amazon
DynamoDB y Amazon Kinesis).
• s3-java: función de Java que procesa los eventos de notificación de Amazon S3 y utiliza Java Class
Library (JCL) para crear miniaturas de los archivos de imagen cargados.
Todas las aplicaciones de ejemplo tienen una clase de contextual para las pruebas unitarias. La aplicación
java-basic muestra como utilizar el objeto contextual para obtener un registrador. Utiliza SLF4J y Log4J
2 para proporcionar un registrador que funcione con pruebas unitarias locales.
Para generar registros desde el código de función, puede utilizar los métodos de java.lang.System o
cualquier módulo de registro que escriba en stdout o en stderr. La biblioteca aws-lambda-java-
core (p. 386) tiene una clase de registrador llamada LambdaLogger a la que se puede acceder desde el
objeto contextual. La clase de registrador admite registros multilínea.
Example Handler.java
398
AWS Lambda Guía para desarrolladores
Registro
{
LambdaLogger logger = context.getLogger();
String response = new String("SUCCESS");
// log execution details
logger.log("ENVIRONMENT VARIABLES: " + gson.toJson(System.getenv()));
logger.log("CONTEXT: " + gson.toJson(context));
// process event
logger.log("EVENT: " + gson.toJson(event));
return response;
}
}
El tiempo de ejecución de Java registra las líneas START, END y REPORT de cada invocación. La línea del
informe proporciona los siguientes detalles:
Registro de informes
399
AWS Lambda Guía para desarrolladores
Visualización de registros en la
Consola de administración de AWS
Puede ver los registros en la consola de Lambda o en la de CloudWatch Logs, o bien en la línea de
comandos.
Secciones
• Visualización de registros en la Consola de administración de AWS (p. 400)
• Mediante AWS CLI (p. 400)
• Eliminación de registros (p. 402)
• Registro avanzado con Log4j 2 y SLF4J (p. 402)
• Código de registro de ejemplo (p. 404)
Cada flujo de registro se corresponde con una instancia de su función (p. 132). Los nuevos flujos aparecen
cuando se actualiza la función y cuando se crean más instancias para atendar varias invocaciones
simultáneas. Para buscar los registros de invocaciones específicas, puede instrumentar la función con
X-Ray y registrar los detalles sobre el flujo de registro y la solicitud en el registro de seguimiento. Para
obtener una aplicación de ejemplo que correlacione registros y rastros de seguimiento con X-Ray, consulte
Aplicación de ejemplo de procesamiento de errores para AWS Lambda (p. 323).
400
AWS Lambda Guía para desarrolladores
Mediante AWS CLI
La utilidad base64 está disponible en Linux, MacOS y Ubuntu en Windows. Para el sistema operativo
macOS, el comando es base64 -D.
Para obtener eventos de registro completos desde la línea de comandos, puede incluir el nombre del
flujo de registros en la salida de la función, como se muestra en el ejemplo anterior. El siguiente script de
ejemplo invoca una función denominada my-function y descarga los últimos cinco eventos de registro.
#!/bin/bash
aws lambda invoke --function-name my-function --payload '{"key": "value"}' out
sed -i'' -e 's/"//g' out
sleep 15
aws logs get-log-events --log-group-name /aws/lambda/my-function --log-stream-name $(cat
out) --limit 5
El script utiliza sed para eliminar las comillas del archivo de salida y permanece inactivo durante
15 segundos para dar tiempo a que los registros estén disponibles. La salida incluye la respuesta de
Lambda y la salida del comando get-log-events.
$ ./get-logs.sh
{
"StatusCode": 200,
"ExecutedVersion": "$LATEST"
}
{
"events": [
{
"timestamp": 1559763003171,
"message": "START RequestId: 4ce9340a-b765-490f-ad8a-02ab3415e2bf Version:
$LATEST\n",
"ingestionTime": 1559763003309
},
{
"timestamp": 1559763003173,
"message": "2019-06-05T19:30:03.173Z\t4ce9340a-b765-490f-ad8a-02ab3415e2bf
\tINFO\tENVIRONMENT VARIABLES\r{\r \"AWS_LAMBDA_FUNCTION_VERSION\": \"$LATEST\",\r ...",
"ingestionTime": 1559763018353
},
{
"timestamp": 1559763003173,
"message": "2019-06-05T19:30:03.173Z\t4ce9340a-b765-490f-ad8a-02ab3415e2bf
\tINFO\tEVENT\r{\r \"key\": \"value\"\r}\n",
"ingestionTime": 1559763018353
},
{
"timestamp": 1559763003218,
"message": "END RequestId: 4ce9340a-b765-490f-ad8a-02ab3415e2bf\n",
"ingestionTime": 1559763018353
},
{
"timestamp": 1559763003218,
"message": "REPORT RequestId: 4ce9340a-b765-490f-ad8a-02ab3415e2bf\tDuration:
26.73 ms\tBilled Duration: 100 ms \tMemory Size: 128 MB\tMax Memory Used: 75 MB\t\n",
401
AWS Lambda Guía para desarrolladores
Eliminación de registros
"ingestionTime": 1559763018353
}
],
"nextForwardToken": "f/34783877304859518393868359594929986069206639495374241795",
"nextBackwardToken": "b/34783877303811383369537420289090800615709599058929582080"
}
Eliminación de registros
Los grupos de registros no se eliminan automáticamente al eliminar una función. Para evitar los registros
de almacenamiento de forma indefinida, elimine el grupo de registros o configure un periodo de retención
después del cual los registros se eliminarán automáticamente.
Para agregar el ID de la solicitud a los registros de la función, use el appender de la biblioteca aws-lambda-
java-log4j2 (p. 386). En el ejemplo siguiente, se muestra un archivo de configuración de Log4j 2 que
agrega una marca temporal y un ID de solicitud a todos los registros.
<Configuration status="WARN">
<Appenders>
<Lambda name="Lambda">
<PatternLayout>
<pattern>%d{yyyy-MM-dd HH:mm:ss} %X{AWSRequestId} %-5p %c{1} - %m%n</pattern>
</PatternLayout>
</Lambda>
</Appenders>
<Loggers>
<Root level="INFO">
<AppenderRef ref="Lambda"/>
</Root>
<Logger name="software.amazon.awssdk" level="WARN" />
<Logger name="software.amazon.awssdk.request" level="DEBUG" />
</Loggers>
</Configuration>
Con esta configuración, en cada línea se antepone la fecha, la hora, el ID de solicitud, el nivel de registro y
el nombre de clase.
402
AWS Lambda Guía para desarrolladores
Registro avanzado con Log4j 2 y SLF4J
{
"memoryLimit": 512,
"awsRequestId": "6bc28136-xmpl-4365-b021-0ce6b2e64ab0",
"functionName": "java-console",
...
}
SLF4J es una biblioteca de fachadas para los registros de código Java. En el código de la función,
se utiliza la fábrica del registrador de SLF4J para recuperar un registrador con métodos para niveles
de registro como info() y warn(). En la configuración de compilación, puede incluir la biblioteca
de registros y el adaptador de SLF4J en el classpath. Si cambia las bibliotecas en la configuración de
compilación, puede cambiar el tipo de registrador sin necesidad de modificar el código de la función. Es
necesario utilizar SLF4J para capturar registros de SDK para Java.
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
La configuración de compilación toma dependencias del entorno de ejecución del appender de Lambda y
del adaptador de SLF4J, y dependencias de implementación de Log4J 2.
dependencies {
implementation platform('software.amazon.awssdk:bom:2.10.73')
implementation platform('com.amazonaws:aws-xray-recorder-sdk-bom:2.4.0')
implementation 'software.amazon.awssdk:lambda'
implementation 'com.amazonaws:aws-xray-recorder-sdk-core'
implementation 'com.amazonaws:aws-xray-recorder-sdk-aws-sdk-core'
implementation 'com.amazonaws:aws-xray-recorder-sdk-aws-sdk-v2'
implementation 'com.amazonaws:aws-xray-recorder-sdk-aws-sdk-v2-instrumentor'
implementation 'com.amazonaws:aws-lambda-java-core:1.2.1'
implementation 'com.amazonaws:aws-lambda-java-events:2.2.9'
implementation 'com.google.code.gson:gson:2.8.6'
implementation 'org.apache.logging.log4j:log4j-api:2.13.0'
implementation 'org.apache.logging.log4j:log4j-core:2.13.0'
runtimeOnly 'org.apache.logging.log4j:log4j-slf4j18-impl:2.13.0'
runtimeOnly 'com.amazonaws:aws-lambda-java-log4j2:1.2.0'
testImplementation 'org.junit.jupiter:junit-jupiter-api:5.6.0'
testRuntimeOnly 'org.junit.jupiter:junit-jupiter-engine:5.6.0'
}
403
AWS Lambda Guía para desarrolladores
Código de registro de ejemplo
Cuando ejecuta el código localmente para realizar pruebas, el objeto contextual con el registrador de
Lambda no está disponible y no hay ningún ID de solicitud que el appender de Lambda pueda utilizar. Para
ver ejemplos de configuraciones de prueba, consulte las aplicaciones de la siguiente sección.
• blank-java: función de Java que muestra el uso de bibliotecas de Java de Lambda, el registro, las
variables de entorno, las capas, el seguimiento de AWS X-Ray, las pruebas unitarias y el SDK de AWS.
• java-basic: función de Java mínima con pruebas unitarias y configuración de registro de variables.
• java-events: función de Java mínima que utiliza la biblioteca aws-lambda-java-events (p. 386) con tipos
de eventos que no requieren el SDK de AWS como dependencia, como Amazon API Gateway.
• java-events-v1sdk: función de Java que utiliza la biblioteca aws-lambda-java-events (p. 386) con tipos
de eventos que requieren el SDK de AWS como dependencia (Amazon Simple Storage Service, Amazon
DynamoDB y Amazon Kinesis).
• s3-java: función de Java que procesa los eventos de notificación de Amazon S3 y utiliza Java Class
Library (JCL) para crear miniaturas de los archivos de imagen cargados.
En la aplicación de ejemplo java-basic, se muestra una configuración de registro mínima que admite
pruebas de registro. El código del controlador utiliza el registrador de LambdaLogger proporcionado por
el objeto contextual. En el caso de las pruebas, la aplicación utiliza una clase TestLogger personalizada
que implementa la interfaz LambdaLogger con un registrador de Log4j 2. SLF4J se utiliza como fachada
para garantizar la compatibilidad con el SDK de AWS. Las bibliotecas de registro se excluyen de la salida
de compilación para mantener un tamaño de paquete de implementación pequeño.
La aplicación de ejemplo blank-java utiliza la configuración básica con los registros del SDK de AWS
y el appender de Log4j 2 de Lambda. Log4j 2 se utiliza en Lambda con un appender personalizado que
agrega el ID de solicitud de invocación a cada línea.
import java.util.List;
404
AWS Lambda Guía para desarrolladores
Ver la salida de errores
{
throw new InputLengthException("Input must be an array that contains 2 numbers.");
}
int numerator = event.get(0);
int denominator = event.get(1);
logger.log("EVENT: " + gson.toJson(event));
logger.log("EVENT TYPE: " + event.getClass().toString());
return numerator/denominator;
}
}
{
"errorMessage":"Input must contain 2 numbers.",
"errorType":"java.lang.InputLengthException",
"stackTrace": [
"example.HandlerDivide.handleRequest(HandlerDivide.java:23)",
"example.HandlerDivide.handleRequest(HandlerDivide.java:14)"
]
}
La instrucción return del ejemplo anterior también puede generar una excepción en tiempo de ejecución.
return numerator/denominator;
{"errorMessage":"/ by zero","errorType":"java.lang.ArithmeticException","stackTrace":
["example.HandlerDivide.handleRequest(HandlerDivide.java:28)","example.HandlerDivide.handleRequest(Hand
Secciones
• Ver la salida de errores (p. 405)
• Descripción de los tipos y orígenes de errores (p. 407)
• Administración de errores en los clientes (p. 408)
• Administración de errores en otros servicios de AWS (p. 408)
• Administración de errores en aplicaciones de ejemplo (p. 409)
Para ver la salida de errores en la consola de Lambda, invóquela con un evento de prueba.
405
AWS Lambda Guía para desarrolladores
Ver la salida de errores
4. Elija una plantilla de evento que se ajuste a los eventos que procesa su función.
5. Asigne un nombre al evento de prueba y modifique la estructura de eventos según sea necesario.
6. Seleccione Create (Crear).
7. Elija Test.
La consola de Lambda invoca la función de forma sincrónica (p. 100) y muestra el resultado. Para ver la
respuesta, los registros y otra información, expanda la sección Details (Detalles).
Cuando se invoca la función desde la línea de comandos, la AWS CLI divide la respuesta en dos
documentos. Para indicar que se ha producido un error en la función, la respuesta que se muestra en el
terminal incluye un campo FunctionError. La respuesta o el error que devuelve la función se escribe en
el archivo de salida.
$ cat out.json
{"errorMessage":"Input must contain 2
numbers.","errorType":"java.lang.InputLengthException","stackTrace":
["example.HandlerDivide.handleRequest(HandlerDivide.java:23)","example.HandlerDivide.handleRequest(Han
Lambda también registra hasta 256 KB del objeto de error en los registros de la función. Para ver los
registros cuando realice la invocación de la función desde la línea de comandos, utilice la opción --log-
type y descodifique la cadena base64 de la respuesta.
406
AWS Lambda Guía para desarrolladores
Descripción de los tipos y orígenes de errores
Para obtener más información acerca de los registros, consulte Registro de funciones de AWS Lambda en
Java (p. 398).
El servicio Lambda recibe la solicitud de invocación y la valida. Comprueba los permisos, que el
documento del evento es un documento JSON válido y los valores de los parámetros. Si el servicio
Lambda encuentra algún error, devuelve un tipo de excepción, mensaje y código de estado HTTP que
indican la causa del error.
Note
Para ver una lista completa de los errores que puede devolver la operación Invoke de la API,
consulte los errores de Invoke (p. 589) en la referencia de la API de Lambda.
Los errores de la serie 4xx del servicio Lambda indican que se trata de un error que el invocador puede
corregir modificando la solicitud, solicitando permiso o intentándolo de nuevo. Los errores de la serie 5xx
indican un problema con el ser Lambda o un problema con la configuración o los recursos de la función.
Estos problemas no puede solucionarlos el invocador, pero el propietario de la función podría corregirlos.
Si una solicitud pasa la validación, Lambda la envía a una instancia de la función. El entorno de ejecución
convierte el documento del evento en un objeto y se lo pasa al código del controlador. Durante este
proceso, pueden producirse errores si, por ejemplo, el nombre del método del controlador no coincide con
la configuración de la función o si el tiempo de espera de la invocación se agotó antes de que el código del
controlador devolviera una respuesta. Los errores de tiempo de ejecución de Lambda tienen un formato
similar a los errores que devuelve el código, pero los devuelve el tiempo de ejecución.
{
"errorMessage": "An error occurred during JSON parsing",
"errorType": "java.lang.RuntimeException",
"stackTrace": [],
"cause": {
"errorMessage": "com.fasterxml.jackson.databind.exc.InvalidFormatException: Can not
construct instance of java.lang.Integer from String value '1000,10': not a valid Integer
value\n at [Source: lambdainternal.util.NativeMemoryAsInputStream@35fc6dc4; line: 1,
column: 1] (through reference chain: java.lang.Object[0])",
"errorType": "java.io.UncheckedIOException",
"stackTrace": [],
"cause": {
"errorMessage": "Can not construct instance of java.lang.Integer
from String value '1000,10': not a valid Integer value\n at [Source:
lambdainternal.util.NativeMemoryAsInputStream@35fc6dc4; line: 1, column: 1] (through
reference chain: java.lang.Object[0])",
"errorType": "com.fasterxml.jackson.databind.exc.InvalidFormatException",
"stackTrace": [
"com.fasterxml.jackson.databind.exc.InvalidFormatException.from(InvalidFormatException.java:55)",
"com.fasterxml.jackson.databind.DeserializationContext.weirdStringException(DeserializationContext.jav
...
]
407
AWS Lambda Guía para desarrolladores
Administración de errores en los clientes
}
}
}
En los errores del entorno de ejecución de Lambda y en otros errores de la función, el servicio Lambda
no devuelve ningún código de error. Un código de estado de la serie 2xx indica que el servicio Lambda
aceptó la solicitud. En lugar de un código de error, Lambda indica el error incluyendo el encabezado X-
Amz-Function-Error en la respuesta.
En las invocaciones asíncronas, los eventos se ponen en cola antes de que Lambda los envíe a la
función. En las solicitudes válidas, Lambda devuelve una respuesta correcta inmediatamente y agrega el
evento a la cola. Después, Lambda lee los eventos de la cola e invoca la función. Si se produce un error,
Lambda vuelve a intentarlo con un comportamiento que variará según el tipo de error. Para obtener más
información, consulte Invocación asincrónica (p. 101).
En otros errores de invocación, el comportamiento correcto dependerá del código de respuesta. La serie
5xx pueden indicar una condición temporal que puede resolverse sin que el usuario tenga que hacer nada.
Volver a intentarlo podría funcionar o no. Los errores de la serie 4xx que no son 429 suelen indicar un
error con la solicitud. No es probable que volver a intentarlo funcione.
En los errores de la función, el cliente puede procesar el documento de error y mostrar el mensaje de error
en un formato sencillo. Una aplicación basada en navegador podría mostrar el mensaje y el tipo de error,
pero omitir el seguimiento de la pila. La CLI de AWS guarda el objeto de error en el archivo de salida y
muestra en su lugar un documento generado a partir de los encabezados de respuesta.
Example out.json
408
AWS Lambda Guía para desarrolladores
Administración de errores en aplicaciones de ejemplo
usuario. Algunos servicios invocan funciones de forma asíncrona y permiten que Lambda administre los
errores, mientras que otros vuelven a intentarlo o pasan los errores al usuario.
Por ejemplo, API Gateway trata todos los errores de invocación y función como errores internos. Si la API
de Lambda rechaza la solicitud de invocación, API Gateway devuelve un código de error 500. Si la función
se ejecuta pero devuelve un error o devuelve una respuesta con un formato incorrecto, API Gateway
muestra un código de error 502. Para personalizar la respuesta del error, debe detectar errores en el
código y elaborar una respuesta en el formato que desee.
Para determinar el origen de un error y su causa, use AWS X-Ray. Con X-Ray, puede saber en qué
componente se produjo un error y ver los detalles sobre las excepciones. En el ejemplo siguiente, se
muestra un error de una función que generó una respuesta 502 de API Gateway.
Para empezar a utilizar X-Ray, habilite el seguimiento activo (p. 409) en las funciones.
Para obtener información detallada sobre otros errores del controlador de servicios, consulte los temas del
capítulo Utilización de AWS Lambda con otros servicios (p. 163).
• blank-java: función de Java que muestra el uso de bibliotecas de Java de Lambda, el registro, las
variables de entorno, las capas, el seguimiento de AWS X-Ray, las pruebas unitarias y el SDK de AWS.
• java-basic: función de Java mínima con pruebas unitarias y configuración de registro de variables.
• java-events: función de Java mínima que utiliza la biblioteca aws-lambda-java-events (p. 386) con tipos
de eventos que no requieren el SDK de AWS como dependencia, como Amazon API Gateway.
• java-events-v1sdk: función de Java que utiliza la biblioteca aws-lambda-java-events (p. 386) con tipos
de eventos que requieren el SDK de AWS como dependencia (Amazon Simple Storage Service, Amazon
DynamoDB y Amazon Kinesis).
• s3-java: función de Java que procesa los eventos de notificación de Amazon S3 y utiliza Java Class
Library (JCL) para crear miniaturas de los archivos de imagen cargados.
La función java-basic incluye un controlador (HandlerDivide) que devuelve una excepción en tiempo
de ejecución personalizada. El controlador HandlerStream implementa RequestStreamHandler y
puede generar una excepción comprobada IOException.
409
AWS Lambda Guía para desarrolladores
Tracing
aplicación, desde el frontend de la API hasta el almacenamiento y la base de datos del backend. Solo
con agregar la biblioteca de X-Ray SDK a la configuración de compilación, puede registrar los errores y la
latencia de cualquier llamada que realice la función a un servicio de AWS.
Para rastrear solicitudes que no tienen un encabezado de rastreo, habilite el rastreo activo en la
configuración de la función.
Precios
X-Ray tiene una capa gratuita permanente Más allá del umbral de la capa gratuita, X-Ray realiza
cargos por almacenamiento y recuperación del seguimiento. Consulte Precios de AWS X-Ray
para obtener más información.
Su función necesita permiso para cargar datos de rastreo en X-Ray. Cuando habilita el rastreo activo en la
Lambda consola, Lambda agrega los permisos necesarios al rol de ejecución (p. 33) de la función. De lo
contrario, agregue la política AWSXRayDaemonWriteAccess al rol de ejecución.
X-Ray aplica un algoritmo de muestreo para garantizar que el rastreo sea eficiente, al tiempo que
proporciona una muestra representativa de las solicitudes a las que sirve la aplicación. La regla de
muestreo predeterminada es 1 solicitud por segundo y un 5 por ciento de las solicitudes adicionales.
Cuando el rastreo activo está habilitado, Lambda registra el rastreo de un subconjunto de invocaciones.
Lambda registra dos segmentos, lo que crea dos nodos en el mapa de servicio. El primer nodo representa
410
AWS Lambda Guía para desarrolladores
Tracing
el servicio de Lambda que recibe la solicitud de invocación. El tiempo de ejecución (p. 19) de la función
registra el segundo nodo.
Para registrar los detalles sobre las llamadas a otros recursos y servicios que realiza la función, agregue
el SDK para Java de X-Ray a la configuración de compilación. En el siguiente ejemplo, se muestra una
configuración de compilación de Gradle que incluye las bibliotecas que permiten la instrumentación
automática de los clientes de AWS SDK para Java 2.x.
dependencies {
implementation platform('software.amazon.awssdk:bom:2.10.73')
implementation platform('com.amazonaws:aws-xray-recorder-sdk-bom:2.4.0')
implementation 'software.amazon.awssdk:lambda'
implementation 'com.amazonaws:aws-xray-recorder-sdk-core'
implementation 'com.amazonaws:aws-xray-recorder-sdk-aws-sdk-core'
implementation 'com.amazonaws:aws-xray-recorder-sdk-aws-sdk-v2'
implementation 'com.amazonaws:aws-xray-recorder-sdk-aws-sdk-v2-instrumentor'
...
}
En el ejemplo siguiente se muestra un seguimiento con 2 segmentos. Ambos se llaman my-function, pero
uno es tipo AWS::Lambda y el otro es AWS::Lambda::Function. El segmento de función se expande
para mostrar sus subsegmentos.
El primer segmento representa la solicitud de invocación procesada por el servicio Lambda. El segundo
segmento registra el trabajo realizado por la función. El segmento de la función tiene 3 subsegmentos.
411
AWS Lambda Guía para desarrolladores
Habilitación del seguimiento activo con la API de Lambda
• Invocation (Invocación) – Representa el trabajo realizado por el código del controlador. Al instrumentar el
código, puede extender este subsegmento mediante subsegmentos adicionales.
• Overhead (Sobrecarga) – Representa el trabajo realizado por el tiempo de ejecución de Lambda con el
fin de prepararse para controlar el siguiente evento.
También puede instrumentar clientes HTTP, registrar consultas SQL y crear subsegmentos personalizados
con anotaciones y metadatos. Para obtener más información, consulte SDK de AWS X-Ray para Java en
Guía para desarrolladores de AWS X-Ray.
Secciones
• Habilitación del seguimiento activo con la API de Lambda (p. 412)
• Habilitación del seguimiento activo con AWS CloudFormation (p. 412)
• Almacenamiento de dependencias en tiempo de ejecución en una capa (p. 413)
• Seguimiento en las aplicaciones de ejemplo (p. 413)
El siguiente comando de la AWS CLI de ejemplo habilita el rastreo activo en una función llamada «my-
function».
El modo de seguimiento forma parte de la configuración específica de la versión, que se bloquea cuando
se publica una versión de la función. No se puede cambiar el modo de seguimiento de una versión
publicada.
Resources:
function:
Type: AWS::Lambda::Function
Properties:
TracingConfig:
Mode: Active
...
412
AWS Lambda Guía para desarrolladores
Almacenamiento de dependencias
en tiempo de ejecución en una capa
Resources:
function:
Type: AWS::Serverless::Function
Properties:
Tracing: Active
...
Resources:
function:
Type: AWS::Serverless::Function
Properties:
CodeUri: build/distributions/blank-java.zip
Tracing: Active
Layers:
- !Ref libs
...
libs:
Type: AWS::Serverless::LayerVersion
Properties:
LayerName: blank-java-lib
Description: Dependencies for the blank-java sample app.
ContentUri: build/blank-java-lib.zip
CompatibleRuntimes:
- java8
Con esta configuración, solo actualiza la capa de la biblioteca si se modifican las dependencias del tiempo
de ejecución. El paquete de implementación de funciones solo contiene su código. Cuando actualiza el
código de la función, el tiempo de carga es mucho más rápido que si incluye dependencias en el paquete
de implementación.
Para crear una capa de dependencias, es necesario realizar cambios en la configuración de compilación
para generar el archivo de capas antes de la implementación. Para ver un ejemplo práctico, consulte la
aplicación de muestra java-basic.
413
AWS Lambda Guía para desarrolladores
Tutorial: IDE de Eclipse
• blank-java: función de Java que muestra el uso de bibliotecas de Java de Lambda, el registro, las
variables de entorno, las capas, el seguimiento de AWS X-Ray, las pruebas unitarias y el SDK de AWS.
• java-basic: función de Java mínima con pruebas unitarias y configuración de registro de variables.
• java-events: función de Java mínima que utiliza la biblioteca aws-lambda-java-events (p. 386) con tipos
de eventos que no requieren el SDK de AWS como dependencia, como Amazon API Gateway.
• java-events-v1sdk: función de Java que utiliza la biblioteca aws-lambda-java-events (p. 386) con tipos
de eventos que requieren el SDK de AWS como dependencia (Amazon Simple Storage Service, Amazon
DynamoDB y Amazon Kinesis).
• s3-java: función de Java que procesa los eventos de notificación de Amazon S3 y utiliza Java Class
Library (JCL) para crear miniaturas de los archivos de imagen cargados.
Todas las aplicaciones de ejemplo tienen activado el seguimiento activo de las funciones Lambda. En la
aplicación blank-java, se muestra la instrumentación automática de los clientes de AWS SDK para Java
2.x, la administración de segmentos para pruebas, subsegmentos personalizados y el uso de capas de
Lambda para almacenar dependencias en tiempo de ejecución.
En este ejemplo de la aplicación blank-java, se muestran los nodos del servicio Lambda, una función
y la API de Lambda. La función llama a la API de Lambda para monitorear el uso del almacenamiento en
Lambda.
Temas
• Requisitos previos (p. 415)
• Creación y compilación de un proyecto (p. 415)
414
AWS Lambda Guía para desarrolladores
Requisitos previos
Requisitos previos
Instale el complemento Maven para Eclipse.
a. Abra el menú contextual (haga clic con el botón derecho) del archivo pom.xml, elija Maven y, a
continuación, Add Dependency.
b. En las ventanas Add Dependency, escriba los siguientes valores:
Versión: 1.2.1
Note
Si está siguiendo otros temas del tutorial de esta guía, es posible que los tutoriales
específicos le soliciten añadir más dependencias. Asegúrese de añadir las dependencias
que sean necesarias.
3. Añada la clase de Java al proyecto.
a. Abra el menú contextual (haga clic con el botón derecho) del subdirectorio src/main/java del
proyecto, elija New y, a continuación, Class.
b. En la ventana New Java Class, escriba los siguientes valores:
415
AWS Lambda Guía para desarrolladores
Creación y compilación de un proyecto
Si está siguiendo otros temas del tutorial de esta guía, es posible que los tutoriales
específicos le recomienden un nombre de paquete o de clase diferente.
c. Añada el código Java. Si está siguiendo otros temas del tutorial de esta guía, añada el código
proporcionado.
4. Compile el proyecto.
Abra el menú contextual (haga clic con el botón derecho) del proyecto en Package Explorer y elija
Run As, seguido de Maven Build.... En la ventana Edit Configuration (Editar configuración), escriba
package en el cuadro Goals (Objetivos).
Note
El complemento maven-shade-plugin tomará los artefactos (archivos .jar) producidos por el objetivo
package (produce archivos .jar de código de cliente), y creará un archivo .jar independiente que
contiene el código de cliente compilado, así como las dependencias resueltas de pom.xml.
a. Abra el menú contextual (haga clic con el botón derecho) del archivo pom.xml, elija Maven y, a
continuación, Add Plugin.
b. En la ventana Add Plugin, escriba los siguientes valores:
Esta vez crearemos el archivo .jar como antes y, a continuación, utilizaremos el complemento
maven-shade-plugin para extraer las dependencias y crear el .jar independiente
i. Abra el menú contextual (haga clic con el botón derecho) del proyecto, elija Run As y, a
continuación Maven build....
ii. En las ventanas Edit Configuration (Editar configuración), escriba package shade:shade
en el cuadro Goals (Objetivos).
iii. Elija Run.
Abra el menú contextual (haga clic con el botón derecho) del subdirectorio /target
y elija Show In, seguido de System Explorer; encontrará el archivo lambda-java-
example-0.0.1-SNAPSHOT.jar.
416
AWS Lambda Guía para desarrolladores
Paquete de implementación
Tiempos de ejecución de Go
Note
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.
Temas
• Paquete de implementación de AWS Lambda en Go (p. 417)
• Controlador de funciones de AWS Lambda en Go (p. 419)
• Objeto context AWS Lambda en Go (p. 422)
• Registro de funciones de AWS Lambda en Go (p. 424)
• Errores de funciones de AWS Lambda en Go (p. 427)
• Instrumentación del código Go en AWS Lambda (p. 427)
• Uso de variables de entorno (p. 431)
417
AWS Lambda Guía para desarrolladores
Creación de un paquete de implementación en Windows
Establecer GOOS en linux garantiza que el ejecutable compilado es compatible con el tiempo de
ejecución de Go (p. 130), incluso si lo compila en un entorno que no sea Linux.
Si aún no lo ha hecho, deberá instalar git y, después, añadir el ejecutable git a la variable de
entorno de Windows %PATH%.
Utilice la herramienta desde su GOPATH. Si tiene una instalación predeterminada de Go, la herramienta
suele estar en %USERPROFILE%\Go\bin. De lo contrario, vaya hasta la ubicación donde instaló el entorno
en tiempo de ejecución de Go y haga lo siguiente:
set GOOS=linux
go build -o main main.go
%USERPROFILE%\Go\bin\build-lambda-zip.exe -output main.zip main
$env:GOOS = "linux"
$env:CGO_ENABLED = "0"
$env:GOARCH = "amd64"
go build -o main main.go
~\Go\Bin\build-lambda-zip.exe -output main.zip main
418
AWS Lambda Guía para desarrolladores
Controlador
package main
import (
"fmt"
"context"
"github.com/aws/aws-lambda-go/lambda"
)
func main() {
lambda.Start(HandleRequest)
}
• package main: en Go, el paquete que contiene func main() debe denominarse siempre main.
• import: utilice esta opción para incluir las bibliotecas que requiere la función de Lambda. En este
ejemplo, incluye:
• context: Objeto context AWS Lambda en Go (p. 422).
• fmt: objeto de formato de Go que se utiliza para dar formato al valor de retorno de la función.
• github.com/aws/aws-lambda-go/lambda: como se mencionó anteriormente, implementa el modelo de
programación de Lambda para Go.
• func HandleRequest(ctx context.Context, name MyEvent) (string, error): esta es la signatura del
controlador de Lambda e incluye el código que se va a ejecutar. Además, los parámetros incluidos
indican lo siguiente:
• ctx context.Context: proporciona información en tiempo de ejecución para la invocación de la función
de Lambda. ctx es la variable que declara para aprovechar la información disponible a través de
Objeto context AWS Lambda en Go (p. 422).
• name MyEvent: tipo de entrada con un nombre de variable de name cuyo valor se devuelve en la
instrucción return.
• string, error: devuelve dos valores: cadena en caso de ejecución correcta e información de error
estándar. Para obtener más información sobre el control de errores personalizado, consulte Errores de
funciones de AWS Lambda en Go (p. 427).
• return fmt.Sprintf("Hello %s!", name), nil: devuelve simplemente un saludo "Hello" formateado con
el nombre que ha proporcionado en el eevnto de entrada. nil indica que no hubo errores y que la
función se ejecutó correctamente.
• func main(): el punto de entrada que ejecuta el código de la función de Lambda. Esto es necesario.
419
AWS Lambda Guía para desarrolladores
Controlador de funciones de
Lambda con tipos estructurados
package main
import (
"fmt"
"github.com/aws/aws-lambda-go/lambda"
)
func main() {
lambda.Start(HandleLambdaEvent)
}
# request
{
"What is your name?": "Jim",
"How old are you?": 33
}
# response
{
"Answer": "Jim is 33 years old!"
}
Para que se exporten, los nombres de campo en la estructura de eventos deben estar en mayúsculas.
Para obtener más información acerca de cómo controlar eventos de orígenes de eventos AWS, consulte
aws-lambda-go/events.
420
AWS Lambda Guía para desarrolladores
Uso del estado global
• El controlador puede aceptar entre 0 y 2 argumentos. Si hay dos argumentos, el primero debe
implementar context.Context.
• El controlador puede devolver entre 0 y 2 argumentos. Si hay un único valor de retorno, este debe
implementar error. Si hay dos valores de retorno, el segundo debe implementar error. Para obtener
más información acerca de cómo implementar la información de control de errores, consulte Errores de
funciones de AWS Lambda en Go (p. 427).
A continuación se enumeran las signaturas del controlador válidas. TIn y TOut representan los tipos
compatibles con la biblioteca estándar encoding/json. Para obtener más información, consulte func
Unmarshal a fin de saber cómo se deserializan estos tipos.
•
func ()
•
func () error
•
func (TIn), error
•
func () (TOut, error)
•
func (context.Context) error
•
func (context.Context, TIn) error
•
func (context.Context) (TOut, error)
•
func (context.Context, TIn) (TOut, error)
package main
import (
"log"
"github.com/aws/aws-lambda-go/lambda"
"github.com/aws/aws-sdk-go/aws/session"
"github.com/aws/aws-sdk-go/service/s3"
"github.com/aws/aws-sdk-go/aws"
)
var invokeCount = 0
var myObjects []*s3.Object
func init() {
svc := s3.New(session.New())
input := &s3.ListObjectsV2Input{
Bucket: aws.String("examplebucket"),
}
result, _ := svc.ListObjectsV2(input)
myObjects = result.Contents
421
AWS Lambda Guía para desarrolladores
Contexto
func main() {
lambda.Start(LambdaHandler)
}
Variables globales
Métodos de context
Propiedades de context
• InvokedFunctionArn: El nombre de recurso de Amazon (ARN) que se utiliza para invocar la función.
Indica si el invocador ha especificado un alias o un número de versión.
• AwsRequestID: El identificador de la solicitud de invocación.
• Identity: (aplicaciones móviles) Información acerca de la identidad de Amazon Cognito que ha
autorizado la solicitud.
• ClientContext: (aplicaciones móviles) El contexto del cliente proporcionado a Lambda por parte de la
aplicación del cliente.
422
AWS Lambda Guía para desarrolladores
Acceso a la información del contexto de invocación
package main
import (
"context"
"log"
"github.com/aws/aws-lambda-go/lambda"
"github.com/aws/aws-lambda-go/lambdacontext"
)
func main() {
lambda.Start(CognitoHandler)
}
En el ejemplo anterior, lc es la variable que se usa para consumir la información que el objeto context
capturó y log.Print(lc.Identity.CognitoIdentityPoolID) imprime dicha información, en este
caso, CognitoIdentityPoolID.
En el ejemplo siguiente se indica cómo utilizar el objeto context para monitorizar el tiempo que tarda en
ejecutarse la función de Lambda. Esto le permite analizar las expectativas de desempeño y ajustar el
código de su función en consecuencia, si es necesario.
package main
import (
"context"
"log"
"time"
"github.com/aws/aws-lambda-go/lambda"
)
deadline, _ := ctx.Deadline()
deadline = deadline.Add(-100 * time.Millisecond)
timeoutChannel := time.After(time.Until(deadline))
for {
select {
default:
log.Print("hello!")
time.Sleep(50 * time.Millisecond)
}
}
}
func main() {
lambda.Start(LongRunningHandler)
}
423
AWS Lambda Guía para desarrolladores
Registro
Para generar registros desde el código de la función, puede utilizar los métodos del paquete fmt o
cualquier biblioteca de registro que escriba en stdout o en stderr. En el ejemplo siguiente, se utiliza el
paquete de registro.
El tiempo de ejecución de Go registra las líneas START, END y REPORT de cada invocación. La línea del
informe proporciona los siguientes detalles.
Registro de informes
424
AWS Lambda Guía para desarrolladores
Visualización de registros en la
Consola de administración de AWS
Puede ver los registros en la consola de Lambda o en la de CloudWatch Logs, o bien en la línea de
comandos.
Secciones
• Visualización de registros en la Consola de administración de AWS (p. 425)
• Mediante AWS CLI (p. 425)
• Eliminación de registros (p. 427)
Cada flujo de registro se corresponde con una instancia de su función (p. 132). Los nuevos flujos aparecen
cuando se actualiza la función y cuando se crean más instancias para atendar varias invocaciones
simultáneas. Para buscar los registros de invocaciones específicas, puede instrumentar la función con
X-Ray y registrar los detalles sobre el flujo de registro y la solicitud en el registro de seguimiento. Para
obtener una aplicación de ejemplo que correlacione registros y rastros de seguimiento con X-Ray, consulte
Aplicación de ejemplo de procesamiento de errores para AWS Lambda (p. 323).
425
AWS Lambda Guía para desarrolladores
Mediante AWS CLI
La utilidad base64 está disponible en Linux, MacOS y Ubuntu en Windows. Para el sistema operativo
macOS, el comando es base64 -D.
Para obtener eventos de registro completos desde la línea de comandos, puede incluir el nombre del
flujo de registros en la salida de la función, como se muestra en el ejemplo anterior. El siguiente script de
ejemplo invoca una función denominada my-function y descarga los últimos cinco eventos de registro.
#!/bin/bash
aws lambda invoke --function-name my-function --payload '{"key": "value"}' out
sed -i'' -e 's/"//g' out
sleep 15
aws logs get-log-events --log-group-name /aws/lambda/my-function --log-stream-name $(cat
out) --limit 5
El script utiliza sed para eliminar las comillas del archivo de salida y permanece inactivo durante
15 segundos para dar tiempo a que los registros estén disponibles. La salida incluye la respuesta de
Lambda y la salida del comando get-log-events.
$ ./get-logs.sh
{
"StatusCode": 200,
"ExecutedVersion": "$LATEST"
}
{
"events": [
{
"timestamp": 1559763003171,
"message": "START RequestId: 4ce9340a-b765-490f-ad8a-02ab3415e2bf Version:
$LATEST\n",
"ingestionTime": 1559763003309
},
{
"timestamp": 1559763003173,
"message": "2019-06-05T19:30:03.173Z\t4ce9340a-b765-490f-ad8a-02ab3415e2bf
\tINFO\tENVIRONMENT VARIABLES\r{\r \"AWS_LAMBDA_FUNCTION_VERSION\": \"$LATEST\",\r ...",
"ingestionTime": 1559763018353
},
{
"timestamp": 1559763003173,
"message": "2019-06-05T19:30:03.173Z\t4ce9340a-b765-490f-ad8a-02ab3415e2bf
\tINFO\tEVENT\r{\r \"key\": \"value\"\r}\n",
"ingestionTime": 1559763018353
},
{
"timestamp": 1559763003218,
"message": "END RequestId: 4ce9340a-b765-490f-ad8a-02ab3415e2bf\n",
426
AWS Lambda Guía para desarrolladores
Eliminación de registros
"ingestionTime": 1559763018353
},
{
"timestamp": 1559763003218,
"message": "REPORT RequestId: 4ce9340a-b765-490f-ad8a-02ab3415e2bf\tDuration:
26.73 ms\tBilled Duration: 100 ms \tMemory Size: 128 MB\tMax Memory Used: 75 MB\t\n",
"ingestionTime": 1559763018353
}
],
"nextForwardToken": "f/34783877304859518393868359594929986069206639495374241795",
"nextBackwardToken": "b/34783877303811383369537420289090800615709599058929582080"
}
Eliminación de registros
Los grupos de registros no se eliminan automáticamente al eliminar una función. Para evitar los registros
de almacenamiento de forma indefinida, elimine el grupo de registros o configure un periodo de retención
después del cual los registros se eliminarán automáticamente.
En los siguientes códigos de muestra se ilustra cómo hacerlo. Tenga en cuenta que los errores
personalizados en Go deben importar el módulo errors.
package main
import (
"errors"
"github.com/aws/aws-lambda-go/lambda"
)
func main() {
lambda.Start(OnlyErrors)
}
{
"errorMessage": "something went wrong!",
"errorType": "errorString"
}
427
AWS Lambda Guía para desarrolladores
Tracing
con agregar la biblioteca de X-Ray SDK a la configuración de compilación, puede registrar los errores y la
latencia de cualquier llamada que realice la función a un servicio de AWS.
Para rastrear solicitudes que no tienen un encabezado de rastreo, habilite el rastreo activo en la
configuración de la función.
Precios
X-Ray tiene una capa gratuita permanente Más allá del umbral de la capa gratuita, X-Ray realiza
cargos por almacenamiento y recuperación del seguimiento. Consulte Precios de AWS X-Ray
para obtener más información.
Su función necesita permiso para cargar datos de rastreo en X-Ray. Cuando habilita el rastreo activo en la
Lambda consola, Lambda agrega los permisos necesarios al rol de ejecución (p. 33) de la función. De lo
contrario, agregue la política AWSXRayDaemonWriteAccess al rol de ejecución.
X-Ray aplica un algoritmo de muestreo para garantizar que el rastreo sea eficiente, al tiempo que
proporciona una muestra representativa de las solicitudes a las que sirve la aplicación. La regla de
muestreo predeterminada es 1 solicitud por segundo y un 5 por ciento de las solicitudes adicionales.
Cuando el rastreo activo está habilitado, Lambda registra el rastreo de un subconjunto de invocaciones.
Lambda registra dos segmentos, lo que crea dos nodos en el mapa de servicio. El primer nodo representa
el servicio de Lambda que recibe la solicitud de invocación. El tiempo de ejecución (p. 19) de la función
registra el segundo nodo.
428
AWS Lambda Guía para desarrolladores
Tracing
Puede instrumentar su código de controlador para registrar metadatos y rastrear llamadas descendentes.
Para registrar detalles sobre las llamadas que el controlador realiza a otros recursos y servicios, utilice el
SDK de X-Ray para Go. Descargue el SDK desde su repositorio de GitHub con go get:
$ go get github.com/aws/aws-xray-sdk-go
xray.AWS(s3.Client)
En el ejemplo siguiente se muestra un seguimiento con 2 segmentos. Ambos se llaman my-function, pero
uno es tipo AWS::Lambda y el otro es AWS::Lambda::Function. El segmento de función se expande
para mostrar sus subsegmentos.
El primer segmento representa la solicitud de invocación procesada por el servicio Lambda. El segundo
segmento registra el trabajo realizado por la función. El segmento de la función tiene 3 subsegmentos.
También puede instrumentar clientes HTTP, registrar consultas SQL y crear subsegmentos personalizados
con anotaciones y metadatos. Para obtener más información, consulte SDK de X-Ray para Go en la Guía
para desarrolladores de AWS X-Ray.
429
AWS Lambda Guía para desarrolladores
Habilitación del seguimiento activo con la API de Lambda
Secciones
• Habilitación del seguimiento activo con la API de Lambda (p. 430)
• Habilitación del seguimiento activo con AWS CloudFormation (p. 430)
El siguiente comando de la AWS CLI de ejemplo habilita el rastreo activo en una función llamada «my-
function».
El modo de seguimiento forma parte de la configuración específica de la versión, que se bloquea cuando
se publica una versión de la función. No se puede cambiar el modo de seguimiento de una versión
publicada.
Resources:
function:
Type: AWS::Lambda::Function
Properties:
TracingConfig:
Mode: Active
...
Resources:
function:
Type: AWS::Serverless::Function
Properties:
Tracing: Active
...
430
AWS Lambda Guía para desarrolladores
Variables de entorno
El siguiente ejemplo explica cómo hacerlo. Tenga en cuenta que la función importa el paquete fmt para
formatear los resultados impresos y el paquete os, una interfaz del sistema independiente de la plataforma
que le permite obtener acceso a las variables de entorno.
package main
import (
"fmt"
"os"
"github.com/aws/aws-lambda-go/lambda"
)
func main() {
fmt.Printf("%s is %s. years old\n", os.Getenv("NAME"), os.Getenv("AGE"))
Para obtener una lista de variables de entorno establecidas por el motor de ejecución de Lambda, consulte
Variables de entorno de tiempo de ejecución (p. 58).
431
AWS Lambda Guía para desarrolladores
Runtimes de .NET
Note
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.
• blank-csharp: una función de C# que muestra el uso de las bibliotecas de .NET de Lambda, el
registro, las variables de entorno, el seguimiento de AWS X-Ray, las pruebas de unidad y el
SDK de AWS.
• ec2-spot: una función que administra las solicitudes de instancia de spot en Amazon EC2.
Temas
• AWS Lambda Paquete de implementación en C# (p. 433)
432
AWS Lambda Guía para desarrolladores
Paquete de implementación
Temas
• CLI de .NET Core (p. 433)
• AWS Toolkit for Visual Studio (p. 436)
En la CLI de .NET se usa el comando new para crear proyectos .NET desde una línea de comando. Esto
resulta útil si desea crear un proyecto fuera de Visual Studio. Para ver una lista de los tipos de proyectos
disponibles, abra una línea de comando, vaya hasta la ubicación donde instaló el entorno en tiempo de
ejecución de .NET Core y ejecute el siguiente comando:
-------------------------------------------------------------------------------------------------------
Console Application console [C#], F#, VB
Common/Console
Class library classlib [C#], F#, VB
Common/Library
Unit Test Project mstest [C#], F#, VB
Test/MSTest
xUnit Test Project xunit [C#], F#, VB
Test/xUnit
...
Examples:
433
AWS Lambda Guía para desarrolladores
CLI de .NET Core
AWS Lambda ofrece plantillas adicionales a través del paquete NuGet Amazon.Lambda.Templates. Para
instalar este paquete, ejecute el comando siguiente:
Una vez completada la instalación, las plantillas de Lambda; aparecen como parte de dotnet new. Para
examinar los detalles acerca de una plantilla, utilice la opción de ayuda.
"profile" : "default",
"region" : "us-east-2",
"configuration" : "Release",
"framework" : "netcoreapp2.1",
"function-runtime":"dotnetcore3.1",
"function-memory-size" : 256,
"function-timeout" : 30,
"function-handler" : "MyFunction::MyFunction.Function::FunctionHandler"
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
using Amazon.Lambda.Core;
// Assembly attribute to enable the Lambda function's JSON input to be converted into
a .NET class.
[assembly: LambdaSerializer(typeof(Amazon.Lambda.Serialization.Json.JsonSerializer))]
434
AWS Lambda Guía para desarrolladores
CLI de .NET Core
namespace MyFunction
{
public class Function
{
• MyFunction.csproj: archivo MSBuild que enumera los archivos y ensamblados que componen la
aplicación.
<Project Sdk="Microsoft.NET.Sdk">
<PropertyGroup>
<TargetFramework>netcoreapp2.1</TargetFramework>
</PropertyGroup>
<ItemGroup>
<PackageReference Include="Amazon.Lambda.Core" Version="1.0.0 " />
<PackageReference Include="Amazon.Lambda.Serialization.Json" Version="1.3.0" />
</ItemGroup>
</Project>
<Project Sdk="Microsoft.NET.Sdk">
...
• FunctionTest.cs: el mismo archivo de plantilla de código C# que se incluye en el directorio src. Edite
este archivo para reflejar el código de producción de su función y probarlo antes de cargar su función de
Lambda en un entorno de producción.
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
using Xunit;
using Amazon.Lambda.Core;
using Amazon.Lambda.TestUtilities;
using MyFunction;
namespace MyFunction.Tests
{
public class FunctionTest
{
435
AWS Lambda Guía para desarrolladores
AWS Toolkit for Visual Studio
[Fact]
public void TestToUpperFunction()
{
// Invoke the lambda function and confirm the string was upper cased.
var function = new Function();
var context = new TestLambdaContext();
var upperCase = function.FunctionHandler("hello world", context);
Una vez que la función ha superado las pruebas, puede crearla e implementarla mediante la herramienta
de .NET Core Global Amazon.Lambda.Tools. Para instalar la herramienta de .NET Core Global, ejecute el
siguiente comando.
Si ya tiene la herramienta instalada, puede asegurarse de estar utilizando la última versión con el siguiente
comando.
Para obtener más información acerca de la herramienta de .NET Core Global Amazon.Lambda.Tools,
consulte su repositorio GitHub.
Con las herramientas Amazon.Lambda.Tools instalados, puede implementar su función con el siguiente
comando:
Si todos los aspectos del proceso son correctos, debe ver lo siguiente:
Log Tail:
START RequestId: id Version: $LATEST
END RequestId: id
REPORT RequestId: id Duration: 0.99 ms Billed Duration: 100 ms Memory Size:
256 MB Max Memory Used: 12 MB
436
AWS Lambda Guía para desarrolladores
AWS Toolkit for Visual Studio
{
"profile":"default",
"region" : "us-east-2",
"configuration" : "Release",
"framework" : "netcoreapp2.1",
"function-runtime":"dotnetcore3.1",
"function-memory-size" : 256,
"function-timeout" : 30,
"function-handler" : "Assembly::Namespace.Class::Function"
}
3. Abra el archivo Function.cs. Se le proporcionará una plantilla para implementar el código del
controlador de la función de Lambda.
4. Una vez que haya escrito el código que representa la función de Lambda, puede cargarlo haciendo
clic con el botón derecho del ratón en el nodo Project (Previsión) de la aplicación y, a continuación,
eligiendo Publish to AWS Lambda (Publicar en AWS Lambda).
5. En la ventana Upload Lambda Function (Cargar función de Lambda), escriba un nombre para la
función o seleccione una función que ya se haya publicado para volver a publicarla. A continuación,
elija Siguiente
6. En la ventana Advanced Function Details (Detalles de función avanzada), configure las siguientes
opciones:
437
AWS Lambda Guía para desarrolladores
Controlador
• Role Name (Nombre de rol) (obligatorio): El rol de IAM (p. 33) que AWS Lambda asume cuando
ejecuta la función.
• Environment (Entorno): Pares clave-valor que Lambda establece en el entorno de ejecución. Utilice
variables de entorno (p. 56) para ampliar la configuración de la función fuera del código.
• Memory (Memoria): La cantidad de memoria disponible para la función durante la ejecución. Elija
una cantidad entre 128 MB y 3,008 MB (p. 31), en incrementos de 64 MB.
• Timeout (Tiempo de espera): La cantidad de tiempo que Lambda permite que una función se
ejecute antes de detenerla. El valor predeterminado es de 3 segundos. El valor máximo permitido es
de 900 segundos.
• VPC: Si la función necesita acceso de red a recursos que no están disponibles a través de Internet,
configúrela para que se conecte a una VPC (p. 81).
• DLQ: Si la función se invoca de forma asíncrona, elija una cola o un tema (p. 107) para recibir las
invocaciones erróneas.
• Enable active tracing (Habilitar rastreo activo): Realice un muestreo de las solicitudes entrantes y
rastree las solicitudes muestreadas con AWS X-Ray (p. 311).
7. Elija Next seguido de Upload para implementar la aplicación.
Para obtener más información, consulte Implementación de un proyecto de AWS Lambda con la CLI
de .NET Core.
Un controlador de función de Lambda se define como una instancia o un método estático en una clase. Si
desea acceder al objeto context de Lambda, está disponible definiendo un parámetro de método de tipo
ILambdaContext, una interfaz que puede utilizar para obtener acceso a información acerca de la ejecución
actual, como el nombre de la función actual, la cantidad máxima de memoria, el tiempo que falta para
finalizar la ejecución y el registro.
• inputType: el primer parámetro del controlador es su entrada, que puede estar formada por datos de
eventos (publicados por un origen de eventos) o por una entrada personalizada proporcionada por el
usuario, como una cadena o cualquier objeto de datos personalizado.
• returnType: si piensa invocar la función de Lambda de forma síncrona (utilizando el tipo de invocación
RequestResponse), puede devolver la salida de la función utilizando cualquiera de los tipos de datos
admitidos. Por ejemplo, si utiliza una función de Lambda como backend de aplicaciones móviles, la
invocación se realiza de forma síncrona. El tipo de datos de salida se serializará en JSON.
Si piensa invocar la función de Lambda de forma asíncrona (utilizando el tipo de invocación Event),
returnType debería ser void. Por ejemplo, si utiliza AWS Lambda con orígenes de eventos como
Amazon S3 o Amazon SNS, estos orígenes de eventos invocan la función de Lambda mediante el tipo
de invocación Event.
• ILambdaContext context: el segundo argumento de la firma del controlador es opcional.
Proporciona acceso al objeto context (p. 443) que tiene información sobre la función y la solicitud.
438
AWS Lambda Guía para desarrolladores
Control de flujos
Control de flujos
De forma predeterminada, solo se admite el tipo System.IO.Stream como parámetro de entrada.
using System.IO;
namespace Example
{
public class Hello
{
public Stream MyHandler(Stream stream)
{
//function logic
}
}
}
En el código C# del ejemplo, el primer parámetro del controlador es la entrada al controlador (MyHandler),
que puede estar formada por datos de eventos (publicados por un origen de eventos como Amazon S3)
o por una entrada personalizada proporcionada por el usuario, tal como Stream (como sucede en este
ejemplo) o cualquier objeto de datos personalizado. La salida es de tipo Stream.
A menos que los parámetros de entrada y salida de la función sean del tipo System.IO.Stream,
deberá serializarlos. AWS Lambda proporciona un serializador predeterminado que se puede aplicar
en el nivel de ensamblado o de método de la aplicación, o puede definir uno implementando la interfaz
ILambdaSerializer proporcionada por la biblioteca Amazon.Lambda.Core. Para obtener más
información, consulte AWS Lambda Paquete de implementación en C# (p. 433).
Para añadir el atributo serializador predeterminado a un método, primero añada una dependencia de
Amazon.Lambda.Serialization.Json en el archivo project.json.
{
"version": "1.0.0-*",
"dependencies":{
"Microsoft.NETCore.App": {
"type": "platform",
"version": "1.0.1"
},
"Amazon.Lambda.Serialization.Json": "1.3.0"
439
AWS Lambda Guía para desarrolladores
Signaturas del controlador
},
"frameworks": {
"netcoreapp1.0": {
"imports": "dnxcore50"
}
}
}
[LambdaSerializer(typeof(MyJsonSerializer))]
public Customer DescribeCustomer(DescribeCustomerRequest request)
{
return customerService.DescribeCustomer(request.Id);
}
}
Note
ENSAMBLADO::TIPO::MÉTODO, donde:
• ENSAMBLADO es el nombre del archivo de ensamblado de .NET para la aplicación. Cuando utilice la
CLI de .NET Core para compilar la aplicación, si no ha establecido el nombre del ensamblado con la
opción buildOptions.outputName en project.json, el nombre de ENSAMBLADO será el nombre de
la carpeta que contiene el archivo project. json. Para obtener más información, consulte CLI de .NET
Core (p. 433). En este caso, supongamos que el nombre de la carpeta es HelloWorldApp.
• TIPO es el nombre completo del tipo de controlador, que consta del EspacioDeNombres y del
NombreDeLaClase. En este caso Example.Hello.
• MÉTODO es el nombre del controlador de la función, en este caso, MyHandler.
using System.IO;
namespace Example
{
440
AWS Lambda Guía para desarrolladores
Serialización de las funciones de Lambda
Puede implementar este método para deserializar la carga de solicitud desde la API Invoke en el
objeto que se pasa al controlador de la función de Lambda.
• T Serialize<T>(T response, Stream responseStream);.
Puede implementar este método para serializar el resultado que devuelve el controlador de la función
de Lambda en la carga de respuesta que devuelve la API Invoke.
Puede utilizar cualquier serializador que desee añadiéndolo como una dependencia al archivo
MyProject.csproj.
...
<ItemGroup>
<PackageReference Include="Amazon.Lambda.Core" Version="1.0.0" />
<PackageReference Include="Amazon.Lambda.Serialization.Json" Version="1.3.0" />
</ItemGroup>
[assembly:LambdaSerializer(typeof(Amazon.Lambda.Serialization.Json.JsonSerializer))]
441
AWS Lambda Guía para desarrolladores
Restricciones del controlador de funciones de Lambda
Note
• No puede ser unsafe ni utilizar tipos de puntero en la signatura del controlador, aunque el contexto
unsafe puede utilizarse dentro del método del controlador y sus dependencias. Para obtener más
información, consulte unsafe (Referencia de C#).
• No puede pasar un número variable de parámetros utilizando la palabra clave params, ni utilizar
ArgIterator como parámetro de entrada o de retorno que se utiliza para admitir un número variable
de parámetros.
• El controlador no puede ser un método genérico (por ejemplo, IList<T> Sort<T>(IList<T> input)).
• No se admiten los controladores asíncronos con la signatura async void.
• La función de Lambda puede incluir varias llamadas asíncronas, que pueden invocarse en paralelo.
Puede utilizar los métodos Task.WhenAll y Task.WhenAny para trabajar con varias tareas. Para
utilizar el método Task.WhenAll, pase una lista de las operaciones en una matriz al método. En el
ejemplo siguiente, tenga en cuenta que si olvida incluir cualquier operación en la matriz, la llamada
puede volver antes de que finalice su operación.
442
AWS Lambda Guía para desarrolladores
Contexto
// Lambda may return before printing "Test2" since we never wait on task2.
await Task.WhenAll(task1, task3);
}
Para utilizar el método Task.WhenAny, también se pasa una lista de las operaciones en una matriz al
método. La llamada vuelve tan pronto como finaliza la primera operación, incluso si las demás siguen
ejecutándose.
// Lambda may return before printing all tests since we're only waiting for one to
finish.
await Task.WhenAny(task1, task2, task3);
}
Propiedades de context
El siguiente fragmento de código C# muestra una función de controlador sencilla que imprime parte de la
información de contexto.
443
AWS Lambda Guía para desarrolladores
Registro
await Task.Delay(TimeSpan.FromSeconds(0.42));
Console.WriteLine("RemainingTime after sleep: " + context.RemainingTime);
}
Para generar registros desde el código de función, puede utilizar los métodos de la clase Console o
cualquier biblioteca de registro que escriba en stdout o en stderr. En el ejemplo siguiente se utiliza la
clase LambdaLogger de la biblioteca Amazon.Lambda.Core (p. 432).
444
AWS Lambda Guía para desarrolladores
Visualización de registros en la
Consola de administración de AWS
"Attributes": {
"ApproximateReceiveCount": "1",
"SentTimestamp": "1523232000000",
"SenderId": "123456789012",
"ApproximateFirstReceiveTimestamp": "1523232000001"
},
...
END RequestId: d1cf0ccb-xmpl-46e6-950d-04c96c9b1c5d
REPORT RequestId: d1cf0ccb-xmpl-46e6-950d-04c96c9b1c5d Duration: 4157.16 ms Billed
Duration: 4200 ms Memory Size: 256 MB Max Memory Used: 99 MB Init Duration: 841.60 ms
XRAY TraceId: 1-5e7e8131-7ff0xmpl32bfb31045d0a3bb SegmentId: 0152xmpl6016310f Sampled: true
El tiempo de ejecución de .NET registra las líneas START, END y REPORT de cada invocación. La línea del
informe proporciona los siguientes detalles.
Registro de informes
Puede ver los registros en la consola de Lambda o en la de CloudWatch Logs, o bien en la línea de
comandos.
Secciones
• Visualización de registros en la Consola de administración de AWS (p. 445)
• Mediante AWS CLI (p. 446)
• Eliminación de registros (p. 447)
Cada flujo de registro se corresponde con una instancia de su función (p. 132). Los nuevos flujos aparecen
cuando se actualiza la función y cuando se crean más instancias para atendar varias invocaciones
445
AWS Lambda Guía para desarrolladores
Mediante AWS CLI
simultáneas. Para buscar los registros de invocaciones específicas, puede instrumentar la función con
X-Ray y registrar los detalles sobre el flujo de registro y la solicitud en el registro de seguimiento. Para
obtener una aplicación de ejemplo que correlacione registros y rastros de seguimiento con X-Ray, consulte
Aplicación de ejemplo de procesamiento de errores para AWS Lambda (p. 323).
La utilidad base64 está disponible en Linux, MacOS y Ubuntu en Windows. Para el sistema operativo
macOS, el comando es base64 -D.
Para obtener eventos de registro completos desde la línea de comandos, puede incluir el nombre del
flujo de registros en la salida de la función, como se muestra en el ejemplo anterior. El siguiente script de
ejemplo invoca una función denominada my-function y descarga los últimos cinco eventos de registro.
#!/bin/bash
aws lambda invoke --function-name my-function --payload '{"key": "value"}' out
sed -i'' -e 's/"//g' out
sleep 15
aws logs get-log-events --log-group-name /aws/lambda/my-function --log-stream-name $(cat
out) --limit 5
El script utiliza sed para eliminar las comillas del archivo de salida y permanece inactivo durante
15 segundos para dar tiempo a que los registros estén disponibles. La salida incluye la respuesta de
Lambda y la salida del comando get-log-events.
$ ./get-logs.sh
{
"StatusCode": 200,
"ExecutedVersion": "$LATEST"
}
{
"events": [
446
AWS Lambda Guía para desarrolladores
Eliminación de registros
{
"timestamp": 1559763003171,
"message": "START RequestId: 4ce9340a-b765-490f-ad8a-02ab3415e2bf Version:
$LATEST\n",
"ingestionTime": 1559763003309
},
{
"timestamp": 1559763003173,
"message": "2019-06-05T19:30:03.173Z\t4ce9340a-b765-490f-ad8a-02ab3415e2bf
\tINFO\tENVIRONMENT VARIABLES\r{\r \"AWS_LAMBDA_FUNCTION_VERSION\": \"$LATEST\",\r ...",
"ingestionTime": 1559763018353
},
{
"timestamp": 1559763003173,
"message": "2019-06-05T19:30:03.173Z\t4ce9340a-b765-490f-ad8a-02ab3415e2bf
\tINFO\tEVENT\r{\r \"key\": \"value\"\r}\n",
"ingestionTime": 1559763018353
},
{
"timestamp": 1559763003218,
"message": "END RequestId: 4ce9340a-b765-490f-ad8a-02ab3415e2bf\n",
"ingestionTime": 1559763018353
},
{
"timestamp": 1559763003218,
"message": "REPORT RequestId: 4ce9340a-b765-490f-ad8a-02ab3415e2bf\tDuration:
26.73 ms\tBilled Duration: 100 ms \tMemory Size: 128 MB\tMax Memory Used: 75 MB\t\n",
"ingestionTime": 1559763018353
}
],
"nextForwardToken": "f/34783877304859518393868359594929986069206639495374241795",
"nextBackwardToken": "b/34783877303811383369537420289090800615709599058929582080"
}
Eliminación de registros
Los grupos de registros no se eliminan automáticamente al eliminar una función. Para evitar los registros
de almacenamiento de forma indefinida, elimine el grupo de registros o configure un periodo de retención
después del cual los registros se eliminarán automáticamente.
• Inicialización (cuando Lambda carga el código, valida la cadena de controlador y crea una instancia de la
clase, si no es estática).
• La invocación de la función de Lambda.
La información serializada sobre la excepción se devuelve como la carga de un objeto JSON modelado, y
se registra en los logs de CloudWatch.
447
AWS Lambda Guía para desarrolladores
Errores
"errorType": "LambdaException",
"errorMessage": "Invalid lambda function handler: 'http://this.is.not.a.valid.handler/'.
The valid format is 'ASSEMBLY::TYPE::METHOD'."
}
Si el constructor genera una excepción, el error también es del tipo LambdaException, pero la excepción
generada durante la construcción se proporciona en la propiedad cause, que es un objeto de excepción
modelado:
{
"errorType": "LambdaException",
"errorMessage": "An exception was thrown when the constructor for type
'LambdaExceptionTestFunction.ThrowExceptionInConstructor'
was invoked. Check inner exception for more details.",
"cause": {
"errorType": "TargetInvocationException",
"errorMessage": "Exception has been thrown by the target of an invocation.",
"stackTrace": [
"at System.RuntimeTypeHandle.CreateInstance(RuntimeType type, Boolean publicOnly,
Boolean noCheck, Boolean&canBeCached,
RuntimeMethodHandleInternal&ctor, Boolean& bNeedSecurityCheck)",
"at System.RuntimeType.CreateInstanceSlow(Boolean publicOnly, Boolean skipCheckThis,
Boolean fillCache, StackCrawlMark& stackMark)",
"at System.Activator.CreateInstance(Type type, Boolean nonPublic)",
"at System.Activator.CreateInstance(Type type)"
],
"cause": {
"errorType": "ArithmeticException",
"errorMessage": "Sorry, 2 + 2 = 5",
"stackTrace": [
"at LambdaExceptionTestFunction.ThrowExceptionInConstructor..ctor()"
]
}
}
}
Como muestra el ejemplo, las excepciones internas siempre se conservan (como la propiedad cause) y
pueden anidarse profundamente.
Las excepciones también pueden producirse durante la invocación. En este caso, se conserva el tipo de la
excepción y esta se devuelve directamente como carga y en los logs de CloudWatch. Por ejemplo:
{
"errorType": "AggregateException",
"errorMessage": "One or more errors occurred. (An unknown web exception occurred!)",
"stackTrace": [
"at System.Threading.Tasks.Task.ThrowIfExceptional(Boolean
includeTaskCanceledExceptions)",
"at System.Threading.Tasks.Task`1.GetResultCore(Boolean waitCompletionNotification)",
"at lambda_method(Closure , Stream , Stream , ContextInfo )"
],
"cause": {
"errorType": "UnknownWebException",
"errorMessage": "An unknown web exception occurred!",
"stackTrace": [
"at LambdaDemo107.LambdaEntryPoint.<GetUriResponse>d__1.MoveNext()",
"--- End of stack trace from previous location where exception was thrown ---",
"at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)",
"at
System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task
task)",
"at System.Runtime.CompilerServices.TaskAwaiter`1.GetResult()",
"at LambdaDemo107.LambdaEntryPoint.<CheckWebsiteStatus>d__0.MoveNext()"
448
AWS Lambda Guía para desarrolladores
Errores
],
"cause": {
"errorType": "WebException",
"errorMessage": "An error occurred while sending the request. SSL peer certificate or
SSH remote key was not OK",
"stackTrace": [
"at System.Net.HttpWebRequest.EndGetResponse(IAsyncResult asyncResult)",
"at System.Threading.Tasks.TaskFactory`1.FromAsyncCoreLogic(IAsyncResult iar,
Func`2 endFunction, Action`1 endAction, Task`1 promise, Boolean requiresSynchronization)",
"--- End of stack trace from previous location where exception was thrown ---",
"at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)",
"at
System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task
task)",
"at System.Runtime.CompilerServices.TaskAwaiter`1.GetResult()",
"at LambdaDemo107.LambdaEntryPoint.<GetUriResponse>d__1.MoveNext()"
],
"cause": {
"errorType": "HttpRequestException",
"errorMessage": "An error occurred while sending the request.",
"stackTrace": [
"at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)",
"at
System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task
task)",
"at System.Net.Http.HttpClient.<FinishSendAsync>d__58.MoveNext()",
"--- End of stack trace from previous location where exception was thrown ---",
"at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)",
"at
System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task
task)",
"at System.Net.HttpWebRequest.<SendRequest>d__63.MoveNext()",
"--- End of stack trace from previous location where exception was thrown ---",
"at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)",
"at
System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task
task)",
"at System.Net.HttpWebRequest.EndGetResponse(IAsyncResult asyncResult)"
],
"cause": {
"errorType": "CurlException",
"errorMessage": "SSL peer certificate or SSH remote key was not OK",
"stackTrace": [
"at System.Net.Http.CurlHandler.ThrowIfCURLEError(CURLcode error)",
"at
System.Net.Http.CurlHandler.MultiAgent.FinishRequest(StrongToWeakReference`1 easyWrapper,
CURLcode messageResult)"
]
}
}
}
}
}
El método con el que se comunica la información del error depende del tipo de invocación:
• Tipo de invocación RequestResponse (es decir, ejecución síncrona): en este caso, se obtiene el
mensaje de error.
Por ejemplo, si invoca una función de Lambda utilizando la consola de Lambda, RequestResponse
siempre es el tipo de invocación, y la consola muestra la información de error devuelta por AWS Lambda
en la sección Execution result (Resultado de ejecución) de la consola.
• Tipo de invocación Event (es decir, ejecución asíncrona): en este caso, AWS Lambda no devuelve
nada. En su lugar, registra la información de error en las métricas de CloudWatch Logs y CloudWatch.
449
AWS Lambda Guía para desarrolladores
Tracing
En función del origen de eventos, AWS Lambda puede volver a intentar la ejecución de la función
de Lambda que ha fallado. Para obtener más información, consulte Control de errores y reintentos
automáticos en AWS Lambda (p. 119).
Para rastrear solicitudes que no tienen un encabezado de rastreo, habilite el rastreo activo en la
configuración de la función.
Precios
X-Ray tiene una capa gratuita permanente Más allá del umbral de la capa gratuita, X-Ray realiza
cargos por almacenamiento y recuperación del seguimiento. Consulte Precios de AWS X-Ray
para obtener más información.
450
AWS Lambda Guía para desarrolladores
Tracing
Su función necesita permiso para cargar datos de rastreo en X-Ray. Cuando habilita el rastreo activo en la
Lambda consola, Lambda agrega los permisos necesarios al rol de ejecución (p. 33) de la función. De lo
contrario, agregue la política AWSXRayDaemonWriteAccess al rol de ejecución.
X-Ray aplica un algoritmo de muestreo para garantizar que el rastreo sea eficiente, al tiempo que
proporciona una muestra representativa de las solicitudes a las que sirve la aplicación. La regla de
muestreo predeterminada es 1 solicitud por segundo y un 5 por ciento de las solicitudes adicionales.
Cuando el rastreo activo está habilitado, Lambda registra el rastreo de un subconjunto de invocaciones.
Lambda registra dos segmentos, lo que crea dos nodos en el mapa de servicio. El primer nodo representa
el servicio de Lambda que recibe la solicitud de invocación. El tiempo de ejecución (p. 19) de la función
registra el segundo nodo.
Puede instrumentar su código de función para registrar metadatos y rastrear llamadas descendentes. Para
registrar detalles sobre las llamadas que realiza su función a otros recursos y servicios, use el SDK de X-
Ray para .NET. Para obtener el SDK, agregue los paquetes AWSXRayRecorder al archivo de proyecto.
Example src/blank-csharp/blank-csharp.csproj
<Project Sdk="Microsoft.NET.Sdk">
<PropertyGroup>
<TargetFramework>netcoreapp3.1</TargetFramework>
<GenerateRuntimeConfigurationFiles>true</GenerateRuntimeConfigurationFiles>
<AWSProjectType>Lambda</AWSProjectType>
</PropertyGroup>
<ItemGroup>
<PackageReference Include="Newtonsoft.Json" Version="12.0.3" />
<PackageReference Include="Amazon.Lambda.Core" Version="1.1.0" />
<PackageReference Include="Amazon.Lambda.SQSEvents" Version="1.1.0" />
<PackageReference Include="Amazon.Lambda.Serialization.Json" Version="1.7.0" />
<PackageReference Include="AWSSDK.Core" Version="3.3.104.38" />
<PackageReference Include="AWSSDK.Lambda" Version="3.3.108.11" />
<PackageReference Include="AWSXRayRecorder.Core" Version="2.6.2" />
<PackageReference Include="AWSXRayRecorder.Handlers.AwsSdk" Version="2.7.2" />
</ItemGroup>
</Project>
451
AWS Lambda Guía para desarrolladores
Habilitación del seguimiento activo con la API de Lambda
En el ejemplo siguiente se muestra un seguimiento con 2 segmentos. Ambos se llaman my-function, pero
uno es tipo AWS::Lambda y el otro es AWS::Lambda::Function. El segmento de función se expande
para mostrar sus subsegmentos.
El primer segmento representa la solicitud de invocación procesada por el servicio Lambda. El segundo
segmento registra el trabajo realizado por la función. El segmento de la función tiene 3 subsegmentos.
También puede instrumentar clientes HTTP, registrar consultas SQL y crear subsegmentos personalizados
con anotaciones y metadatos. Para obtener más información, consulte SDK de X-Ray para .NET en Guía
para desarrolladores de AWS X-Ray.
Secciones
• Habilitación del seguimiento activo con la API de Lambda (p. 452)
• Habilitación del seguimiento activo con AWS CloudFormation (p. 453)
El siguiente comando de la AWS CLI de ejemplo habilita el rastreo activo en una función llamada «my-
function».
452
AWS Lambda Guía para desarrolladores
Habilitación del seguimiento
activo con AWS CloudFormation
--tracing-config Mode=Active
El modo de seguimiento forma parte de la configuración específica de la versión, que se bloquea cuando
se publica una versión de la función. No se puede cambiar el modo de seguimiento de una versión
publicada.
Resources:
function:
Type: AWS::Lambda::Function
Properties:
TracingConfig:
Mode: Active
...
Resources:
function:
Type: AWS::Serverless::Function
Properties:
Tracing: Active
...
453
AWS Lambda Guía para desarrolladores
Entorno de desarrollo
Runtimes de .NET
Note
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.
• blank-powershell: una función de PowerShell que muestra el uso de registro, las variables de
entorno y el SDK de AWS.
Antes de comenzar, primero debe configurar un entorno de desarrollo de PowerShell. Para obtener
instrucciones al respecto, consulte Configuración del entorno de desarrollo de PowerShell (p. 454).
Para obtener más información sobre cómo utilizar el módulo AWSLambdaPSCore para descargar
proyectos de muestra de PowerShell a partir de plantillas, cómo crear paquetes de implementación de
PowerShell y cómo implementar funciones de PowerShell en la nube de AWS, consulte Paquete de
implementación de AWS Lambda en PowerShell (p. 455).
Temas
• Configuración del entorno de desarrollo de PowerShell (p. 454)
• Paquete de implementación de AWS Lambda en PowerShell (p. 455)
• Controlador de funciones de AWS Lambda en PowerShell (p. 457)
• Objeto context de AWS Lambda en PowerShell (p. 458)
• Registro de funciones AWS Lambda en PowerShell (p. 458)
• Errores de la función AWS Lambda en PowerShell. (p. 462)
454
AWS Lambda Guía para desarrolladores
Paquete de implementación
4. (Opcional) Instale Herramientas de AWS para PowerShell – Puede instalar la versión de AWS.Tools
modularizada o AWSPOwerShell.NetCore de un solo módulo en PowerShell Core 6.0 para utilizar
la API de Lambda dentro de su entorno de PowerShell. Para obtener instrucciones, consulte la
instalación de Herramientas de AWS para PowerShell.
El módulo AWSLambdaPSCore tiene los siguientes nuevos cmdlets para ayudarle a crear y publicar las
funciones de Lambda para PowerShell.
AWSLambdaPSCore Cmdlets
Para que le resulte más fácil empezar a escribir e invocar un script de PowerShell con Lambda, puede
utilizar el cmdlet New-AWSPowerShellLambda para crear un script de inicio basado en una plantilla.
Puede utilizar el cmdlet Publish-AWSPowerShellLambda para implementar su script en AWS Lambda.
A continuación, puede probar el script ya sea a través de la línea de comandos o de la consola.
Para crear un nuevo script de PowerShell, cargarlo y probarlo, siga este procedimiento:
PS C:\> Get-AWSPowerShellLambdaTemplate
Template Description
-------- -----------
Basic Bare bones script
455
AWS Lambda Guía para desarrolladores
Paquete de implementación
2. Ejecute el siguiente comando para crear un script de muestra basado en la plantilla Basic:
3. Para ver cómo se envían los mensajes de registro desde su secuencia de comandos de PowerShell a
CloudWatch Logs, anule el comentario de la línea Write-Host del script de muestra.
Para demostrar cómo puede devolver los datos de sus funciones de Lambda, añada una nueva línea
al final del script con $PSVersionTable. Esto añadirá $PSVersionTable a la canalización de
PowerShell. Una vez que el script de PowerShell se ha completado, el último objeto en la canalización
de PowerShell son los datos de devolución de la función de Lambda. $PSVersionTable es una
variable global de PowerShell que también proporciona información sobre el entorno en ejecución.
Después de realizar estos cambios, las dos últimas líneas del script de muestra tienen un aspecto
similar al siguiente:
Tenga en cuenta que el parámetro -Name especifica el nombre de la función de Lambda, que aparece
en la consola de Lambda. Puede utilizar esta función para invocar manualmente a su script.
5. Invoque su función con el comando invoke de la CLI de AWS.
456
AWS Lambda Guía para desarrolladores
Controlador
• $ LambdaInput: un PSObject que contiene la entrada al controlador. Esta entrada puede estar
formada por datos de eventos (publicados por un origen de eventos) o por una entrada personalizada
que proporcione, como una cadena o cualquier objeto de datos personalizado.
• $LambdaContext: un objeto Amazon.Lambda.Core.ILambdaContext que puede utilizar para obtener
acceso a información sobre la ejecución actual, como el nombre de la función actual, el límite de
memoria, el tiempo de ejecución restante y el registro.
Es necesario que utilice la instrucción #Requires dentro de sus scripts de PowerShell para
indicar los módulos de los que dependen los scripts. Esta instrucción realiza dos tareas
importantes. 1) Comunica a otros desarrolladores los módulos que utiliza el script; y 2) identifica
los módulos dependientes que necesitan las herramientas de AWS PowerShell para incluir
en el paquete con el script, como parte de la implementación. Para obtener más información
sobre la instrucción #Requires en PowerShell, consulte Acerca de los requisitos. Para obtener
más información sobre los paquetes de implementación de PowerShell, consulte Paquete de
implementación de AWS Lambda en PowerShell (p. 455).
Si su función de Lambda para PowerShell utiliza los cmdlets de AWS PowerShell,
asegúrese de establecer una instrucción #Requires que haga referencia al módulo
AWSPowerShell.NetCore, que admite PowerShell Core y no el módulo AWSPowerShell, que
solo admite Windows PowerShell. Además, asegúrese de utilizar la versión 3.3.270.0 o posterior
de AWSPowerShell.NetCore, que optimiza el proceso de importación del cmdlet. Si utiliza una
versión anterior, experimentará unos arranques en frío más largos. Para obtener más información,
consulte Herramientas de AWS para PowerShell.
Devolución de datos
Algunas invocaciones Lambda están destinadas a devolver los datos a su intermediario. Por ejemplo, si
una invocación se hizo en respuesta a una solicitud web procedente de API Gateway, entonces nuestra
función de Lambda debe devolver la respuesta. Para PowerShell Lambda, el último objeto que se añade a
la canalización de PowerShell son los datos de devolución de la invocación de Lambda. Si el objeto es una
cadena, los datos se devuelven tal cual. De lo contrario, el objeto se convierte en JSON mediante el uso
del cmdlet ConvertTo-Json.
$PSVersionTable
457
AWS Lambda Guía para desarrolladores
Contexto
Una vez que el script de PowerShell ha finalizado, el último objeto en la canalización de PowerShell son los
datos de devolución de la función de Lambda. $PSVersionTable es una variable global de PowerShell
que también proporciona información sobre el entorno en ejecución.
Propiedades de context
El siguiente fragmento de código PowerShell muestra una función de controlador sencilla que imprime
parte de la información de contexto.
Para generar registros desde el código de su función, puede usar cmdlets en Microsoft.PowerShell.Utility o
en cualquier módulo de registro que escriba en stdout o en stderr. El siguiente ejemplo utiliza Write-
Host.
458
AWS Lambda Guía para desarrolladores
Registro
El tiempo de ejecución de .NET registra las líneas START, END y REPORT de cada invocación. La línea del
informe proporciona los siguientes detalles.
Registro de informes
459
AWS Lambda Guía para desarrolladores
Visualización de registros en la
Consola de administración de AWS
Puede ver los registros en la consola de Lambda o en la de CloudWatch Logs, o bien en la línea de
comandos.
Secciones
• Visualización de registros en la Consola de administración de AWS (p. 460)
• Mediante AWS CLI (p. 460)
• Eliminación de registros (p. 462)
Cada flujo de registro se corresponde con una instancia de su función (p. 132). Los nuevos flujos aparecen
cuando se actualiza la función y cuando se crean más instancias para atendar varias invocaciones
simultáneas. Para buscar los registros de invocaciones específicas, puede instrumentar la función con
X-Ray y registrar los detalles sobre el flujo de registro y la solicitud en el registro de seguimiento. Para
obtener una aplicación de ejemplo que correlacione registros y rastros de seguimiento con X-Ray, consulte
Aplicación de ejemplo de procesamiento de errores para AWS Lambda (p. 323).
460
AWS Lambda Guía para desarrolladores
Mediante AWS CLI
La utilidad base64 está disponible en Linux, MacOS y Ubuntu en Windows. Para el sistema operativo
macOS, el comando es base64 -D.
Para obtener eventos de registro completos desde la línea de comandos, puede incluir el nombre del
flujo de registros en la salida de la función, como se muestra en el ejemplo anterior. El siguiente script de
ejemplo invoca una función denominada my-function y descarga los últimos cinco eventos de registro.
#!/bin/bash
aws lambda invoke --function-name my-function --payload '{"key": "value"}' out
sed -i'' -e 's/"//g' out
sleep 15
aws logs get-log-events --log-group-name /aws/lambda/my-function --log-stream-name $(cat
out) --limit 5
El script utiliza sed para eliminar las comillas del archivo de salida y permanece inactivo durante
15 segundos para dar tiempo a que los registros estén disponibles. La salida incluye la respuesta de
Lambda y la salida del comando get-log-events.
$ ./get-logs.sh
{
"StatusCode": 200,
"ExecutedVersion": "$LATEST"
}
{
"events": [
{
"timestamp": 1559763003171,
"message": "START RequestId: 4ce9340a-b765-490f-ad8a-02ab3415e2bf Version:
$LATEST\n",
"ingestionTime": 1559763003309
},
{
"timestamp": 1559763003173,
"message": "2019-06-05T19:30:03.173Z\t4ce9340a-b765-490f-ad8a-02ab3415e2bf
\tINFO\tENVIRONMENT VARIABLES\r{\r \"AWS_LAMBDA_FUNCTION_VERSION\": \"$LATEST\",\r ...",
"ingestionTime": 1559763018353
},
{
"timestamp": 1559763003173,
"message": "2019-06-05T19:30:03.173Z\t4ce9340a-b765-490f-ad8a-02ab3415e2bf
\tINFO\tEVENT\r{\r \"key\": \"value\"\r}\n",
"ingestionTime": 1559763018353
},
{
"timestamp": 1559763003218,
"message": "END RequestId: 4ce9340a-b765-490f-ad8a-02ab3415e2bf\n",
"ingestionTime": 1559763018353
},
{
"timestamp": 1559763003218,
"message": "REPORT RequestId: 4ce9340a-b765-490f-ad8a-02ab3415e2bf\tDuration:
26.73 ms\tBilled Duration: 100 ms \tMemory Size: 128 MB\tMax Memory Used: 75 MB\t\n",
"ingestionTime": 1559763018353
}
],
"nextForwardToken": "f/34783877304859518393868359594929986069206639495374241795",
"nextBackwardToken": "b/34783877303811383369537420289090800615709599058929582080"
}
461
AWS Lambda Guía para desarrolladores
Eliminación de registros
Eliminación de registros
Los grupos de registros no se eliminan automáticamente al eliminar una función. Para evitar los registros
de almacenamiento de forma indefinida, elimine el grupo de registros o configure un periodo de retención
después del cual los registros se eliminarán automáticamente.
Al invocar esta función de Lambda, se genera un error de terminación y AWS Lambda devuelve el
siguiente mensaje de error:
{
"errorMessage": "The Account is not found",
"errorType": "RuntimeException"
}
{
"errorMessage": "The Account is not found",
"errorType": "AccountNotFound"
}
Si no necesita un mensaje de error, puede generar una cadena con el formato de un código de error. El
formato de código de error requiere que la cadena empiece con un carácter y solo contenga letras y dígitos
a continuación, sin espacios ni símbolos.
throw 'AccountNotFound'
{
"errorMessage": "AccountNotFound",
"errorType": "AccountNotFound"
}
462
AWS Lambda Guía para desarrolladores
Monitorización y solución de
problemas de aplicaciones basadas
en Lambda
AWS Lambda monitoriza automáticamente funciones Lambda en su nombre e informa sobre las métricas
a través de Amazon CloudWatch. Para ayudarle a monitorizar el código mientras se ejecuta, Lambda
controla automáticamente el número de solicitudes, la duración de la ejecución por solicitud y el número de
solicitudes que generan un error. También publica las métricas de CloudWatch asociadas. Puede utilizar
estas métricas para configurar alarmas personalizadas de CloudWatch.
La consola Lambda proporciona un panel de monitorización (p. 464) integrado para cada una de sus
funciones y aplicaciones.
Precios
CloudWatch tiene una capa gratuita perpetua Más allá del umbral de capa gratuita, CloudWatch
hace cargos por métricas, paneles, alarmas, registros e información. Consulte Precios de
CloudWatch para obtener más información.
Cada vez que se invoca la función, Lambda registra métricas (p. 464) de la solicitud, la respuesta
de la función y el estado general de la función. Puede utilizar métricas para establecer alarmas que se
activan cuando el rendimiento de la función se degrada o cuando esté cerca de alcanzar los límites de
concurrencia en la región actual.
Para depurar y validar que el código funciona como se esperaba, puede generar registros con la
funcionalidad de registro estándar para el lenguaje de programación. El tiempo de ejecución de Lambda
carga la salida de registro de su función en CloudWatch Logs. Puede ver los registros (p. 467) en la
consola de CloudWatch Logs o en la de Lambda, o bien en la línea de comandos.
Además de supervisar registros y métricas en CloudWatch, puede utilizar AWS X-Ray para rastrear y
depurar solicitudes atendidas por la aplicación. Para obtener más información, consulte Uso de AWS
Lambda con AWS X-Ray (p. 311).
Secciones
• Monitorización de funciones en la consola de AWS Lambda (p. 464)
• Trabajar con métricas de funciones de AWS Lambda (p. 464)
• Acceso a los registros de Amazon CloudWatch para AWS Lambda (p. 467)
463
AWS Lambda Guía para desarrolladores
Consola de administración
• Invocations (Invocaciones): el número de veces que se invocó la función en cada período de 5 minutos.
• Duration (Duración): los tiempos promedio, mínimo y máximo de ejecución.
• Error count and success rate (%) (Número de errores y tasa de éxito (%)): el número de errores y el
porcentaje de ejecuciones completadas sin errores.
• Throttles (Limitaciones): el número de veces que se produjo un error en la ejecución debido a los límites
de simultaneidad.
• IteratorAge: en los orígenes de eventos de flujo, la antigüedad del último elemento del lote cuando
Lambda lo recibe e invoca la función.
• Errores de entrega asincrónicos: Número de errores que se produjeron cuando Lambda intentó escribir
en una cola de mensajes fallidos o destino.
• Ejecuciones simultáneas: Número de instancias de función que están procesando eventos.
Para ver la definición de un gráfico en CloudWatch, elija View in metrics (Ver en métricas) en el menú de
la parte superior derecha del gráfico. Para obtener más información acerca de las métricas que Lambda
registra, consulte Trabajar con métricas de funciones de AWS Lambda (p. 464).
La consola también muestra los informes de CloudWatch Logs Insights compilados a partir de información
en sus registros de función. Puede añadir estos informes a un panel personalizado en la consola de
CloudWatch Logs. Utilice las consultas como punto de partida para sus propios informes.
Para ver una consulta, elija View en CloudWatch Logs Insights (Ver en CloudWatch Logs Insights) en el
menú de la parte superior derecha del informe.
1. Abra la página Metrics (métricas) de la consola de Amazon CloudWatch (espacio de nombres AWS/
Lambda).
464
AWS Lambda Guía para desarrolladores
Uso de métricas de invocación
• Por nombre de función (FunctionName): ver métricas agregadas de todas las versiones y alias de
una función.
• Por recurso (Resource): ver las métricas de una versión o el alias de una función.
• Por versión ejecutada (ExecutedVersion): ver métricas para una combinación de alias y versión.
Utilice la dimensión ExecutedVersion para comparar las tasas de error de dos versiones de una
función que son objetivos de un alias ponderado (p. 72).
• En todas las funciones (ninguna): ver métricas agregadas de todas las funciones de la región de
AWS actual.
3. Elija métricas para agregarlas al gráfico.
De forma predeterminada, los gráficos utilizan la estadística Sum para todas las métricas. Para elegir una
estadística diferente y personalizar el gráfico, utilice las opciones de la pestaña Métricas Gráficas .
La marca temporal de una métrica refleja cuándo se invocó la función. Dependiendo de la duración de la
ejecución, esto puede ser varios minutos antes de la emisión de la métrica. Si, por ejemplo, su función
tiene un tiempo de espera de 10 minutos, busque más de 10 minutos en el pasado para obtener métricas
precisas.
Para obtener más información acerca de CloudWatch, consulte la Guía del usuario de Amazon
CloudWatch.
Secciones
• Uso de métricas de invocación (p. 465)
• Uso de métricas de desempeño (p. 466)
• Uso de métricas de simultaneidad (p. 466)
Métricas de invocación
• Invocations: el número de veces que se ejecuta el código de función, incluidas las ejecuciones
exitosas y las ejecuciones que dan lugar a un error de función. Las invocaciones no se registran si la
solicitud de invocación se limita o da lugar a un error de invocación (p. 589). Esto equivale al número
de solicitudes facturadas.
• Errors: el número de invocaciones que dan lugar a un error de función. Los errores de función
incluyen excepciones lanzadas por su código y excepciones lanzadas por el tiempo de ejecución de
Lambda. El motor de ejecución devuelve errores para problemas como tiempos de espera y errores de
configuración. Para calcular la tasa de error, divida el valor de Errors por el valor de Invocations.
• DeadLetterErrors: para la invocación asíncrona (p. 101), el número de veces que Lambda intenta
enviar un evento a una cola de mensajes fallidos pero falla. Pueden producirse errores de mensaje
fallido debido a errores de permisos, recursos mal configurados o límites de tamaño.
• DestinationDeliveryFailures: para la invocación asíncrona, el número de veces que Lambda
intenta enviar un evento a un destino (p. 27) pero falla. Pueden producirse errores de entrega debido a
errores de permisos, recursos mal configurados o límites de tamaño.
465
AWS Lambda Guía para desarrolladores
Uso de métricas de desempeño
• Throttles: el número de solicitudes de invocación que se han limitado. Cuando todas las instancias
de función están procesando solicitudes y no hay concurrencia disponible para escalar, Lambda rechaza
solicitudes adicionales con TooManyRequestsException (p. 589). Las solicitudes aceleradas y otros
errores de invocación no cuentan como Invocations o Errors.
• ProvisionedConcurrencyInvocations: el número de veces que su código de función se ejecuta
en concurrencia aprovisionada (p. 62).
• ProvisionedConcurrencySpilloverInvocations: el número de veces que su código de función
se ejecuta en concurrencia estándar cuando toda concurrencia aprovisionada está en uso.
Métricas de desempeño
• Duration: la cantidad de tiempo que el código de función pasa procesando un evento. Para el primer
evento procesado por una instancia de su función, esto incluye el tiempo de inicialización (p. 20). La
duración facturada de una invocación es el valor de Duration redondeado hacia arriba a los 100
milisegundos más cercanos.
• IteratorAge: para las asignaciones de origen de eventos (p. 109) que leen desde secuencias, la
antigüedad del último registro del evento. La antigüedad es la cantidad de tiempo entre cuando la
secuencia recibe el registro y cuando la asignación de origen de eventos envía el evento a la función.
Duration también admite estadísticas percentiles. Utilice percentiles para excluir valores atípicos que
sesgan las estadísticas medias y máximas. Por ejemplo, la estadística P95 muestra la duración máxima
del 95 por ciento de las ejecuciones, excluyendo el 5 por ciento más lento.
Métricas de simultaneidad
466
AWS Lambda Guía para desarrolladores
Registros de CloudWatch
Puede introducir instrucciones de registro en el código comprobar que el código está funcionando según lo
previsto. Lambda se integra automáticamente con CloudWatch Logs y envía todos los registros generados
por el código a un grupo de CloudWatch Logs asociado a una función de Lambda, denominada /aws/
lambda/<nombre de la función>. Para obtener más información acerca de los grupos de registros
y cómo acceder a ellos a través de la consola de CloudWatch, consulte Monitorización del sistema, la
aplicación y los archivos de registro personalizados en la Guía del usuario de Amazon CloudWatch.
Puede ver los registros de Lambda mediante la consola de Lambda, la consola de CloudWatch, la AWS
CLI o la API de CloudWatch. El siguiente procedimiento muestra cómo ver los registros utilizando la
consola de Lambda.
Note
No se aplican cargos adicionales por utilizar los registros de Lambda; no obstante, sí se aplican
los cargos estándar de CloudWatch Logs. Para obtener más información, consulte los precios de
CloudWatch.
467
AWS Lambda Guía para desarrolladores
Registros de CloudWatch
Lambda utiliza los permisos de la función para cargar los registros en CloudWatch Logs. Si no ve registros
en la consola, compruebe los permisos del rol de ejecución (p. 33).
468
AWS Lambda Guía para desarrolladores
Protección de los datos
Esta documentación le ayuda a comprender cómo aplicar el modelo de responsabilidad compartida cuando
se utiliza Lambda. En los siguientes temas, se le mostrará cómo configurar Lambda para satisfacer sus
objetivos de seguridad y conformidad. También puede aprender a utilizar otros servicios de AWS que le
ayudan a supervisar y proteger sus recursos de Lambda.
Temas
• Protección de los datos en AWS Lambda (p. 469)
• Administración de identidad y acceso en AWS Lambda (p. 471)
• Validación de la conformidad de AWS Lambda (p. 479)
• Resiliencia de AWS Lambda (p. 479)
• Seguridad de la infraestructura en AWS Lambda (p. 480)
• Configuración y análisis de vulnerabilidades en AWS Lambda (p. 481)
Para fines de protección de datos, le recomendamos proteger las credenciales de la cuenta de AWS y
configurar cuentas de usuario individuales con AWS Identity and Access Management (IAM), de modo que
a cada usuario se le concedan únicamente los permisos necesarios para llevar a cabo su trabajo. También
le recomendamos proteger sus datos de las siguientes formas:
469
AWS Lambda Guía para desarrolladores
Cifrado en tránsito
• Utilice las soluciones de cifrado de AWS, junto con todos los controles de seguridad predeterminados
dentro de los servicios de AWS.
• Utilice los servicios de seguridad administrados avanzados como, por ejemplo, Amazon Macie, que
ayudan a detectar y proteger los datos personales almacenados en Amazon S3.
Para obtener más información sobre la protección de datos, consulte la entrada de blog relativa al modelo
de responsabilidad compartida de AWS y GDPR en el blog de seguridad de AWS.
Secciones
• Cifrado en tránsito (p. 470)
• Cifrado en reposo (p. 470)
Cifrado en tránsito
Los puntos de enlace de API de Lambda solo admiten conexiones seguras a través de HTTPS. Al
administrar recursos de Lambda con el SDK de AWS de Consola de administración de AWS o la API de
Lambda, todas las comunicaciones se cifran con Transport Layer Security (TLS).
Cuando conecta su función a un sistema de archivos (p. 91), Lambda utiliza Cifrado en tránsito para todas
las conexiones.
Para obtener una lista completa de los puntos de enlace de API, consulte Regiones y puntos de enlace de
AWS en la AWS General Reference.
Cifrado en reposo
Puede utilizar las variables de entorno para almacenar claves secretas de forma segura para su uso con
funciones de Lambda. Lambda cifra siempre las variables de entorno en reposo.
Además, puede utilizar las siguientes características para personalizar la forma en que se cifran las
variables de entorno.
• Configuración de clave: en una base por función, puede configurar – Lambda para utilizar una clave de
cifrado que se crea y administra en AWS Key Management Service. Estas operaciones se denominan
claves maestras de cliente administradas por el cliente (CMK) o claves administradas por el cliente. Si
no configura una clave administrada por el cliente, Lambda usa una CMK administrada por AWS llamada
aws/lambda, que Lambda crea en su cuenta.
• Ayudantes de cifrado: la consola de – Lambda le permite cifrar los valores de variables de entorno del
lado del cliente, antes de enviarlos a Lambda. Esto mejora aún más seguridad evitando que los secretos
aparezcan sin cifrar en la consola de Lambda, o en la configuración de la función que devuelve la API
de Lambda. La consola también proporciona el código de muestra que puede adaptar para descifrar los
valores en el controlador de la función.
Para obtener más información, consulte Uso de variables de entorno de AWS Lambda (p. 56).
Lambda siempre cifra los archivos que carga en Lambda, incluidos los paquetes de implementación (p. 22)
y los archivos de capas (p. 76).
470
AWS Lambda Guía para desarrolladores
Administración de identidades y accesos
Amazon CloudWatch Logs y AWS X-Ray también cifran los datos de manera predeterminada y se pueden
configurar para utilizar una clave administrada por el cliente. Para obtener más información, consulte Cifrar
datos de registro en CloudWatch Logs y Protección de los datos en AWS X-Ray.
Temas
• Público (p. 471)
• Autenticación con identidades (p. 471)
• Administración de acceso mediante políticas (p. 473)
• Cómo funciona AWS Lambda con IAM (p. 475)
• Ejemplos de políticas basadas en identidades de AWS Lambda (p. 475)
• Solucionar problemas de identidad y acceso en AWS Lambda (p. 477)
Público
La forma en que utilice AWS Identity and Access Management (IAM) difiere, en función del trabajo que
realice en Lambda.
Usuario de servicio: si utiliza el servicio Lambda para realizar su trabajo, su administrador le proporciona
las credenciales y los permisos que necesita. A medida que utilice más características de Lambda
para realizar su trabajo, es posible que necesite permisos adicionales. Entender cómo se administra
el acceso puede ayudarle a solicitar los permisos correctos a su administrador. Si no puede acceder
a una característica en Lambda, consulte Solucionar problemas de identidad y acceso en AWS
Lambda (p. 477).
Administrador de servicio: si está a cargo de los recursos de Lambda en su empresa, probablemente tenga
acceso completo a Lambda. Su trabajo consiste en determinar qué a características y recursos de Lambda
deben acceder sus empleados. A continuación, debe enviar solicitudes a su administrador de IAM para
cambiar los permisos de los usuarios de su servicio. Revise la información de esta página para conocer los
conceptos básicos de IAM. Para obtener más información sobre cómo su empresa puede utilizar IAM con
Lambda, consulte Cómo funciona AWS Lambda con IAM (p. 475).
Administrator de IAM: si es un administrador de IAM, es posible que quiera conocer información sobre
cómo escribir políticas para administrar el acceso a Lambda. Para ver ejemplos de políticas basadas en la
identidad de Lambda que puede utilizar en IAM, consulte Ejemplos de políticas basadas en identidades de
AWS Lambda (p. 475).
Debe estar autenticado (haber iniciado sesión en AWS) como Usuario de la cuenta raíz de AWS, usuario
de IAM o asumiendo un rol de IAM. También puede utilizar la autenticación de inicio de sesión único de
471
AWS Lambda Guía para desarrolladores
Autenticación con identidades
su empresa o incluso iniciar sesión con Google o Facebook. En estos casos, su administrador habrá
configurado previamente la federación de identidad mediante roles de IAM. Cuando obtiene acceso a AWS
mediante credenciales de otra empresa, asume un rol indirectamente.
Para iniciar sesión directamente en la Consola de administración de AWS, use su contraseña con su
correo electrónico usuario raíz o su nombre de usuario de IAM. Puede obtener acceso a AWS mediante
programación utilizando sus claves de acceso usuario raíz o de usuario de IAM. AWS proporciona SDK y
herramientas de línea de comandos para firmar criptográficamente su solicitud con sus credenciales. Si no
utiliza las herramientas de AWS, debe firmar usted mismo la solicitud. Para ello, utilice Signature Version
4, un protocolo para autenticar solicitudes de API de entrada. Para obtener más información acerca de la
autenticación de solicitudes, consulte Proceso de firma Signature Version 4 en la AWS General Reference.
Independientemente del método de autenticación que utilice, es posible que también deba proporcionar
información de seguridad adicional. Por ejemplo, AWS le recomienda el uso de la autenticación multifactor
(MFA) para aumentar la seguridad de su cuenta. Para obtener más información, consulte Uso de Multi-
Factor Authentication (MFA) en AWS en la Guía del usuario de IAM.
Un grupo de IAM es una identidad que especifica un conjunto de usuarios de IAM. No puede iniciar sesión
como grupo. Puede usar los grupos para especificar permisos para varios usuarios a la vez. Los grupos
facilitan la administración de los permisos de grandes conjuntos de usuarios. Por ejemplo, podría tener un
grupo cuyo nombre fuese Administradores de IAM y conceder permisos a dicho grupo para administrar los
recursos de IAM.
Los usuarios son diferentes de los roles. Un usuario se asocia exclusivamente a una persona o aplicación,
pero la intención es que cualquier usuario pueda asumir un rol que necesite. Los usuarios tienen
credenciales permanentes a largo plazo y los roles proporcionan credenciales temporales. Para obtener
más información, consulte Cuándo crear un usuario de IAM (en lugar de un rol) en la Guía del usuario de
IAM.
Roles de IAM
Un rol de IAM es una entidad de la cuenta de AWS que dispone de permisos específicos. Es similar a
un usuario de IAM, pero no está asociado a una determinada persona. Puede asumir temporalmente un
rol de IAM en la Consola de administración de AWS cambiando de roles. Puede asumir un rol llamando
a una operación de la AWS CLI o de la API de AWS, o utilizando una URL personalizada. Para obtener
más información acerca de los métodos para el uso de roles, consulte Uso de roles de IAM en la Guía del
usuario de IAM.
472
AWS Lambda Guía para desarrolladores
Administración de acceso mediante políticas
Los roles de IAM con credenciales temporales son útiles en las siguientes situaciones:
• Permisos de usuario temporales de IAM: un usuario de IAM puede asumir un rol de IAM para recibir
temporalmente permisos distintos que le permitan realizar una tarea concreta.
• Acceso de usuario federado: En lugar de crear un usuario de IAM, puede utilizar identidades existentes
de AWS Directory Service, del directorio de usuarios de la empresa o de un proveedor de identidades
web. A estas identidades se les llama usuarios federados. AWS asigna una función a un usuario
federado cuando se solicita acceso a través de un proveedor de identidad. Para obtener más
información acerca de los usuarios federados, consulte Usuarios federados y roles en la Guía del
usuario de IAM.
• Acceso entre cuentas: puede utilizar un rol de IAM para permitir que alguien (una entidad principal de
confianza) de otra cuenta obtenga acceso a los recursos de su cuenta. Los roles son la forma principal
de conceder acceso entre cuentas. Sin embargo, con algunos servicios de AWS, puede asociar una
política directamente a un recurso (en lugar de utilizar un rol como proxy). Para obtener información
acerca de la diferencia entre los roles y las políticas basadas en recursos para el acceso entre cuentas,
consulte Cómo los roles de IAM difieren de las políticas basadas en recursos en la Guía del usuario de
IAM.
• Acceso a servicios de AWS: Un rol de servicio es un rol de IAM que un servicio asume para realizar
acciones en su cuenta en su nombre. Al configurar algunos de los entornos de los servicios de AWS,
debe definir un rol que el servicio asumirá. Este rol de servicio debe incluir todos los permisos que
son necesarios para que el servicio pueda acceder a los recursos de AWS que necesita. Los roles de
servicio varían de servicio a servicio, pero muchos le permiten elegir sus permisos, siempre y cuando
se cumplan los requisitos documentados para dicho servicio. Los roles de servicio ofrecen acceso solo
dentro de su cuenta y no se pueden utilizar para otorgar acceso a servicios en otras cuentas. Puede
crear, modificar y eliminar un rol de servicio desde IAM. Por ejemplo, puede crear un rol que permita
a Amazon Redshift tener acceso a un bucket de Amazon S3 en su nombre y, a continuación, cargar
los datos de ese bucket en un clúster de Amazon Redshift. Para obtener más información, consulte
Creación de un rol para delegar permisos a un servicio de AWS en la Guía del usuario de IAM.
• Aplicaciones que se ejecutan en Amazon EC2: Puede utilizar un rol de IAM para administrar
credenciales temporales para las aplicaciones que se ejecutan en una instancia EC2 y realizan
solicitudes de la AWS CLI o la API de AWS. Es preferible hacerlo de este modo a almacenar claves de
acceso en la instancia EC2. Para asignar un rol de AWS a una instancia EC2 y ponerla a disposición de
todas las aplicaciones, cree un perfil de instancia asociado a la misma. Un perfil de instancia contiene el
rol y permite a los programas que se ejecutan en la instancia EC2 obtener credenciales temporales. Para
obtener más información, consulte Uso de un rol de IAM para conceder permisos a aplicaciones que se
ejecutan en instancias Amazon EC2 en la Guía del usuario de IAM.
Para obtener información acerca del uso de los roles de IAM, consulte Cuándo crear un rol de IAM (en vez
de un usuario) en la Guía del usuario de IAM.
Un administrador de IAM puede utilizar las políticas para especificar quién tiene acceso a los recursos de
AWS y qué acciones se pueden realizar en dichos recursos. Cada entidad de IAM (usuario o rol) comienza
sin permisos. En otras palabras, de forma predeterminada, los usuarios no pueden hacer nada, ni siquiera
cambiar sus propias contraseñas. Para conceder permiso a un usuario para hacer algo, el administrador
debe asociarle una política de permisos. O bien el administrador puede añadir al usuario a un grupo que
473
AWS Lambda Guía para desarrolladores
Administración de acceso mediante políticas
tenga los permisos necesarios. Cuando el administrador concede permisos a un grupo, todos los usuarios
de ese grupo obtienen los permisos.
Las políticas de IAM definen permisos para una acción independientemente del método que se utilice
para realizar la operación. Por ejemplo, suponga que dispone de una política que permite la acción
iam:GetRole. Un usuario con dicha política puede obtener información del usuario de la Consola de
administración de AWS, la AWS CLI o la API de AWS.
Las políticas basadas en identidad pueden clasificarse además como políticas insertadas o políticas
administradas. Las políticas insertadas se integran directamente en un único usuario, grupo o rol. Las
políticas administradas son políticas independientes que puede asociar a varios usuarios, grupos y roles
de su cuenta de AWS. Las políticas administradas incluyen las políticas administradas por AWS y las
políticas administradas por el cliente. Para obtener más información acerca de cómo elegir una política
administrada o una política insertada, consulte Elegir entre políticas administradas y políticas insertadas en
la Guía del usuario de IAM.
• Límites de permisos: un límite de permisos es una característica avanzada que le permite definir los
permisos máximos que una política basada en identidad puede conceder a una entidad de IAM (usuario
o rol de IAM). Puede establecer un límite de permisos para una identidad. Los permisos resultantes son
la intersección de las políticas basadas en identidades de la entidad y los límites de sus permisos. Las
políticas basadas en recursos que especifiquen el usuario o rol en el campo Principal no estarán
restringidas por el límite de permisos. Una denegación explícita en cualquiera de estas políticas anulará
el permiso. Para obtener más información acerca de los límites de permisos, consulte see Límites de
permisos para las entidades de IAM en la Guía del usuario de IAM.
• Políticas de control de servicios (SCP): las SCP son políticas de JSON que especifican los permisos
máximos para una organización o unidad organizativa (OU) en AWS Organizations. AWS Organizations
es un servicio que le permite agrupar y administrar de forma centralizada varias cuentas de AWS
474
AWS Lambda Guía para desarrolladores
Cómo funciona AWS Lambda con IAM
que posee su negocio. Si habilita todas las funciones en una organización, entonces podrá aplicar
políticas de control de servicio (SCP) a una o todas sus cuentas. Una SCP limita los permisos para las
entidades de las cuentas de miembros, incluido cada Usuario de la cuenta raíz de AWS. Para obtener
más información acerca de Organizaciones y las SCP, consulte Funcionamiento de las SCP en la Guía
del usuario de AWS Organizations.
• Políticas de sesión: las políticas de sesión son políticas avanzadas que se pasan como parámetro
cuando se crea una sesión temporal mediante programación para un rol o un usuario federado. Los
permisos de la sesión resultantes son la intersección de las políticas basadas en identidades del rol y las
políticas de la sesión. Los permisos también pueden proceder de una política basada en recursos. Una
denegación explícita en cualquiera de estas políticas anulará el permiso. Para obtener más información,
consulte Políticas de sesión en la Guía del usuario de IAM.
Para obtener información general acerca de los permisos, las políticas y funciones a medida que Lambda
utiliza, consulte Permisos de AWS Lambda (p. 33).
Para obtener más información acerca de cómo crear una política basada en identidad de IAM con estos
documentos de políticas de JSON de ejemplo, consulte Creación de políticas en la pestaña JSON en la
Guía del usuario de IAM.
Temas
• Prácticas recomendadas relativas a políticas (p. 475)
• Mediante la consola de Lambda (p. 476)
• Permitir a los usuarios consultar sus propios permisos (p. 476)
475
AWS Lambda Guía para desarrolladores
Ejemplos de políticas basadas en identidades
• Introducción sobre el uso de políticas administradas de AWS: para comenzar a utilizar Lambda
rápidamente, utilice las políticas administradas de AWS para proporcionar a los empleados los permisos
necesarios. Estas políticas ya están disponibles en su cuenta y las mantiene y actualiza AWS. Para
obtener más información, consulte Introducción sobre el uso de permisos con políticas administradas de
AWS en la Guía del usuario de IAM.
• Conceder privilegios mínimos: al crear políticas personalizadas, conceda solo los permisos necesarios
para llevar a cabo una tarea. Comience con un conjunto mínimo de permisos y conceda permisos
adicionales según sea necesario. Por lo general, es más seguro que comenzar con permisos que son
demasiado tolerantes e intentar hacerlos más severos más adelante. Para obtener más información,
consulte Conceder privilegios mínimos en la Guía del usuario de IAM.
• Habilitar MFA para operaciones confidenciales: para mayor seguridad, obligue a los usuarios de
IAM a que utilicen la autenticación multifactor (MFA) para acceder a recursos u operaciones de API
confidenciales. Para obtener más información, consulte Uso de Multi-Factor Authentication (MFA) en
AWS en la Guía del usuario de IAM.
• Utilizar condiciones de política para mayor seguridad: en la medida en que sea práctico, defina las
condiciones en las que sus políticas basadas en identidad permitan el acceso a un recurso. Por ejemplo,
puede escribir condiciones para especificar un rango de direcciones IP permitidas desde el que debe
proceder una solicitud. También puede escribir condiciones para permitir solicitudes solo en un intervalo
de hora o fecha especificado o para solicitar el uso de SSL o MFA. Para obtener más información,
consulte Elementos de la política de JSON de IAM: condición en la Guía del usuario de IAM.
Para obtener un ejemplo de política que concede un acceso mínimo para el desarrollo de funciones,
consulte Desarrollo de funciones (p. 42). Además de las API de Lambda, la consola de Lambda utiliza
otros servicios para mostrar la configuración de activación y permitir agregar nuevos desencadenadores.
Si sus usuarios usan Lambda con otros servicios, también necesitan acceso a esos servicios. Para obtener
más información sobre cómo configurar otros servicios con Lambda, consulte Utilización de AWS Lambda
con otros servicios (p. 163).
{
"Version": "2012-10-17",
"Statement": [
{
"Sid": "ViewOwnUserInfo",
"Effect": "Allow",
"Action": [
"iam:GetUserPolicy",
"iam:ListGroupsForUser",
"iam:ListAttachedUserPolicies",
"iam:ListUserPolicies",
"iam:GetUser"
],
"Resource": ["arn:aws:iam::*:user/${aws:username}"]
476
AWS Lambda Guía para desarrolladores
Solución de problemas
},
{
"Sid": "NavigateInConsole",
"Effect": "Allow",
"Action": [
"iam:GetGroupPolicy",
"iam:GetPolicyVersion",
"iam:GetPolicy",
"iam:ListAttachedGroupPolicies",
"iam:ListGroupPolicies",
"iam:ListPolicyVersions",
"iam:ListPolicies",
"iam:ListUsers"
],
"Resource": "*"
}
]
}
Temas
• No tengo autorización para realizar una acción en Lambda (p. 477)
• No tengo autorización para realizar la operación iam:PassRole (p. 477)
• Quiero ver mis claves de acceso (p. 478)
• Soy administrador y deseo permitir que otros obtengan acceso a Lambda (p. 478)
• Deseo permitir a personas externas a mi cuenta de AWS el acceso a mis recursos de
Lambda (p. 478)
En el siguiente ejemplo, el error se produce cuando el usuario de IAM, mateojackson intenta utilizar la
consola para ver detalles sobre una función, pero no tiene permisos lambda:GetFunction.
En este caso, Mateo pide a su administrador que actualice sus políticas de forma que pueda obtener
acceso al recurso my-function mediante la acción lambda:GetFunction.
477
AWS Lambda Guía para desarrolladores
Solución de problemas
Algunos servicios de AWS le permiten transferir un rol existente a dicho servicio en lugar de crear un nuevo
rol de servicio o uno vinculado al servicio. Para ello, debe tener permisos para transferir el rol al servicio.
En el siguiente ejemplo, el error se produce cuando un usuario de IAM denominado marymajor intenta
utilizar la consola para realizar una acción en Lambda. Sin embargo, la acción requiere que el servicio
cuente con permisos otorgados por un rol de servicio. Mary no tiene permisos para transferir el rol al
servicio.
En este caso, Mary pide a su administrador que actualice sus políticas para que pueda realizar la acción
iam:PassRole.
Las claves de acceso se componen de dos partes: un ID de clave de acceso (por ejemplo,
AKIAIOSFODNN7EXAMPLE) y una clave de acceso secreta (por ejemplo, wJalrXUtnFEMI/K7MDENG/
bPxRfiCYEXAMPLEKEY). El ID de clave de acceso y la clave de acceso secreta se utilizan juntos, como un
nombre de usuario y contraseña, para autenticar sus solicitudes. Administre sus claves de acceso con el
mismo nivel de seguridad que para el nombre de usuario y la contraseña.
Important
No proporcione las claves de acceso a terceras personas, ni siquiera para que le ayuden a buscar
el ID de usuario canónico. Si lo hace, podría conceder a otra persona acceso permanente a su
cuenta.
Cuando cree un par de claves de acceso, se le pide que guarde el ID de clave de acceso y la clave de
acceso secreta en un lugar seguro. La clave de acceso secreta solo está disponible en el momento de su
creación. Si pierde la clave de acceso secreta, debe añadir nuevas claves de acceso a su usuario de IAM.
Puede tener un máximo de dos claves de acceso. Si ya cuenta con dos, debe eliminar un par de claves
antes de crear uno nuevo. Para ver las instrucciones, consulte Administración de las claves de acceso en
la Guía del usuario de IAM.
Para comenzar de inmediato, consulte Creación del primer grupo y usuario delegado de IAM en la Guía del
usuario de IAM.
478
AWS Lambda Guía para desarrolladores
Validación de la conformidad
En el caso de los servicios que admitan las políticas basadas en recursos o las listas de control de acceso
(ACL), puede utilizar dichas políticas para conceder a las personas acceso a sus recursos.
• Para obtener información acerca de si Lambda admite estas características, consulte Cómo funciona
AWS Lambda con IAM (p. 475).
• Para aprender cómo proporcionar acceso a sus recursos en cuentas de AWS de su propiedad, consulte
Proporcionar acceso a un usuario de IAM a otra cuenta de AWS de la que es propietario en la Guía del
usuario de IAM.
• Para obtener información acerca de cómo ofrecer acceso a sus recursos a cuentas de AWS de terceros,
consulte Proporcionar acceso a las cuentas de AWS propiedad de terceros en la Guía del usuario de
IAM.
• Para obtener información acerca de cómo ofrecer acceso a la identidad federada, consulte Proporcionar
acceso a usuarios autenticados externamente (identidad federada) en la Guía del usuario de IAM.
• Para obtener información acerca de la diferencia entre utilizar los roles y las políticas basadas en
recursos para el acceso entre cuentas, consulte Cómo los roles de IAM difieren de las políticas basadas
en recursos en la Guía del usuario de IAM.
Para obtener una lista de los servicios de AWS en el ámbito de programas de conformidad específicos,
consulte Servicios de AWS en el ámbito del programa de conformidad. Para obtener información general,
consulte Programas de conformidad de AWS.
Puede descargar los informes de auditoría de terceros utilizando AWS Artifact. Para obtener más
información, consulte Descarga de informes en AWS Artifact.
479
AWS Lambda Guía para desarrolladores
Seguridad de la infraestructura
que se encuentran conectadas mediante redes con un alto nivel de rendimiento y redundancia, además
de baja latencia. Con las zonas de disponibilidad, puede diseñar y utilizar aplicaciones y bases de datos
que realizan una conmutación por error automática entre zonas de disponibilidad sin interrupciones. Las
zonas de disponibilidad tienen una mayor disponibilidad, tolerancia a errores y escalabilidad que las
infraestructuras tradicionales de centros de datos únicos o múltiples.
Para obtener más información sobre las zonas de disponibilidad y las regiones de AWS, consulte
Infraestructura global de AWS.
Además de la infraestructura global de AWS, Lambda ofrece varias características que le ayudan con sus
necesidades de resiliencia y copia de seguridad de los datos.
• Control de versiones: Puede utilizar el control de versiones en – Lambda para guardar el código de la
función y la configuración a medida que realice el desarrollo. Junto con los alias, puede utilizar el control
de versiones para realizar implementaciones continuas y blue/green. Para obtener más información,
consulte Versiones de funciones de AWS Lambda (p. 70).
• Escalado:: cuando la función recibe una solicitud mientras se procesa una solicitud anterior, Lambda
lanza otra instancia de su función para administrar el aumento de la carga. Lambda automáticamente
se escala para administrar ejecuciones simultáneas 1,000 por región, una cuota (p. 31) que se puede
aumentar si es necesario. Para obtener más información, consulte Escalado de funciones de AWS
Lambda (p. 114).
• Alta disponibilidad: – Lambda ejecuta la función en varias zonas de disponibilidad para asegurarse de
que está disponible para procesar eventos en caso de una interrupción del servicio en una sola zona.
Si configura la función para conectarse a una nube privada virtual (VPC) en su cuenta, especifique
subredes en varias zonas de disponibilidad para garantizar una alta disponibilidad. Para obtener más
información, consulte Configuración de una función de Lambda para obtener acceso a los recursos de
una VPC (p. 81).
• Simultaneidad reservada: – para asegurarse de que la función siempre puede escalarse para gestionar
solicitudes adicionales, puede reservar la simultaneidad para ella. Configurar la simultaneidad reservada
para una función garantiza que se puede escalar, pero no superar, un determinado número de
invocaciones simultáneas. De este modo, se asegura de que no pierde las solicitudes debido a otras
funciones que consumen toda la simultaneidad disponible. Para obtener más información, consulte
Administración de la simultaneidad para una función de Lambda (p. 62).
• Reintentos: en invocaciones asíncronas y un subconjunto de invocaciones activadas por otros servicios,
Lambda reintenta automáticamente en error con retrasos entre los reintentos. Otros clientes y servicios
de AWS que invocan de forma sincrónica son responsables de realizar los reintentos. Para obtener más
información, consulte Control de errores y reintentos automáticos en AWS Lambda (p. 119).
• Cola de mensajes fallidos: – en invocaciones asíncronas, puede configurar Lambda para enviar
solicitudes a una cola de mensajes fallidos si fallan todos los reintentos. Una cola de mensajes fallidos
es un tema de Amazon SNS o una cola de Amazon SQS que recibe eventos para la resolución de
problemas o para reprocesamiento. Para obtener más información, consulte Colas de mensajes fallidos
de funciones de AWS Lambda (p. 107).
Puede utilizar llamadas a la API publicadas en AWS para obtener acceso a Lambda a través de la red.
Los clientes deben ser compatibles con Transport Layer Security (TLS) 1.0 o una versión posterior.
Le recomendamos TLS 1.2 o una versión posterior. Los clientes también deben ser compatibles con
conjuntos de cifrado con confidencialidad directa total (PFS) tales como Ephemeral Diffie-Hellman (DHE)
o Elliptic Curve Ephemeral Diffie-Hellman (ECDHE). La mayoría de los sistemas modernos como Java 7 y
posteriores son compatibles con estos modos.
480
AWS Lambda Guía para desarrolladores
Configuración y análisis de vulnerabilidades
Además, las solicitudes deben estar firmadas mediante un ID de clave de acceso y una clave de acceso
secreta que esté asociada a una entidad principal de IAM. También puede utilizar AWS Security Token
Service (AWS STS) para generar credenciales de seguridad temporales para firmar solicitudes.
Si utiliza bibliotecas adicionales con su función, será responsable de actualizar las bibliotecas. Puede
incluir bibliotecas adicionales en el paquete de implementación (p. 22) o en capas (p. 76) que asocie
a su función. También puede crear tiempos de ejecución personalizados (p. 134) y utilizar capas para
compartirlas con otras cuentas.
481
AWS Lambda Guía para desarrolladores
Implementación
Para obtener más consejos para la resolución de problemas y respuestas a preguntas comunes de
soporte, visite el Centro de conocimientos de AWS.
Temas
• Solución de problemas en las implementaciones de AWS Lambda (p. 482)
• Solucionar problemas de invocación en AWS Lambda (p. 484)
• Solucionar problemas de ejecución en AWS Lambda (p. 486)
• Solucionar problemas de redes en AWS Lambda (p. 488)
Cuando implementa actualizaciones en su función directamente con la API de Lambda o con un cliente
como la AWS CLI, puede ver errores de Lambda directamente en la salida. Si utiliza servicios como AWS
CloudFormation, AWS CodeDeploy o AWS CodePipeline, busque la respuesta de Lambda en los registros
o en la secuencia de eventos del servicio.
El runtime de Lambda necesita permiso para leer los archivos del paquete de implementación. Puede
utilizar el comando chmod para cambiar el modo de archivo. Los siguientes comandos de ejemplo permiten
que cualquier usuario pueda leer todos los archivos y carpetas del directorio actual.
482
AWS Lambda Guía para desarrolladores
Implementación
Cuando carga un archivo directamente con la AWS CLI, el SDK de AWS o de otro modo, el
archivo ZIP binario se convierte a base64, que aumenta su tamaño en aproximadamente un 30 %.
Para permitir esto y el tamaño de otros parámetros de la solicitud, el límite de tamaño de solicitud
real que aplica Lambda es mayor. Por este motivo, el límite de 50 MB es aproximado.
Error: se produjo un error mientras GetObject. Código de error S3: PermanentRedirect. Mensaje de error
S3: el bucket está en esta región: us-east-2. Utilice esta región para volver a intentar la solicitud
Cuando carga el paquete de implementación de una función desde un bucket Amazon S3, el bucket
debe estar en la misma Región que la función. Este problema puede producirse cuando especifica un
Amazon S3 objeto en una llamada a UpdateFunctionCode (p. 659), o utiliza el paquete y los comandos
de implementación en la CLI de AWS o en la CLI de AWS SAM. Cree un depósito de artefactos de
implementación para cada Región donde desarrolle aplicaciones.
El nombre del archivo o clase en la configuración del controlador de su función no coincide con su código.
Consulte la siguiente entrada para obtener más información.
Error: No public method named handleRequest with appropriate method signature found on class class
function.Handler
Error: Unable to find method 'handleRequest' in type 'Function.Handler' from assembly 'Function'
El nombre del método de controlador en la configuración del controlador de su función no coincide con su
código. Cada motor de ejecución define una convención de nomenclatura para los controladores, como
nombredearchivo.nombredelmétodo. El controlador es el método en el código de su función ejecutado
por el tiempo de ejecución cuando se invoca la función.
En algunos idiomas, Lambda proporciona una biblioteca con una interfaz que espera que un método de
controlador tenga un nombre específico. Para obtener información detallada sobre la nomenclatura de
controladores para cada idioma, consulte los temas siguientes.
483
AWS Lambda Guía para desarrolladores
Invocación
Error: RequestEntityTooLargeException: la solicitud debe ser menor de 5120 bytes para la operación
UpdateFunctionConfiguration
El tamaño máximo del objeto de variables que se almacena en la configuración de la función no debe
exceder los 4096 bytes. Esto incluye nombres clave, valores, comillas, comas y corchetes. El tamaño total
del cuerpo de la solicitud HTTP también es limitado.
{
"FunctionName": "my-function",
"FunctionArn": "arn:aws:lambda:us-east-2:123456789012:function:my-function",
"Runtime": "nodejs12.x",
"Role": "arn:aws:iam::123456789012:role/lambda-role",
"Environment": {
"Variables": {
"BUCKET": "my-bucket",
"KEY": "file.txt"
}
},
...
}
En este ejemplo, el objeto tiene 39 caracteres y ocupa 39 bytes cuando se almacena (sin espacios en
blanco) como la cadena {"BUCKET":"my-bucket","KEY":"file.txt"}. Los caracteres ASCII
estándar en valores de variables de entorno utilizan un byte cada uno. Los caracteres ASCII y Unicode
extendidos pueden usar entre 2 y 4 bytes por carácter.
Error: InvalidParameterValueException: Lambda no pudo configurar las variables de entorno porque las
variables de entorno que ha proporcionado contienen claves reservadas que actualmente no se admiten
para su modificación.
Lambda reserva algunas claves de variables de entorno para uso interno. Por ejemplo, el motor de
ejecución usa AWS_REGION para determinar la región actual y no se puede reemplazar. Otras variables,
como PATH, son usadas por el tiempo de ejecución, pero se pueden extender en la configuración de su
función. Para obtener una lista completa, consulte Variables de entorno de tiempo de ejecución (p. 58).
484
AWS Lambda Guía para desarrolladores
Invocación
Para obtener una lista de los tipos de error que puede devolver la operación Invoke, consulte
Invoke (p. 587).
El usuario de IAM, o el rol que asume el usuario, necesita permiso para invocar una función. Este
requisito también se aplica a las funciones Lambda y a otros recursos informáticos que invocan funciones.
Añada la política administrada AWSLambdaRole o una política personalizada que permita la acción
lambda:InvokeFunction en la función de destino al usuario de IAM.
Note
Para obtener más información, consulte Permisos de AWS Lambda (p. 33).
Cuando conecta una función a una VPC en el momento de la creación, la función entra en un estado
Pending mientras Lambda crea interfaces de red elásticas. Durante este tiempo, no puede invocar o
modificar su función. Si conecta su función a una VPC después de la creación, puede invocarla mientras la
actualización esté pendiente, pero no podrá modificar su código o configuración.
Para obtener más información, consulte Monitorización del estado de una función con la API de
Lambda (p. 113).
Error: una función está bloqueada en el estado Pending durante varios minutos.
Si una función queda bloqueada en el estado Pending durante más de seis minutos, llame a una de las
siguientes operaciones de API para desbloquearla.
Lambda cancela la operación pendiente y pone la función en el estado Failed. A continuación, puede
eliminar la función y volver a crearla, o bien intentar otra actualización.
Problema: Una función está usando toda la concurrencia disponible, causando que otras funciones se
limiten.
Para dividir la concurrencia disponible en una región en grupos, utilice concurrencia reservada (p. 62). La
concurrencia reservada garantiza que una función siempre puede escalar a su concurrencia asignada, y
también que no escalará más allá de su concurrencia asignada.
Problema: puede invocar la función directamente, pero esta no se ejecuta cuando otro servicio o cuenta la
invoca.
Puede conceder permisos a otros servicios (p. 163) y cuentas para invocar una función en la política
basada en recursos (p. 37) de la función. Si el usuario que invoca la función está en otra cuenta, ese
usuario también necesita permiso para invocar funciones (p. 42).
Esto suele ocurrir cuando la función administra recursos en el mismo servicio de AWS que lo activa. Por
ejemplo, es posible crear una función que almacene un objeto en un bucket de Amazon S3 configurado
485
AWS Lambda Guía para desarrolladores
Ejecución
con una notificación que invoca la función de nuevo (p. 272). Para detener la ejecución de la función, elija
Throttle (Restricción) en la página de configuración de la función (p. 54). A continuación, identifique la ruta
de acceso del código o el error de configuración que provocó la invocación recursiva.
Error: KMSDisabledException: Lambda no pudo descifrar las variables de entorno porque la clave KMS
utilizada está deshabilitada. Compruebe la configuración de teclas KMS de la función.
Este error puede producirse si su clave KMS está deshabilitada o si se revoca la concesión que permite
a Lambda usar la clave. Si falta la concesión, configure la función para usar una clave diferente. A
continuación, reasigne la clave personalizada para volver a crear la concesión.
Error: EFSMountFailureException: la función no pudo montar el sistema de archivos de EFS con el punto
de acceso arn:aws:elasticfilesystem:us-east-2:123456789012:access-point/fsap-015cxmplb72b405fd.
Se rechazó la solicitud de montaje en el sistema de archivos (p. 91) de la función. Compruebe los permisos
de la función y confirme que su sistema de archivos y su punto de acceso existen y están listos para su
uso.
La función no pudo establecer una conexión con el sistema de archivos (p. 91) de la función con el
protocolo NFS (puerto TCP 2049). Compruebe el grupo de seguridad y la configuración de enrutamiento de
las subredes de la VPC.
Error: EFSMountTimeoutException: la función no pudo montar el sistema de archivos EFS con el punto de
acceso {arn:aws:elasticfilesystem:us-east-2:123456789012:access-point/fsap-015cxmplb72b405fd} debido
a que se agotó el tiempo de espera del montaje
La función pudo conectarse al sistema de archivos (p. 91) de la función, pero se agotó el tiempo de
espera de la operación de montaje. Vuelva a intentarlo después en un tiempo corto y considere limitar la
concurrencia (p. 62) de la función para reducir la carga en el sistema de archivos.
Error: EFSIOException: esta instancia de función se detuvo porque Lambda detectó un proceso de E/S que
estaba tardando demasiado.
Se agotó el tiempo de espera de una invocación anterior y Lambda no pudo finalizar el controlador de
funciones. Este problema puede producirse cuando un sistema de archivos adjunto se queda sin créditos
de ráfaga y el rendimiento previsto es insuficiente. Para aumentar el rendimiento, puede aumentar el
tamaño del sistema de archivos o utilizar el rendimiento aprovisionado. Para obtener más información,
consulte Rendimiento (p. 246).
Los errores de ejecución de funciones pueden deberse a problemas con el código, la configuración de
funciones, los recursos descendentes o los permisos. Si invoca su función directamente, verá errores
de función en la respuesta de Lambda. Si invoca la función de forma asíncrona, con una asignación de
origen de eventos o a través de otro servicio, es posible que encuentre errores en los registros, una cola de
486
AWS Lambda Guía para desarrolladores
Ejecución
mensajes fallidos o un destino en caso de error. Las opciones de manejo de errores y el comportamiento
de reintento varían en función de cómo invoque su función y del tipo de error.
Cuando el código de función o el tiempo de ejecución de Lambda devuelven un error, el código de estado
en la respuesta de Lambda es 200 OK. La presencia de un error en la respuesta se indica mediante un
encabezado llamado X-Amz-Function-Error. Los códigos de estado de las series 400 y 500 están
reservados para los errores de invocación (p. 484).
Si el código tarda mucho más en ejecutarse en Lambda que en el equipo local, puede estar limitado por
la memoria o la potencia de procesamiento disponibles para la función. Configure la función con memoria
adicional (p. 54) para aumentar la memoria y la CPU.
La función necesita permiso para llamar a CloudWatch Logs y X-Ray. Actualice su rol de ejecución (p. 33)
para concederle permiso. Añada las siguientes políticas administradas para habilitar los registros y el
seguimiento.
• AWSLambdaBasicExecutionRole
• AWSXRayDaemonWriteAccess
Cuando añade permisos a su función, actualice también su código o configuración. Esto obliga a las
instancias en ejecución de su función, cuyas credenciales han expirado, a detenerse y ser sustituidas.
Muchas bibliotecas, incluida la SDK de AWS, funcionan de forma asíncrona. Cuando realiza una llamada
de red o realiza otra operación que requiere esperar una respuesta, las bibliotecas devuelven un objeto
denominado promesa que realiza un seguimiento del progreso de la operación en segundo plano.
Para esperar a que la promesa se resuelva en una respuesta, utilice la palabra clave await. Esto bloquea
la ejecución de su código de controlador hasta que la promesa se resuelve en un objeto que contiene
la respuesta. Si no necesita usar los datos de la respuesta en su código, puede devolver la promesa
directamente al tiempo de ejecución.
Algunas bibliotecas no devuelven promesas, pero se pueden envolver en código que sí lo hace. Para
obtener más información, consulte Controlador de la función AWS Lambda en Node.js (p. 334).
Los tiempos de ejecución de los lenguajes de scripting incluyen AWS SDK y se actualizan periódicamente
a la versión más reciente. La versión actual de cada motor de ejecución se muestra en la página de
tiempos de ejecución (p. 130). Para utilizar una versión más reciente del SDK de AWS o para bloquear las
funciones a una versión específica, puede agrupar la biblioteca con el código de función o crear una capa
de Lambda (p. 76). Para obtener información detallada sobre la creación de un paquete de implementación
con dependencias, consulte los temas siguientes:
487
AWS Lambda Guía para desarrolladores
Redes
Las bibliotecas con módulos de extensión escritos en C o C++ deben compilarse en un entorno con la
misma arquitectura de procesador que Lambda (Amazon Linux). Para obtener más información, consulte
Paquete de implementación de AWS Lambda en Python (p. 352).
Los errores de conectividad de red pueden deberse a problemas de configuración de enrutamiento, reglas
de grupo de seguridad, permisos de rol, traducción de direcciones de red o disponibilidad de recursos
como direcciones IP o interfaces de red. Pueden dar lugar a un error específico o, si una solicitud no puede
alcanzar su destino, a un tiempo de espera.
Cuando conecta una función a una VPC, todas las solicitudes salientes pasan por la VPC. Para conectarse
a Internet, configure la VPC para que envíe tráfico saliente desde la subred de la función a una puerta de
enlace NAT en una subred pública. Para obtener más información y ejemplos de configuraciones de VPC,
consulte Acceso a Internet y a los servicios para funciones conectadas a la VPC (p. 87).
Problema: La función necesita acceso a los servicios de AWS sin utilizar internet
Para conectarse a servicios de AWS desde una subred privada sin acceso a Internet, utilice los puntos de
enlace de la VPC. Para obtener una plantilla de ejemplo con extremos de VPC para DynamoDB y Amazon
S3, consulte ??? (p. 87).
Error: ENILimitReacedException: Se alcanzó el límite de interfaz de red elástica para la VPC de la función.
Al conectar una función a una VPC, Lambda crea una interfaz de red elástica para cada combinación
de subred y grupo de seguridad asociados a la función. Estas interfaces de red están limitadas a 250
por VPC, pero este límite puede aumentarse. Para solicitar un aumento, utilice la consola del Centro de
soporte.
488
AWS Lambda Guía para desarrolladores
Claves de condición de IAM para Ahora puede usar claves de August 10, 2020
la configuración de Amazon VPC condición específicas de Lambda
para la configuración de VPC.
Por ejemplo, puede requerir
que todas las funciones de la
organización estén conectadas
a una VPC. También puede
especificar las subredes y los
grupos de seguridad que los
usuarios de la función pueden y
no pueden utilizar. Para obtener
más información, consulte
Configuración de VPC para
funciones de IAM.
Ventana por lotes para Ahora puede configurar June 18, 2020
consumidores de secuencias una ventana por lotes
HTTP/2 de Kinesis (MaximumBatchingWindowInSeconds)
para secuencias HTTP/2.
Lambda lee los registros de
la secuencia hasta que haya
recopilado un lote completo o
hasta que caduque la ventana
del lote. Para obtener más
información, consulte Uso de
AWS Lambda con Amazon
Kinesis.
Compatibilidad para sistemas de Ahora puede conectar un sistema June 16, 2020
archivos de Amazon EFS de archivos de Amazon EFS
a sus funciones Lambda para
acceder a archivos de red
compartidos. Para obtener
489
AWS Lambda Guía para desarrolladores
Compatibilidad con el tiempo de AWS Lambda ahora admite el March 31, 2020
ejecución de .NET Core 3.1.0 en tiempo de ejecución de .NET
AWS Lambda Core 3.1.0. Para obtener más
información, consulte .NET Core
CLI.
Compatibilidad con las API HTTP Se ha actualizado y ampliado la March 23, 2020
de API Gateway documentación sobre el uso de
Lambda con API Gateway, como
la compatibilidad con las API
HTTP. Se ha incorporado una
aplicación de ejemplo que crea
una API y una función con AWS
CloudFormation. Para obtener
más información, consulte Uso
de AWS Lambda con Amazon
API Gateway.
490
AWS Lambda Guía para desarrolladores
491
AWS Lambda Guía para desarrolladores
Crear un proxy de base de datos Ahora puede usar la consola December 3, 2019
de Lambda para crear un proxy
de base de datos para una
función Lambda. Un proxy de
base de datos permite que una
función alcance altos niveles
de simultaneidad sin agotar las
conexiones de base de datos.
Para obtener más información,
consulte Configuración del
acceso a la base de datos para
una función Lambda.
Compatibilidad con percentiles Ahora puede filtrar la métrica November 26, 2019
para la métrica de duración de duración en función de los
percentiles. Para obtener más
información, consulte Métricas de
AWS Lambda.
Opciones de gestión de errores Hay disponibles nuevas opciones November 25, 2019
para la invocación asincrónica de configuración para la
invocación asincrónica. Puede
configurar Lambda para limitar
los reintentos y establecer una
antigüedad de evento máxima.
Para obtener más información,
consulte Configuración de
la gestión de errores para la
invocación asincrónica.
492
AWS Lambda Guía para desarrolladores
Gestión de errores para orígenes Hay disponibles nuevas opciones November 25, 2019
de eventos de flujo de configuración para los
mapeos de origen de eventos
que se leen de los flujos. Puede
configurar los mapeos de
orígenes de eventos de flujos
de DynamoDB y de flujos de
Kinesis para limitar los reintentos
y establecer una antigüedad
de registro máxima. Cuando
se producen errores, puede
configurar el mapeo de origen de
eventos para que divida los lotes
antes de volver a intentarlo y
envíe registros de invocación de
los lotes con error a una cola o
tema. Para obtener más detalles,
consulte Mapeo de orígenes de
eventos de AWS Lambda.
Destinos para invocación Ahora puede configurar Lambda November 25, 2019
asincrónica para que envíe registros de
invocaciones asincrónicas a
otro servicio. Los registros de
invocación contienen detalles
sobre el evento, el contexto y la
respuesta de la función. Puede
enviar registros de invocación
a una cola SQS, un tema SNS,
una función Lambda o un bus
de eventos de EventBridge.
Para obtener más información,
consulte Configuración de
destinos para invocación
asincrónica.
493
AWS Lambda Guía para desarrolladores
Aumento de la simultaneidad Una nueva opción para mapeos November 25, 2019
para orígenes de eventos de flujo de orígenes de eventos de flujos
de DynamoDB y de flujos de
Kinesis le permiten procesar
más de un lote a la vez de cada
fragmento. Cuando aumenta el
número de lotes simultáneos
por fragmento, la simultaneidad
de su función puede ser hasta
diez veces mayor que el número
de fragmentos en el flujo. Para
obtener más detalles, consulte
Mapeo de orígenes de eventos
de AWS Lambda.
Nuevos tiempos de ejecución Hay nuevos tiempos de ejecución November 18, 2019
para Node.js, Python y Java disponibles para Node.js 12,
Python 3.8 y Java 11. Para
obtener más información,
consulte Tiempos de ejecución
de AWS Lambda.
Compatibilidad de la cola FIFO Ahora puede crear un mapeo November 18, 2019
con los orígenes de eventos de de orígenes de eventos que
Amazon SQS haga lecturas desde una cola
de primero en entrar, primero
en salir (FIFO). Antes, solo
se admitían colas estándar.
Para obtener más información,
consulte Uso de AWS Lambda
con Amazon SQS.
494
AWS Lambda Guía para desarrolladores
495
AWS Lambda Guía para desarrolladores
496
AWS Lambda Guía para desarrolladores
Uso de los consumidores de Puede utilizar los consumidores November 19, 2018
flujos HTTP/2 de Kinesis como de flujos de datos HTTP/2 de
desencadenadores Kinesis para enviar eventos a
AWS Lambda. Los consumidores
de flujos tienen rendimiento de
lectura dedicado desde cada
partición del flujo de datos y
utilizan HTTP/2 para minimizar
la latencia. Para obtener más
información, consulte Uso de
AWS Lambda con Kinesis.
Incremento del límite de carga El tamaño de carga máximo para November 16, 2018
para las invocaciones asíncronas las invocaciones asíncronas
de funciones ha aumentado de 128 KB a
256 KB, que coincide con el
tamaño máximo del mensaje
desde un desencadenador de
Amazon SNS. Para obtener
detalles, consulte Cuotas de
AWS Lambda.
Región AWS GovCloud (EE. UU. AWS Lambda ya está disponible November 12, 2018
Este) en la región AWS GovCloud
(EE.UU. Este). Para obtener
más información, consulte AWS
GovCloud (EE. UU. Este). now
open en el blog de AWS.
497
AWS Lambda Guía para desarrolladores
Límite de tiempo de espera de Para permitir las funciones October 10, 2018
ejecución de funciones de ejecución prolongada, el
máximo tiempo de espera de
ejecución configurable se ha
aumentado de 5 minutos a 15
minutos. Para obtener más
información, consulte Límites de
AWS Lambda.
Compatibilidad con lenguaje AWS Lambda ahora admite el September 11, 2018
de PowerShell Core en AWS lenguaje de PowerShell Core.
Lambda Para obtener más información,
consulte Creación de funciones
de Lambda con PowerShell.
Región China (Ningxia) AWS Lambda ya está disponible June 28, 2018
en la Región China (Ningxia).
Para obtener más información
acerca de las regiones y los
puntos de enlace de Lambda,
consulte Regiones y puntos
de enlace en la AWS General
Reference.
498
AWS Lambda Guía para desarrolladores
Actualizaciones anteriores
Compatibilidad con Amazon SQS AWS Lambda ahora admite June 28, 2018
como origen de eventos Amazon Simple Queue Service
(Amazon SQS) como origen
de eventos. Para obtener más
información, consulte Invocación
de funciones de Lambda.
Actualizaciones anteriores
En la siguiente tabla, se describen los cambios importantes que se han realizado en cada una de las
versiones de la Guía para desarrolladores de AWS Lambda anteriores a junio de 2018.
Compatibilidad con AWS Lambda ahora es compatible con la versión 8.10 2 de abril
tiempo de ejecución 8.10 de tiempo de ejecución de Node.js. Para obtener más de 2018
de Node.js información, consulte Creación de funciones de Lambda con
Node.js (p. 332).
ID de revisión de los AWS Lambda admite ahora los ID de revisión en los alias 25 de
alias y las funciones y las versiones de las funciones. Puede usar estos ID para enero de
realizar un seguimiento de las actualizaciones condicionales 2018
y aplicarlas al actualizar los recursos de alias o la versión de
función.
Rediseño de la consola AWS Lambda presenta una nueva consola de Lambda para 30 de
simplificar su experiencia y se ha añadido un Cloud9 Code noviembre
Editor para mejorar su capacidad de depurar y revisar el código de 2017
de las funciones. Para obtener más información, consulte
Creación de funciones mediante el editor de la consola de AWS
Lambda (p. 7).
Desvío de tráfico AWS Lambda admite ahora el desvío de tráfico con alias. Para 28 de
mediante alias obtener más información, consulte Implementaciones continuas noviembre
para funciones de Lambda (p. 156). de 2017
Región China (Pekín) AWS Lambda ya está disponible en la Región China (Pekín). 9 de
Para obtener más información acerca de las regiones y los noviembre
puntos de enlace de Lambda, consulte Regiones y puntos de de 2017
enlace en la AWS General Reference.
499
AWS Lambda Guía para desarrolladores
Actualizaciones anteriores
Región Canadá (Central) AWS Lambda ya está disponible en la Región Canadá 22 de junio
(Central). Para obtener más información acerca de las regiones de 2017
y los puntos de enlace de Lambda, consulte Regiones y puntos
de enlace en la AWS General Reference.
Región América del Sur AWS Lambda ya está disponible en la Región América del 6 de junio
(São Paulo) Sur (São Paulo). Para obtener más información acerca de las de 2017
regiones y los puntos de enlace de Lambda, consulte Regiones
y puntos de enlace en la AWS General Reference.
Compatibilidad de AWS Lambda introduce la compatibilidad con X-Ray, que permite 19 de abril
Lambda para AWS X- detectar, analizar y optimizar problemas de desempeño con de 2017
Ray. las aplicaciones de Lambda. Para obtener más información,
consulte Uso de AWS Lambda con AWS X-Ray (p. 311).
Región Asia Pacífico AWS Lambda ya está disponible en la Región Asia Pacífico 28 de
(Mumbai) (Mumbai). Para obtener más información acerca de las marzo de
regiones y los puntos de enlace de Lambda, consulte Regiones 2017
y puntos de enlace en la AWS General Reference.
Compatibilidad de AWS AWS Lambda incorpora compatibilidad con C#. Para obtener 3 de
Lambda con el tiempo más información, consulte Creación de funciones Lambda con diciembre
de ejecución de .NET, C# (p. 432). de 2016
Lambda@Edge (vista
previa), las colas de Lambda@Edge le permite ejecutar funciones de Lambda en
mensajes fallidos y las ubicaciones de borde de AWS en respuesta a eventos de
la implementación CloudFront. Para obtener más información, consulte Uso de
automatizada de las AWS Lambda con CloudFront Lambda@Edge (p. 205).
aplicaciones sin servidor
AWS Lambda agrega Con Lambda y Amazon Lex, puede crear rápidamente bots 30 de
Amazon Lex como de chat para diversos servicios, como Slack y Facebook. Para noviembre
origen de eventos obtener más información, consulte Uso de AWS Lambda con de 2016
compatible. Amazon Lex (p. 265).
500
AWS Lambda Guía para desarrolladores
Actualizaciones anteriores
EE.UU. Oeste (Norte de AWS Lambda ya está disponible en la EE.UU. Oeste (Norte 21 de
California) de California). Para obtener más información acerca de las noviembre
regiones y los puntos de enlace de Lambda, consulte Regiones de 2016
y puntos de enlace en la AWS General Reference.
Se presenta AWS AWS Serverless Application Model: ahora puede utilizar AWS 18 de
Serverless Application SAM para definir la sintaxis para expresar recursos dentro de noviembre
Model, que permite una aplicación sin servidor. Para implementar la aplicación, de 2016
crear e implementar solo tiene que especificar los recursos que necesita que formen
aplicaciones basadas parte de ella, junto con sus políticas de permisos asociadas
en Lambda y utilizar en un archivo de plantilla de AWS CloudFormation (escrito en
variables de entorno JSON o YAML), empaquetar sus artefactos de implementación
para los ajustes de e implementar la plantilla. Para obtener más información,
configuración de las consulte Aplicaciones de AWS Lambda (p. 144).
funciones de Lambda.
Variables de entorno: puede utilizar variables de entorno para
especificar las opciones de configuración de una función de
Lambda fuera del código de la función. Para obtener más
información, consulte Uso de variables de entorno de AWS
Lambda (p. 56).
Región Asia Pacífico AWS Lambda ya está disponible en la Región Asia Pacífico 29 de
(Seúl) (Seúl). Para obtener más información acerca de las regiones y agosto de
los puntos de enlace de Lambda, consulte Regiones y puntos 2016
de enlace en la AWS General Reference.
Región Asia Pacífico Lambda ya está disponible en la Región Asia Pacífico (Sídney). 23 de junio
(Sídney) Para obtener más información acerca de las regiones y los de 2016
puntos de enlace de Lambda, consulte Regiones y puntos de
enlace en la AWS General Reference.
AWS Lambda ahora es AWS Lambda ha agregado compatibilidad con el tiempo 07 de abril
compatible con el tiempo de ejecución v4.3. Para obtener más información, consulte de 2016
de ejecución v4.3 de Creación de funciones de Lambda con Node.js (p. 332).
Node.js
Compatibilidad con VPC Ahora puede configurar una función de Lambda para obtener 11 de
acceso a los recursos de una VPC. Para obtener más febrero de
información, consulte Configuración de una función de Lambda 2016
para obtener acceso a los recursos de una VPC (p. 81).
501
AWS Lambda Guía para desarrolladores
Actualizaciones anteriores
Compatibilidad con DynamoDB Streams ya está disponible con carácter general 14 de julio
DynamoDB Streams y se puede utilizar en todas las regiones en las que está de 2015
disponible. Puede activar DynamoDB Streams para una tabla
y utilizar una función de Lambda como un disparador para la
tabla. Los disparadores son acciones personalizadas que se
llevan a cabo en respuesta a las actualizaciones realizadas
en la tabla de DynamoDB. Para ver un tutorial de ejemplo,
consulte Tutorial: Uso de AWS Lambda con flujos de Amazon
DynamoDB (p. 223).
AWS Lambda ahora Hasta ahora, para invocar una función de Lambda desde 09 de julio
permite invocar aplicaciones web, móviles o IoT, se necesitaban los SDK de de 2015
funciones de Lambda AWS (por ejemplo, AWS SDK para Java, AWS SDK para
con clientes compatibles Android o AWS SDK para iOS). Ahora, AWS Lambda permite
con REST. invocar una función de Lambda con clientes compatibles con
REST a través de una API personalizada que puede crear con
Amazon API Gateway. Puede enviar solicitudes a la URL del
punto de enlace de una función de Lambda. Puede configurar
la seguridad en el punto de enlace para permitir el acceso
libre, utilizar AWS Identity and Access Management (IAM)
para autorizar el acceso, o utilizar claves de API para medir el
acceso de otros usuarios a sus funciones de Lambda.
502
AWS Lambda Guía para desarrolladores
Actualizaciones anteriores
AWS Lambda ahora A partir de ahora, puede escribir el código de Lambda en Java. 15 de junio
permite utilizar Java Para obtener más información, consulte Creación de funciones de 2015
para crear funciones de de Lambda con Java (p. 383).
Lambda.
AWS Lambda ahora AWS Lambda ya se encuentra disponible con carácter general 9 de abril
está disponible con para su uso con fines de producción. La versión también de 2015
carácter general con presenta características nuevas que facilitan la creación de
soporte para backends backends para móviles, tablets e Internet de las cosas (IoT) con
para móviles AWS Lambda que se escalan automáticamente sin necesidad
de aprovisionar ni administrar infraestructura. AWS Lambda
ahora es compatible con eventos en tiempo real (síncronos) y
asíncronos. También incluye una configuración y administración
de orígenes de eventos más sencilla. El modelo de permisos
y el modelo de programación se han simplificado mediante
la introducción de políticas de recursos para las funciones de
Lambda.
AWS Lambda
503
AWS Lambda Guía para desarrolladores
Actions
Referencia de la API
Esta sección contiene la documentación de referencia de la AWS Lambda. Cuando haga llamadas a la
API, deberá autenticar la solicitud proporcionando una firma. AWS Lambda es compatible con Signature
Version 4. Para obtener más información, consulte Proceso de firma Signature Version 4 en la Referencia
general de Amazon Web Services.
Para obtener información general acerca del servicio, consulte ¿Qué es AWS Lambda? (p. 1).
Puede utilizar la AWS CLI para explorar la API de AWS Lambda. Esta guía proporciona varios tutoriales
que utilizan la AWS CLI.
Temas
Actions
The following actions are supported:
504
AWS Lambda Guía para desarrolladores
Actions
505
AWS Lambda Guía para desarrolladores
AddLayerVersionPermission
AddLayerVersionPermission
Adds permissions to the resource-based policy of a version of an AWS Lambda layer. Use this action to
grant layer usage permission to other accounts. You can grant permission to a single account, all AWS
accounts, or all accounts in an organization.
To revoke permission, call RemoveLayerVersionPermission (p. 641) with the statement ID that you
specified when you added it.
Request Syntax
POST /2018-10-31/layers/LayerName/versions/VersionNumber/policy?RevisionId=RevisionId
HTTP/1.1
Content-type: application/json
{
"Action": "string",
"OrganizationId": "string",
"Principal": "string",
"StatementId": "string"
}
Pattern: (arn:[a-zA-Z0-9-]+:lambda:[a-zA-Z0-9-]+:\d{12}:layer:[a-zA-Z0-9-_]+)|
[a-zA-Z0-9-_]+
Required: Yes
RevisionId (p. 506)
Only update the policy if the revision ID matches the ID specified. Use this option to avoid modifying a
policy that has changed since you last read it.
VersionNumber (p. 506)
Required: Yes
Request Body
The request accepts the following data in JSON format.
The API action that grants access to the layer. For example, lambda:GetLayerVersion.
Type: String
Pattern: lambda:GetLayerVersion
506
AWS Lambda Guía para desarrolladores
AddLayerVersionPermission
Required: Yes
OrganizationId (p. 506)
With the principal set to *, grant permission to all accounts in the specified organization.
Type: String
Pattern: o-[a-z0-9]{10,32}
Required: No
Principal (p. 506)
Type: String
Pattern: \d{12}|\*|arn:(aws[a-zA-Z-]*):iam::\d{12}:root
Required: Yes
StatementId (p. 506)
An identifier that distinguishes the policy from others on the same layer version.
Type: String
Pattern: ([a-zA-Z0-9-_]+)
Required: Yes
Response Syntax
HTTP/1.1 201
Content-type: application/json
{
"RevisionId": "string",
"Statement": "string"
}
Response Elements
If the action is successful, the service sends back an HTTP 201 response.
Type: String
Statement (p. 507)
Type: String
507
AWS Lambda Guía para desarrolladores
AddLayerVersionPermission
Errors
InvalidParameterValueException
The permissions policy for the resource is too large. Learn more
The RevisionId provided does not match the latest RevisionId for the Lambda function or alias. Call the
GetFunction or the GetAlias API to retrieve the latest RevisionId for your resource.
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
508
AWS Lambda Guía para desarrolladores
AddPermission
AddPermission
Grants an AWS service or another account permission to use a function. You can apply the policy at the
function level, or specify a qualifier to restrict access to a single version or alias. If you use a qualifier, the
invoker must use the full Amazon Resource Name (ARN) of that version or alias to invoke the function.
To grant permission to another account, specify the account ID as the Principal. For AWS
services, the principal is a domain-style identifier defined by the service, like s3.amazonaws.com or
sns.amazonaws.com. For AWS services, you can also specify the ARN of the associated resource as
the SourceArn. If you grant permission to a service principal without specifying the source, other accounts
could potentially configure resources in their account to invoke your Lambda function.
This action adds a statement to a resource-based permissions policy for the function. For more information
about function policies, see Lambda Function Policies.
Request Syntax
POST /2015-03-31/functions/FunctionName/policy?Qualifier=Qualifier HTTP/1.1
Content-type: application/json
{
"Action": "string",
"EventSourceToken": "string",
"Principal": "string",
"RevisionId": "string",
"SourceAccount": "string",
"SourceArn": "string",
"StatementId": "string"
}
Name formats
• Function name - my-function (name-only), my-function:v1 (with alias).
• Function ARN - arn:aws:lambda:us-west-2:123456789012:function:my-function.
• Partial ARN - 123456789012:function:my-function.
You can append a version number or alias to any of the formats. The length constraint applies only to
the full ARN. If you specify only the function name, it is limited to 64 characters in length.
Pattern: (arn:(aws[a-zA-Z-]*)?:lambda:)?([a-z]{2}(-gov)?-[a-z]+-\d{1}:)?
(\d{12}:)?(function:)?([a-zA-Z0-9-_]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Required: Yes
Qualifier (p. 509)
509
AWS Lambda Guía para desarrolladores
AddPermission
Pattern: (|[a-zA-Z0-9$_-]+)
Request Body
The request accepts the following data in JSON format.
The action that the principal can use on the function. For example, lambda:InvokeFunction or
lambda:GetFunction.
Type: String
Pattern: (lambda:[*]|lambda:[a-zA-Z]+|[*])
Required: Yes
EventSourceToken (p. 509)
For Alexa Smart Home functions, a token that must be supplied by the invoker.
Type: String
Pattern: [a-zA-Z0-9._\-]+
Required: No
Principal (p. 509)
The AWS service or account that invokes the function. If you specify a service, use SourceArn or
SourceAccount to limit who can invoke the function through that service.
Type: String
Pattern: .*
Required: Yes
RevisionId (p. 509)
Only update the policy if the revision ID matches the ID that's specified. Use this option to avoid
modifying a policy that has changed since you last read it.
Type: String
Required: No
SourceAccount (p. 509)
For Amazon S3, the ID of the account that owns the resource. Use this together with SourceArn to
ensure that the resource is owned by the specified account. It is possible for an Amazon S3 bucket to
be deleted by its owner and recreated by another account.
Type: String
Pattern: \d{12}
Required: No
SourceArn (p. 509)
For AWS services, the ARN of the AWS resource that invokes the function. For example, an Amazon
S3 bucket or Amazon SNS topic.
510
AWS Lambda Guía para desarrolladores
AddPermission
Type: String
Pattern: arn:(aws[a-zA-Z0-9-]*):([a-zA-Z0-9\-])+:([a-z]{2}(-gov)?-[a-z]+-
\d{1})?:(\d{12})?:(.*)
Required: No
StatementId (p. 509)
A statement identifier that differentiates the statement from others in the same policy.
Type: String
Pattern: ([a-zA-Z0-9-_]+)
Required: Yes
Response Syntax
HTTP/1.1 201
Content-type: application/json
{
"Statement": "string"
}
Response Elements
If the action is successful, the service sends back an HTTP 201 response.
Type: String
Errors
InvalidParameterValueException
The permissions policy for the resource is too large. Learn more
The RevisionId provided does not match the latest RevisionId for the Lambda function or alias. Call the
GetFunction or the GetAlias API to retrieve the latest RevisionId for your resource.
511
AWS Lambda Guía para desarrolladores
AddPermission
ResourceConflictException
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
512
AWS Lambda Guía para desarrolladores
CreateAlias
CreateAlias
Creates an alias for a Lambda function version. Use aliases to provide clients with a function identifier that
you can update to invoke a different version.
You can also map an alias to split invocation requests between two versions. Use the RoutingConfig
parameter to specify a second version and the percentage of invocation requests that it receives.
Request Syntax
POST /2015-03-31/functions/FunctionName/aliases HTTP/1.1
Content-type: application/json
{
"Description": "string",
"FunctionVersion": "string",
"Name": "string",
"RoutingConfig": {
"AdditionalVersionWeights": {
"string" : number
}
}
}
Name formats
• Function name - MyFunction.
• Function ARN - arn:aws:lambda:us-west-2:123456789012:function:MyFunction.
• Partial ARN - 123456789012:function:MyFunction.
The length constraint applies only to the full ARN. If you specify only the function name, it is limited to
64 characters in length.
Pattern: (arn:(aws[a-zA-Z-]*)?:lambda:)?([a-z]{2}(-gov)?-[a-z]+-\d{1}:)?
(\d{12}:)?(function:)?([a-zA-Z0-9-_]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Required: Yes
Request Body
The request accepts the following data in JSON format.
Type: String
513
AWS Lambda Guía para desarrolladores
CreateAlias
Required: No
FunctionVersion (p. 513)
Type: String
Pattern: (\$LATEST|[0-9]+)
Required: Yes
Name (p. 513)
Type: String
Pattern: (?!^[0-9]+$)([a-zA-Z0-9-_]+)
Required: Yes
RoutingConfig (p. 513)
Required: No
Response Syntax
HTTP/1.1 201
Content-type: application/json
{
"AliasArn": "string",
"Description": "string",
"FunctionVersion": "string",
"Name": "string",
"RevisionId": "string",
"RoutingConfig": {
"AdditionalVersionWeights": {
"string" : number
}
}
}
Response Elements
If the action is successful, the service sends back an HTTP 201 response.
514
AWS Lambda Guía para desarrolladores
CreateAlias
Type: String
Pattern: arn:(aws[a-zA-Z-]*)?:lambda:[a-z]{2}(-gov)?-[a-z]+-\d{1}:
\d{12}:function:[a-zA-Z0-9-_]+(:(\$LATEST|[a-zA-Z0-9-_]+))?
Description (p. 514)
Type: String
Type: String
Pattern: (\$LATEST|[0-9]+)
Name (p. 514)
Type: String
Pattern: (?!^[0-9]+$)([a-zA-Z0-9-_]+)
RevisionId (p. 514)
Type: String
RoutingConfig (p. 514)
Errors
InvalidParameterValueException
515
AWS Lambda Guía para desarrolladores
CreateAlias
ServiceException
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
516
AWS Lambda Guía para desarrolladores
CreateEventSourceMapping
CreateEventSourceMapping
Creates a mapping between an event source and an AWS Lambda function. Lambda reads items from the
event source and triggers the function.
For details about each event source type, see the following topics.
The following error handling options are only available for stream sources (DynamoDB and Kinesis):
• BisectBatchOnFunctionError - If the function returns an error, split the batch in two and retry.
• DestinationConfig - Send discarded records to an Amazon SQS queue or Amazon SNS topic.
• MaximumRecordAgeInSeconds - Discard records older than the specified age. Default -1 (infinite).
Minimum 60. Maximum 604800.
• MaximumRetryAttempts - Discard records after the specified number of retries. Default -1 (infinite).
Minimum 0. Maximum 10000. When infinite, failed records will be retried until the record expires.
• ParallelizationFactor - Process multiple batches from each shard concurrently.
Request Syntax
POST /2015-03-31/event-source-mappings/ HTTP/1.1
Content-type: application/json
{
"BatchSize": number,
"BisectBatchOnFunctionError": boolean,
"DestinationConfig": {
"OnFailure": {
"Destination": "string"
},
"OnSuccess": {
"Destination": "string"
}
},
"Enabled": boolean,
"EventSourceArn": "string",
"FunctionName": "string",
"MaximumBatchingWindowInSeconds": number,
"MaximumRecordAgeInSeconds": number,
"MaximumRetryAttempts": number,
"ParallelizationFactor": number,
"StartingPosition": "string",
"StartingPositionTimestamp": number,
"Topics": [ "string" ]
}
517
AWS Lambda Guía para desarrolladores
CreateEventSourceMapping
Request Body
The request accepts the following data in JSON format.
Type: Integer
Required: No
BisectBatchOnFunctionError (p. 517)
(Streams) If the function returns an error, split the batch in two and retry.
Type: Boolean
Required: No
DestinationConfig (p. 517)
(Streams) An Amazon SQS queue or Amazon SNS topic destination for discarded records.
Required: No
Enabled (p. 517)
If true, the event source mapping is active. Set to false to pause polling and invocation.
Type: Boolean
Required: No
EventSourceArn (p. 517)
Type: String
Pattern: arn:(aws[a-zA-Z0-9-]*):([a-zA-Z0-9\-])+:([a-z]{2}(-gov)?-[a-z]+-
\d{1})?:(\d{12})?:(.*)
Required: Yes
FunctionName (p. 517)
518
AWS Lambda Guía para desarrolladores
CreateEventSourceMapping
Name formats
• Function name - MyFunction.
• Function ARN - arn:aws:lambda:us-west-2:123456789012:function:MyFunction.
• Version or Alias ARN - arn:aws:lambda:us-
west-2:123456789012:function:MyFunction:PROD.
• Partial ARN - 123456789012:function:MyFunction.
The length constraint applies only to the full ARN. If you specify only the function name, it's limited to
64 characters in length.
Type: String
Pattern: (arn:(aws[a-zA-Z-]*)?:lambda:)?([a-z]{2}(-gov)?-[a-z]+-\d{1}:)?
(\d{12}:)?(function:)?([a-zA-Z0-9-_]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Required: Yes
MaximumBatchingWindowInSeconds (p. 517)
(Streams) The maximum amount of time to gather records before invoking the function, in seconds.
Type: Integer
Required: No
MaximumRecordAgeInSeconds (p. 517)
(Streams) Discard records older than the specified age. The default value is infinite (-1).
Type: Integer
Required: No
MaximumRetryAttempts (p. 517)
(Streams) Discard records after the specified number of retries. The default value is infinite (-1). When
set to infinite (-1), failed records will be retried until the record expires.
Type: Integer
Required: No
ParallelizationFactor (p. 517)
Type: Integer
Required: No
StartingPosition (p. 517)
The position in a stream from which to start reading. Required for Amazon Kinesis, Amazon
DynamoDB, and Amazon MSK Streams sources. AT_TIMESTAMP is only supported for Amazon
Kinesis streams.
519
AWS Lambda Guía para desarrolladores
CreateEventSourceMapping
Type: String
Required: No
StartingPositionTimestamp (p. 517)
With StartingPosition set to AT_TIMESTAMP, the time from which to start reading, in Unix time
seconds.
Type: Timestamp
Required: No
Topics (p. 517)
Pattern: ^[^.]([a-zA-Z0-9\-_.]+)
Required: No
Response Syntax
HTTP/1.1 202
Content-type: application/json
{
"BatchSize": number,
"BisectBatchOnFunctionError": boolean,
"DestinationConfig": {
"OnFailure": {
"Destination": "string"
},
"OnSuccess": {
"Destination": "string"
}
},
"EventSourceArn": "string",
"FunctionArn": "string",
"LastModified": number,
"LastProcessingResult": "string",
"MaximumBatchingWindowInSeconds": number,
"MaximumRecordAgeInSeconds": number,
"MaximumRetryAttempts": number,
"ParallelizationFactor": number,
"State": "string",
"StateTransitionReason": "string",
"Topics": [ "string" ],
"UUID": "string"
}
Response Elements
If the action is successful, the service sends back an HTTP 202 response.
520
AWS Lambda Guía para desarrolladores
CreateEventSourceMapping
Type: Integer
(Streams) If the function returns an error, split the batch in two and retry.
Type: Boolean
DestinationConfig (p. 520)
(Streams) An Amazon SQS queue or Amazon SNS topic destination for discarded records.
Type: String
Pattern: arn:(aws[a-zA-Z0-9-]*):([a-zA-Z0-9\-])+:([a-z]{2}(-gov)?-[a-z]+-
\d{1})?:(\d{12})?:(.*)
FunctionArn (p. 520)
Type: String
Pattern: arn:(aws[a-zA-Z-]*)?:lambda:[a-z]{2}(-gov)?-[a-z]+-\d{1}:
\d{12}:function:[a-zA-Z0-9-_]+(:(\$LATEST|[a-zA-Z0-9-_]+))?
LastModified (p. 520)
The date that the event source mapping was last updated, or its state changed, in Unix time seconds.
Type: Timestamp
LastProcessingResult (p. 520)
The result of the last AWS Lambda invocation of your Lambda function.
Type: String
MaximumBatchingWindowInSeconds (p. 520)
(Streams) The maximum amount of time to gather records before invoking the function, in seconds.
Type: Integer
(Streams) The maximum age of a record that Lambda sends to a function for processing.
Type: Integer
521
AWS Lambda Guía para desarrolladores
CreateEventSourceMapping
(Streams) The maximum number of times to retry when the function returns an error.
Type: Integer
Type: Integer
The state of the event source mapping. It can be one of the following: Creating, Enabling,
Enabled, Disabling, Disabled, Updating, or Deleting.
Type: String
StateTransitionReason (p. 520)
Indicates whether the last change to the event source mapping was made by a user, or by the Lambda
service.
Type: String
Topics (p. 520)
Pattern: ^[^.]([a-zA-Z0-9\-_.]+)
UUID (p. 520)
Type: String
Errors
InvalidParameterValueException
522
AWS Lambda Guía para desarrolladores
CreateEventSourceMapping
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
523
AWS Lambda Guía para desarrolladores
CreateFunction
CreateFunction
Creates a Lambda function. To create a function, you need a deployment package and an execution role.
The deployment package contains your function code. The execution role grants the function permission
to use AWS services, such as Amazon CloudWatch Logs for log streaming and AWS X-Ray for request
tracing.
When you create a function, Lambda provisions an instance of the function and its supporting resources.
If your function connects to a VPC, this process can take a minute or so. During this time, you can't invoke
or modify the function. The State, StateReason, and StateReasonCode fields in the response from
GetFunctionConfiguration (p. 565) indicate when the function is ready to invoke. For more information,
see Function States.
A function has an unpublished version, and can have published versions and aliases. The unpublished
version changes when you update your function's code and configuration. A published version is a
snapshot of your function code and configuration that can't be changed. An alias is a named resource
that maps to a version, and can be changed to map to a different version. Use the Publish parameter to
create version 1 of your function from its initial configuration.
The other parameters let you configure version-specific and function-level settings. You can modify version-
specific settings later with UpdateFunctionConfiguration (p. 667). Function-level settings apply to both the
unpublished and published versions of the function, and include tags (TagResource (p. 645)) and per-
function concurrency limits (PutFunctionConcurrency (p. 631)).
If another account or an AWS service invokes your function, use AddPermission (p. 509) to grant
permission by creating a resource-based IAM policy. You can grant permissions at the function level, on a
version, or on an alias.
To invoke your function directly, use Invoke (p. 587). To invoke your function in response to events in
other AWS services, create an event source mapping (CreateEventSourceMapping (p. 517)), or configure a
function trigger in the other service. For more information, see Invoking Functions.
Request Syntax
POST /2015-03-31/functions HTTP/1.1
Content-type: application/json
{
"Code": {
"S3Bucket": "string",
"S3Key": "string",
"S3ObjectVersion": "string",
"ZipFile": blob
},
"DeadLetterConfig": {
"TargetArn": "string"
},
"Description": "string",
"Environment": {
"Variables": {
"string" : "string"
}
},
"FileSystemConfigs": [
{
"Arn": "string",
"LocalMountPath": "string"
}
],
"FunctionName": "string",
524
AWS Lambda Guía para desarrolladores
CreateFunction
"Handler": "string",
"KMSKeyArn": "string",
"Layers": [ "string" ],
"MemorySize": number,
"Publish": boolean,
"Role": "string",
"Runtime": "string",
"Tags": {
"string" : "string"
},
"Timeout": number,
"TracingConfig": {
"Mode": "string"
},
"VpcConfig": {
"SecurityGroupIds": [ "string" ],
"SubnetIds": [ "string" ]
}
}
Request Body
The request accepts the following data in JSON format.
Required: Yes
DeadLetterConfig (p. 524)
A dead letter queue configuration that specifies the queue or topic where Lambda sends asynchronous
events when they fail processing. For more information, see Dead Letter Queues.
Required: No
Description (p. 524)
Type: String
Required: No
Environment (p. 524)
Environment variables that are accessible from function code during execution.
Required: No
525
AWS Lambda Guía para desarrolladores
CreateFunction
Required: No
FunctionName (p. 524)
Name formats
• Function name - my-function.
• Function ARN - arn:aws:lambda:us-west-2:123456789012:function:my-function.
• Partial ARN - 123456789012:function:my-function.
The length constraint applies only to the full ARN. If you specify only the function name, it is limited to
64 characters in length.
Type: String
Pattern: (arn:(aws[a-zA-Z-]*)?:lambda:)?([a-z]{2}(-gov)?-[a-z]+-\d{1}:)?
(\d{12}:)?(function:)?([a-zA-Z0-9-_]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Required: Yes
Handler (p. 524)
The name of the method within your code that Lambda calls to execute your function. The format
includes the file name. It can also include namespaces and other qualifiers, depending on the runtime.
For more information, see Programming Model.
Type: String
Pattern: [^\s]+
Required: Yes
KMSKeyArn (p. 524)
The ARN of the AWS Key Management Service (AWS KMS) key that's used to encrypt your function's
environment variables. If it's not provided, AWS Lambda uses a default service key.
Type: String
Pattern: (arn:(aws[a-zA-Z-]*)?:[a-z0-9-.]+:.*)|()
Required: No
Layers (p. 524)
A list of function layers to add to the function's execution environment. Specify each layer by its ARN,
including the version.
526
AWS Lambda Guía para desarrolladores
CreateFunction
Pattern: arn:[a-zA-Z0-9-]+:lambda:[a-zA-Z0-9-]+:\d{12}:layer:[a-zA-Z0-9-_]+:
[0-9]+
Required: No
MemorySize (p. 524)
The amount of memory that your function has access to. Increasing the function's memory also
increases its CPU allocation. The default value is 128 MB. The value must be a multiple of 64 MB.
Type: Integer
Required: No
Publish (p. 524)
Set to true to publish the first version of the function during creation.
Type: Boolean
Required: No
Role (p. 524)
Type: String
Pattern: arn:(aws[a-zA-Z-]*)?:iam::\d{12}:role/?[a-zA-Z_0-9+=,.@\-_/]+
Required: Yes
Runtime (p. 524)
Type: String
Required: Yes
Tags (p. 524)
Required: No
Timeout (p. 524)
The amount of time that Lambda allows a function to run before stopping it. The default is 3 seconds.
The maximum allowed value is 900 seconds.
Type: Integer
527
AWS Lambda Guía para desarrolladores
CreateFunction
Required: No
TracingConfig (p. 524)
Set Mode to Active to sample and trace a subset of incoming requests with AWS X-Ray.
Required: No
VpcConfig (p. 524)
For network connectivity to AWS resources in a VPC, specify a list of security groups and subnets in
the VPC. When you connect a function to a VPC, it can only access resources and the internet through
that VPC. For more information, see VPC Settings.
Required: No
Response Syntax
HTTP/1.1 201
Content-type: application/json
{
"CodeSha256": "string",
"CodeSize": number,
"DeadLetterConfig": {
"TargetArn": "string"
},
"Description": "string",
"Environment": {
"Error": {
"ErrorCode": "string",
"Message": "string"
},
"Variables": {
"string" : "string"
}
},
"FileSystemConfigs": [
{
"Arn": "string",
"LocalMountPath": "string"
}
],
"FunctionArn": "string",
"FunctionName": "string",
"Handler": "string",
"KMSKeyArn": "string",
"LastModified": "string",
"LastUpdateStatus": "string",
"LastUpdateStatusReason": "string",
"LastUpdateStatusReasonCode": "string",
"Layers": [
{
"Arn": "string",
"CodeSize": number
}
],
"MasterArn": "string",
"MemorySize": number,
"RevisionId": "string",
528
AWS Lambda Guía para desarrolladores
CreateFunction
"Role": "string",
"Runtime": "string",
"State": "string",
"StateReason": "string",
"StateReasonCode": "string",
"Timeout": number,
"TracingConfig": {
"Mode": "string"
},
"Version": "string",
"VpcConfig": {
"SecurityGroupIds": [ "string" ],
"SubnetIds": [ "string" ],
"VpcId": "string"
}
}
Response Elements
If the action is successful, the service sends back an HTTP 201 response.
Type: String
CodeSize (p. 528)
Type: Long
DeadLetterConfig (p. 528)
Type: String
529
AWS Lambda Guía para desarrolladores
CreateFunction
Type: String
Pattern: arn:(aws[a-zA-Z-]*)?:lambda:[a-z]{2}(-gov)?-[a-z]+-\d{1}:
\d{12}:function:[a-zA-Z0-9-_\.]+(:(\$LATEST|[a-zA-Z0-9-_]+))?
FunctionName (p. 528)
Type: String
Pattern: (arn:(aws[a-zA-Z-]*)?:lambda:)?([a-z]{2}(-gov)?-[a-z]+-\d{1}:)?
(\d{12}:)?(function:)?([a-zA-Z0-9-_\.]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Handler (p. 528)
Type: String
Pattern: [^\s]+
KMSKeyArn (p. 528)
The KMS key that's used to encrypt the function's environment variables. This key is only returned if
you've configured a customer managed CMK.
Type: String
Pattern: (arn:(aws[a-zA-Z-]*)?:[a-z0-9-.]+:.*)|()
LastModified (p. 528)
The date and time that the function was last updated, in ISO-8601 format (YYYY-MM-
DDThh:mm:ss.sTZD).
Type: String
LastUpdateStatus (p. 528)
The status of the last update that was performed on the function. This is first set to Successful after
function creation completes.
Type: String
The reason for the last update that was performed on the function.
Type: String
LastUpdateStatusReasonCode (p. 528)
The reason code for the last update that was performed on the function.
Type: String
530
AWS Lambda Guía para desarrolladores
CreateFunction
Type: String
Pattern: arn:(aws[a-zA-Z-]*)?:lambda:[a-z]{2}(-gov)?-[a-z]+-\d{1}:
\d{12}:function:[a-zA-Z0-9-_]+(:(\$LATEST|[a-zA-Z0-9-_]+))?
MemorySize (p. 528)
Type: Integer
Type: String
Role (p. 528)
Type: String
Pattern: arn:(aws[a-zA-Z-]*)?:iam::\d{12}:role/?[a-zA-Z_0-9+=,.@\-_/]+
Runtime (p. 528)
Type: String
The current state of the function. When the state is Inactive, you can reactivate the function by
invoking it.
Type: String
Type: String
StateReasonCode (p. 528)
The reason code for the function's current state. When the code is Creating, you can't invoke or
modify the function.
531
AWS Lambda Guía para desarrolladores
CreateFunction
Type: String
The amount of time in seconds that Lambda allows a function to run before stopping it.
Type: Integer
Type: String
Pattern: (\$LATEST|[0-9]+)
VpcConfig (p. 528)
Errors
CodeStorageExceededException
You have exceeded your maximum total code size per account. Learn more
532
AWS Lambda Guía para desarrolladores
CreateFunction
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
533
AWS Lambda Guía para desarrolladores
DeleteAlias
DeleteAlias
Deletes a Lambda function alias.
Request Syntax
DELETE /2015-03-31/functions/FunctionName/aliases/Name HTTP/1.1
Name formats
• Function name - MyFunction.
• Function ARN - arn:aws:lambda:us-west-2:123456789012:function:MyFunction.
• Partial ARN - 123456789012:function:MyFunction.
The length constraint applies only to the full ARN. If you specify only the function name, it is limited to
64 characters in length.
Pattern: (arn:(aws[a-zA-Z-]*)?:lambda:)?([a-z]{2}(-gov)?-[a-z]+-\d{1}:)?
(\d{12}:)?(function:)?([a-zA-Z0-9-_]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Required: Yes
Name (p. 534)
Pattern: (?!^[0-9]+$)([a-zA-Z0-9-_]+)
Required: Yes
Request Body
The request does not have a request body.
Response Syntax
HTTP/1.1 204
Response Elements
If the action is successful, the service sends back an HTTP 204 response with an empty HTTP body.
534
AWS Lambda Guía para desarrolladores
DeleteAlias
Errors
InvalidParameterValueException
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
535
AWS Lambda Guía para desarrolladores
DeleteEventSourceMapping
DeleteEventSourceMapping
Deletes an event source mapping. You can get the identifier of a mapping from the output of
ListEventSourceMappings (p. 598).
When you delete an event source mapping, it enters a Deleting state and might not be completely
deleted for several seconds.
Request Syntax
DELETE /2015-03-31/event-source-mappings/UUID HTTP/1.1
Required: Yes
Request Body
The request does not have a request body.
Response Syntax
HTTP/1.1 202
Content-type: application/json
{
"BatchSize": number,
"BisectBatchOnFunctionError": boolean,
"DestinationConfig": {
"OnFailure": {
"Destination": "string"
},
"OnSuccess": {
"Destination": "string"
}
},
"EventSourceArn": "string",
"FunctionArn": "string",
"LastModified": number,
"LastProcessingResult": "string",
"MaximumBatchingWindowInSeconds": number,
"MaximumRecordAgeInSeconds": number,
"MaximumRetryAttempts": number,
"ParallelizationFactor": number,
"State": "string",
"StateTransitionReason": "string",
"Topics": [ "string" ],
"UUID": "string"
}
536
AWS Lambda Guía para desarrolladores
DeleteEventSourceMapping
Response Elements
If the action is successful, the service sends back an HTTP 202 response.
Type: Integer
(Streams) If the function returns an error, split the batch in two and retry.
Type: Boolean
DestinationConfig (p. 536)
(Streams) An Amazon SQS queue or Amazon SNS topic destination for discarded records.
Type: String
Pattern: arn:(aws[a-zA-Z0-9-]*):([a-zA-Z0-9\-])+:([a-z]{2}(-gov)?-[a-z]+-
\d{1})?:(\d{12})?:(.*)
FunctionArn (p. 536)
Type: String
Pattern: arn:(aws[a-zA-Z-]*)?:lambda:[a-z]{2}(-gov)?-[a-z]+-\d{1}:
\d{12}:function:[a-zA-Z0-9-_]+(:(\$LATEST|[a-zA-Z0-9-_]+))?
LastModified (p. 536)
The date that the event source mapping was last updated, or its state changed, in Unix time seconds.
Type: Timestamp
LastProcessingResult (p. 536)
The result of the last AWS Lambda invocation of your Lambda function.
Type: String
MaximumBatchingWindowInSeconds (p. 536)
(Streams) The maximum amount of time to gather records before invoking the function, in seconds.
Type: Integer
(Streams) The maximum age of a record that Lambda sends to a function for processing.
537
AWS Lambda Guía para desarrolladores
DeleteEventSourceMapping
Type: Integer
(Streams) The maximum number of times to retry when the function returns an error.
Type: Integer
Type: Integer
The state of the event source mapping. It can be one of the following: Creating, Enabling,
Enabled, Disabling, Disabled, Updating, or Deleting.
Type: String
StateTransitionReason (p. 536)
Indicates whether the last change to the event source mapping was made by a user, or by the Lambda
service.
Type: String
Topics (p. 536)
Pattern: ^[^.]([a-zA-Z0-9\-_.]+)
UUID (p. 536)
Type: String
Errors
InvalidParameterValueException
The operation conflicts with the resource's availability. For example, you attempted to update an
EventSource Mapping in CREATING, or tried to delete a EventSource mapping currently in the
UPDATING state.
538
AWS Lambda Guía para desarrolladores
DeleteEventSourceMapping
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
539
AWS Lambda Guía para desarrolladores
DeleteFunction
DeleteFunction
Deletes a Lambda function. To delete a specific function version, use the Qualifier parameter.
Otherwise, all versions and aliases are deleted.
To delete Lambda event source mappings that invoke a function, use DeleteEventSourceMapping (p. 536).
For AWS services and resources that invoke your function directly, delete the trigger in the service where
you originally configured it.
Request Syntax
DELETE /2015-03-31/functions/FunctionName?Qualifier=Qualifier HTTP/1.1
Name formats
• Function name - my-function (name-only), my-function:1 (with version).
• Function ARN - arn:aws:lambda:us-west-2:123456789012:function:my-function.
• Partial ARN - 123456789012:function:my-function.
You can append a version number or alias to any of the formats. The length constraint applies only to
the full ARN. If you specify only the function name, it is limited to 64 characters in length.
Pattern: (arn:(aws[a-zA-Z-]*)?:lambda:)?([a-z]{2}(-gov)?-[a-z]+-\d{1}:)?
(\d{12}:)?(function:)?([a-zA-Z0-9-_]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Required: Yes
Qualifier (p. 540)
Specify a version to delete. You can't delete a version that's referenced by an alias.
Pattern: (|[a-zA-Z0-9$_-]+)
Request Body
The request does not have a request body.
Response Syntax
HTTP/1.1 204
Response Elements
If the action is successful, the service sends back an HTTP 204 response with an empty HTTP body.
540
AWS Lambda Guía para desarrolladores
DeleteFunction
Errors
InvalidParameterValueException
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
541
AWS Lambda Guía para desarrolladores
DeleteFunctionConcurrency
DeleteFunctionConcurrency
Removes a concurrent execution limit from a function.
Request Syntax
DELETE /2017-10-31/functions/FunctionName/concurrency HTTP/1.1
Name formats
• Function name - my-function.
• Function ARN - arn:aws:lambda:us-west-2:123456789012:function:my-function.
• Partial ARN - 123456789012:function:my-function.
The length constraint applies only to the full ARN. If you specify only the function name, it is limited to
64 characters in length.
Pattern: (arn:(aws[a-zA-Z-]*)?:lambda:)?([a-z]{2}(-gov)?-[a-z]+-\d{1}:)?
(\d{12}:)?(function:)?([a-zA-Z0-9-_]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Required: Yes
Request Body
The request does not have a request body.
Response Syntax
HTTP/1.1 204
Response Elements
If the action is successful, the service sends back an HTTP 204 response with an empty HTTP body.
Errors
InvalidParameterValueException
542
AWS Lambda Guía para desarrolladores
DeleteFunctionConcurrency
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
543
AWS Lambda Guía para desarrolladores
DeleteFunctionEventInvokeConfig
DeleteFunctionEventInvokeConfig
Deletes the configuration for asynchronous invocation for a function, version, or alias.
Request Syntax
DELETE /2019-09-25/functions/FunctionName/event-invoke-config?Qualifier=Qualifier HTTP/1.1
Name formats
• Function name - my-function (name-only), my-function:v1 (with alias).
• Function ARN - arn:aws:lambda:us-west-2:123456789012:function:my-function.
• Partial ARN - 123456789012:function:my-function.
You can append a version number or alias to any of the formats. The length constraint applies only to
the full ARN. If you specify only the function name, it is limited to 64 characters in length.
Pattern: (arn:(aws[a-zA-Z-]*)?:lambda:)?([a-z]{2}(-gov)?-[a-z]+-\d{1}:)?
(\d{12}:)?(function:)?([a-zA-Z0-9-_]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Required: Yes
Qualifier (p. 544)
Pattern: (|[a-zA-Z0-9$_-]+)
Request Body
The request does not have a request body.
Response Syntax
HTTP/1.1 204
Response Elements
If the action is successful, the service sends back an HTTP 204 response with an empty HTTP body.
544
AWS Lambda Guía para desarrolladores
DeleteFunctionEventInvokeConfig
Errors
InvalidParameterValueException
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
545
AWS Lambda Guía para desarrolladores
DeleteLayerVersion
DeleteLayerVersion
Deletes a version of an AWS Lambda layer. Deleted versions can no longer be viewed or added to
functions. To avoid breaking functions, a copy of the version remains in Lambda until no functions refer to it.
Request Syntax
DELETE /2018-10-31/layers/LayerName/versions/VersionNumber HTTP/1.1
Pattern: (arn:[a-zA-Z0-9-]+:lambda:[a-zA-Z0-9-]+:\d{12}:layer:[a-zA-Z0-9-_]+)|
[a-zA-Z0-9-_]+
Required: Yes
VersionNumber (p. 546)
Required: Yes
Request Body
The request does not have a request body.
Response Syntax
HTTP/1.1 204
Response Elements
If the action is successful, the service sends back an HTTP 204 response with an empty HTTP body.
Errors
ServiceException
546
AWS Lambda Guía para desarrolladores
DeleteLayerVersion
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
547
AWS Lambda Guía para desarrolladores
DeleteProvisionedConcurrencyConfig
DeleteProvisionedConcurrencyConfig
Deletes the provisioned concurrency configuration for a function.
Request Syntax
DELETE /2019-09-30/functions/FunctionName/provisioned-concurrency?Qualifier=Qualifier
HTTP/1.1
Name formats
• Function name - my-function.
• Function ARN - arn:aws:lambda:us-west-2:123456789012:function:my-function.
• Partial ARN - 123456789012:function:my-function.
The length constraint applies only to the full ARN. If you specify only the function name, it is limited to
64 characters in length.
Pattern: (arn:(aws[a-zA-Z-]*)?:lambda:)?([a-z]{2}(-gov)?-[a-z]+-\d{1}:)?
(\d{12}:)?(function:)?([a-zA-Z0-9-_]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Required: Yes
Qualifier (p. 548)
Pattern: (|[a-zA-Z0-9$_-]+)
Required: Yes
Request Body
The request does not have a request body.
Response Syntax
HTTP/1.1 204
Response Elements
If the action is successful, the service sends back an HTTP 204 response with an empty HTTP body.
548
AWS Lambda Guía para desarrolladores
DeleteProvisionedConcurrencyConfig
Errors
InvalidParameterValueException
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
549
AWS Lambda Guía para desarrolladores
GetAccountSettings
GetAccountSettings
Retrieves details about your account's limits and usage in an AWS Region.
Request Syntax
GET /2016-08-19/account-settings/ HTTP/1.1
Request Body
The request does not have a request body.
Response Syntax
HTTP/1.1 200
Content-type: application/json
{
"AccountLimit": {
"CodeSizeUnzipped": number,
"CodeSizeZipped": number,
"ConcurrentExecutions": number,
"TotalCodeSize": number,
"UnreservedConcurrentExecutions": number
},
"AccountUsage": {
"FunctionCount": number,
"TotalCodeSize": number
}
}
Response Elements
If the action is successful, the service sends back an HTTP 200 response.
Errors
ServiceException
550
AWS Lambda Guía para desarrolladores
GetAccountSettings
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
551
AWS Lambda Guía para desarrolladores
GetAlias
GetAlias
Returns details about a Lambda function alias.
Request Syntax
GET /2015-03-31/functions/FunctionName/aliases/Name HTTP/1.1
Name formats
• Function name - MyFunction.
• Function ARN - arn:aws:lambda:us-west-2:123456789012:function:MyFunction.
• Partial ARN - 123456789012:function:MyFunction.
The length constraint applies only to the full ARN. If you specify only the function name, it is limited to
64 characters in length.
Pattern: (arn:(aws[a-zA-Z-]*)?:lambda:)?([a-z]{2}(-gov)?-[a-z]+-\d{1}:)?
(\d{12}:)?(function:)?([a-zA-Z0-9-_]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Required: Yes
Name (p. 552)
Pattern: (?!^[0-9]+$)([a-zA-Z0-9-_]+)
Required: Yes
Request Body
The request does not have a request body.
Response Syntax
HTTP/1.1 200
Content-type: application/json
{
"AliasArn": "string",
"Description": "string",
"FunctionVersion": "string",
552
AWS Lambda Guía para desarrolladores
GetAlias
"Name": "string",
"RevisionId": "string",
"RoutingConfig": {
"AdditionalVersionWeights": {
"string" : number
}
}
}
Response Elements
If the action is successful, the service sends back an HTTP 200 response.
Type: String
Pattern: arn:(aws[a-zA-Z-]*)?:lambda:[a-z]{2}(-gov)?-[a-z]+-\d{1}:
\d{12}:function:[a-zA-Z0-9-_]+(:(\$LATEST|[a-zA-Z0-9-_]+))?
Description (p. 552)
Type: String
Type: String
Pattern: (\$LATEST|[0-9]+)
Name (p. 552)
Type: String
Pattern: (?!^[0-9]+$)([a-zA-Z0-9-_]+)
RevisionId (p. 552)
Type: String
RoutingConfig (p. 552)
553
AWS Lambda Guía para desarrolladores
GetAlias
Errors
InvalidParameterValueException
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
554
AWS Lambda Guía para desarrolladores
GetEventSourceMapping
GetEventSourceMapping
Returns details about an event source mapping. You can get the identifier of a mapping from the output of
ListEventSourceMappings (p. 598).
Request Syntax
GET /2015-03-31/event-source-mappings/UUID HTTP/1.1
Required: Yes
Request Body
The request does not have a request body.
Response Syntax
HTTP/1.1 200
Content-type: application/json
{
"BatchSize": number,
"BisectBatchOnFunctionError": boolean,
"DestinationConfig": {
"OnFailure": {
"Destination": "string"
},
"OnSuccess": {
"Destination": "string"
}
},
"EventSourceArn": "string",
"FunctionArn": "string",
"LastModified": number,
"LastProcessingResult": "string",
"MaximumBatchingWindowInSeconds": number,
"MaximumRecordAgeInSeconds": number,
"MaximumRetryAttempts": number,
"ParallelizationFactor": number,
"State": "string",
"StateTransitionReason": "string",
"Topics": [ "string" ],
"UUID": "string"
}
Response Elements
If the action is successful, the service sends back an HTTP 200 response.
555
AWS Lambda Guía para desarrolladores
GetEventSourceMapping
Type: Integer
(Streams) If the function returns an error, split the batch in two and retry.
Type: Boolean
DestinationConfig (p. 555)
(Streams) An Amazon SQS queue or Amazon SNS topic destination for discarded records.
Type: String
Pattern: arn:(aws[a-zA-Z0-9-]*):([a-zA-Z0-9\-])+:([a-z]{2}(-gov)?-[a-z]+-
\d{1})?:(\d{12})?:(.*)
FunctionArn (p. 555)
Type: String
Pattern: arn:(aws[a-zA-Z-]*)?:lambda:[a-z]{2}(-gov)?-[a-z]+-\d{1}:
\d{12}:function:[a-zA-Z0-9-_]+(:(\$LATEST|[a-zA-Z0-9-_]+))?
LastModified (p. 555)
The date that the event source mapping was last updated, or its state changed, in Unix time seconds.
Type: Timestamp
LastProcessingResult (p. 555)
The result of the last AWS Lambda invocation of your Lambda function.
Type: String
MaximumBatchingWindowInSeconds (p. 555)
(Streams) The maximum amount of time to gather records before invoking the function, in seconds.
Type: Integer
(Streams) The maximum age of a record that Lambda sends to a function for processing.
Type: Integer
556
AWS Lambda Guía para desarrolladores
GetEventSourceMapping
(Streams) The maximum number of times to retry when the function returns an error.
Type: Integer
Type: Integer
The state of the event source mapping. It can be one of the following: Creating, Enabling,
Enabled, Disabling, Disabled, Updating, or Deleting.
Type: String
StateTransitionReason (p. 555)
Indicates whether the last change to the event source mapping was made by a user, or by the Lambda
service.
Type: String
Topics (p. 555)
Pattern: ^[^.]([a-zA-Z0-9\-_.]+)
UUID (p. 555)
Type: String
Errors
InvalidParameterValueException
557
AWS Lambda Guía para desarrolladores
GetEventSourceMapping
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
558
AWS Lambda Guía para desarrolladores
GetFunction
GetFunction
Returns information about the function or function version, with a link to download the deployment package
that's valid for 10 minutes. If you specify a function version, only details that are specific to that version are
returned.
Request Syntax
GET /2015-03-31/functions/FunctionName?Qualifier=Qualifier HTTP/1.1
Name formats
• Function name - my-function (name-only), my-function:v1 (with alias).
• Function ARN - arn:aws:lambda:us-west-2:123456789012:function:my-function.
• Partial ARN - 123456789012:function:my-function.
You can append a version number or alias to any of the formats. The length constraint applies only to
the full ARN. If you specify only the function name, it is limited to 64 characters in length.
Pattern: (arn:(aws[a-zA-Z-]*)?:lambda:)?([a-z]{2}(-gov)?-[a-z]+-\d{1}:)?
(\d{12}:)?(function:)?([a-zA-Z0-9-_\.]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Required: Yes
Qualifier (p. 559)
Specify a version or alias to get details about a published version of the function.
Pattern: (|[a-zA-Z0-9$_-]+)
Request Body
The request does not have a request body.
Response Syntax
HTTP/1.1 200
Content-type: application/json
{
"Code": {
"Location": "string",
"RepositoryType": "string"
},
"Concurrency": {
"ReservedConcurrentExecutions": number
559
AWS Lambda Guía para desarrolladores
GetFunction
},
"Configuration": {
"CodeSha256": "string",
"CodeSize": number,
"DeadLetterConfig": {
"TargetArn": "string"
},
"Description": "string",
"Environment": {
"Error": {
"ErrorCode": "string",
"Message": "string"
},
"Variables": {
"string" : "string"
}
},
"FileSystemConfigs": [
{
"Arn": "string",
"LocalMountPath": "string"
}
],
"FunctionArn": "string",
"FunctionName": "string",
"Handler": "string",
"KMSKeyArn": "string",
"LastModified": "string",
"LastUpdateStatus": "string",
"LastUpdateStatusReason": "string",
"LastUpdateStatusReasonCode": "string",
"Layers": [
{
"Arn": "string",
"CodeSize": number
}
],
"MasterArn": "string",
"MemorySize": number,
"RevisionId": "string",
"Role": "string",
"Runtime": "string",
"State": "string",
"StateReason": "string",
"StateReasonCode": "string",
"Timeout": number,
"TracingConfig": {
"Mode": "string"
},
"Version": "string",
"VpcConfig": {
"SecurityGroupIds": [ "string" ],
"SubnetIds": [ "string" ],
"VpcId": "string"
}
},
"Tags": {
"string" : "string"
}
}
Response Elements
If the action is successful, the service sends back an HTTP 200 response.
560
AWS Lambda Guía para desarrolladores
GetFunction
Errors
InvalidParameterValueException
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
561
AWS Lambda Guía para desarrolladores
GetFunction
562
AWS Lambda Guía para desarrolladores
GetFunctionConcurrency
GetFunctionConcurrency
Returns details about the reserved concurrency configuration for a function. To set a concurrency limit for a
function, use PutFunctionConcurrency (p. 631).
Request Syntax
GET /2019-09-30/functions/FunctionName/concurrency HTTP/1.1
Name formats
• Function name - my-function.
• Function ARN - arn:aws:lambda:us-west-2:123456789012:function:my-function.
• Partial ARN - 123456789012:function:my-function.
The length constraint applies only to the full ARN. If you specify only the function name, it is limited to
64 characters in length.
Pattern: (arn:(aws[a-zA-Z-]*)?:lambda:)?([a-z]{2}(-gov)?-[a-z]+-\d{1}:)?
(\d{12}:)?(function:)?([a-zA-Z0-9-_]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Required: Yes
Request Body
The request does not have a request body.
Response Syntax
HTTP/1.1 200
Content-type: application/json
{
"ReservedConcurrentExecutions": number
}
Response Elements
If the action is successful, the service sends back an HTTP 200 response.
The number of simultaneous executions that are reserved for the function.
563
AWS Lambda Guía para desarrolladores
GetFunctionConcurrency
Type: Integer
Errors
InvalidParameterValueException
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
564
AWS Lambda Guía para desarrolladores
GetFunctionConfiguration
GetFunctionConfiguration
Returns the version-specific settings of a Lambda function or version. The output includes
only options that can vary between versions of a function. To modify these settings, use
UpdateFunctionConfiguration (p. 667).
To get all of a function's details, including function-level settings, use GetFunction (p. 559).
Request Syntax
GET /2015-03-31/functions/FunctionName/configuration?Qualifier=Qualifier HTTP/1.1
Name formats
• Function name - my-function (name-only), my-function:v1 (with alias).
• Function ARN - arn:aws:lambda:us-west-2:123456789012:function:my-function.
• Partial ARN - 123456789012:function:my-function.
You can append a version number or alias to any of the formats. The length constraint applies only to
the full ARN. If you specify only the function name, it is limited to 64 characters in length.
Pattern: (arn:(aws[a-zA-Z-]*)?:lambda:)?([a-z]{2}(-gov)?-[a-z]+-\d{1}:)?
(\d{12}:)?(function:)?([a-zA-Z0-9-_\.]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Required: Yes
Qualifier (p. 565)
Specify a version or alias to get details about a published version of the function.
Pattern: (|[a-zA-Z0-9$_-]+)
Request Body
The request does not have a request body.
Response Syntax
HTTP/1.1 200
Content-type: application/json
{
"CodeSha256": "string",
"CodeSize": number,
565
AWS Lambda Guía para desarrolladores
GetFunctionConfiguration
"DeadLetterConfig": {
"TargetArn": "string"
},
"Description": "string",
"Environment": {
"Error": {
"ErrorCode": "string",
"Message": "string"
},
"Variables": {
"string" : "string"
}
},
"FileSystemConfigs": [
{
"Arn": "string",
"LocalMountPath": "string"
}
],
"FunctionArn": "string",
"FunctionName": "string",
"Handler": "string",
"KMSKeyArn": "string",
"LastModified": "string",
"LastUpdateStatus": "string",
"LastUpdateStatusReason": "string",
"LastUpdateStatusReasonCode": "string",
"Layers": [
{
"Arn": "string",
"CodeSize": number
}
],
"MasterArn": "string",
"MemorySize": number,
"RevisionId": "string",
"Role": "string",
"Runtime": "string",
"State": "string",
"StateReason": "string",
"StateReasonCode": "string",
"Timeout": number,
"TracingConfig": {
"Mode": "string"
},
"Version": "string",
"VpcConfig": {
"SecurityGroupIds": [ "string" ],
"SubnetIds": [ "string" ],
"VpcId": "string"
}
}
Response Elements
If the action is successful, the service sends back an HTTP 200 response.
Type: String
566
AWS Lambda Guía para desarrolladores
GetFunctionConfiguration
Type: Long
DeadLetterConfig (p. 565)
Type: String
Type: String
Pattern: arn:(aws[a-zA-Z-]*)?:lambda:[a-z]{2}(-gov)?-[a-z]+-\d{1}:
\d{12}:function:[a-zA-Z0-9-_\.]+(:(\$LATEST|[a-zA-Z0-9-_]+))?
FunctionName (p. 565)
Type: String
Pattern: (arn:(aws[a-zA-Z-]*)?:lambda:)?([a-z]{2}(-gov)?-[a-z]+-\d{1}:)?
(\d{12}:)?(function:)?([a-zA-Z0-9-_\.]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Handler (p. 565)
Type: String
Pattern: [^\s]+
KMSKeyArn (p. 565)
The KMS key that's used to encrypt the function's environment variables. This key is only returned if
you've configured a customer managed CMK.
567
AWS Lambda Guía para desarrolladores
GetFunctionConfiguration
Type: String
Pattern: (arn:(aws[a-zA-Z-]*)?:[a-z0-9-.]+:.*)|()
LastModified (p. 565)
The date and time that the function was last updated, in ISO-8601 format (YYYY-MM-
DDThh:mm:ss.sTZD).
Type: String
LastUpdateStatus (p. 565)
The status of the last update that was performed on the function. This is first set to Successful after
function creation completes.
Type: String
The reason for the last update that was performed on the function.
Type: String
LastUpdateStatusReasonCode (p. 565)
The reason code for the last update that was performed on the function.
Type: String
Type: String
Pattern: arn:(aws[a-zA-Z-]*)?:lambda:[a-z]{2}(-gov)?-[a-z]+-\d{1}:
\d{12}:function:[a-zA-Z0-9-_]+(:(\$LATEST|[a-zA-Z0-9-_]+))?
MemorySize (p. 565)
Type: Integer
Type: String
Role (p. 565)
568
AWS Lambda Guía para desarrolladores
GetFunctionConfiguration
Type: String
Pattern: arn:(aws[a-zA-Z-]*)?:iam::\d{12}:role/?[a-zA-Z_0-9+=,.@\-_/]+
Runtime (p. 565)
Type: String
The current state of the function. When the state is Inactive, you can reactivate the function by
invoking it.
Type: String
Type: String
StateReasonCode (p. 565)
The reason code for the function's current state. When the code is Creating, you can't invoke or
modify the function.
Type: String
The amount of time in seconds that Lambda allows a function to run before stopping it.
Type: Integer
Type: String
Pattern: (\$LATEST|[0-9]+)
VpcConfig (p. 565)
569
AWS Lambda Guía para desarrolladores
GetFunctionConfiguration
Errors
InvalidParameterValueException
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
570
AWS Lambda Guía para desarrolladores
GetFunctionEventInvokeConfig
GetFunctionEventInvokeConfig
Retrieves the configuration for asynchronous invocation for a function, version, or alias.
Request Syntax
GET /2019-09-25/functions/FunctionName/event-invoke-config?Qualifier=Qualifier HTTP/1.1
Name formats
• Function name - my-function (name-only), my-function:v1 (with alias).
• Function ARN - arn:aws:lambda:us-west-2:123456789012:function:my-function.
• Partial ARN - 123456789012:function:my-function.
You can append a version number or alias to any of the formats. The length constraint applies only to
the full ARN. If you specify only the function name, it is limited to 64 characters in length.
Pattern: (arn:(aws[a-zA-Z-]*)?:lambda:)?([a-z]{2}(-gov)?-[a-z]+-\d{1}:)?
(\d{12}:)?(function:)?([a-zA-Z0-9-_]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Required: Yes
Qualifier (p. 571)
Pattern: (|[a-zA-Z0-9$_-]+)
Request Body
The request does not have a request body.
Response Syntax
HTTP/1.1 200
Content-type: application/json
{
"DestinationConfig": {
"OnFailure": {
"Destination": "string"
},
"OnSuccess": {
"Destination": "string"
571
AWS Lambda Guía para desarrolladores
GetFunctionEventInvokeConfig
}
},
"FunctionArn": "string",
"LastModified": number,
"MaximumEventAgeInSeconds": number,
"MaximumRetryAttempts": number
}
Response Elements
If the action is successful, the service sends back an HTTP 200 response.
A destination for events after they have been sent to a function for processing.
Destinations
• Function - The Amazon Resource Name (ARN) of a Lambda function.
• Queue - The ARN of an SQS queue.
• Topic - The ARN of an SNS topic.
• Event Bus - The ARN of an Amazon EventBridge event bus.
Type: String
Pattern: arn:(aws[a-zA-Z-]*)?:lambda:[a-z]{2}(-gov)?-[a-z]+-\d{1}:
\d{12}:function:[a-zA-Z0-9-_]+(:(\$LATEST|[a-zA-Z0-9-_]+))?
LastModified (p. 571)
The date and time that the configuration was last updated, in Unix time seconds.
Type: Timestamp
MaximumEventAgeInSeconds (p. 571)
The maximum age of a request that Lambda sends to a function for processing.
Type: Integer
The maximum number of times to retry when the function returns an error.
Type: Integer
Errors
InvalidParameterValueException
572
AWS Lambda Guía para desarrolladores
GetFunctionEventInvokeConfig
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
573
AWS Lambda Guía para desarrolladores
GetLayerVersion
GetLayerVersion
Returns information about a version of an AWS Lambda layer, with a link to download the layer archive
that's valid for 10 minutes.
Request Syntax
GET /2018-10-31/layers/LayerName/versions/VersionNumber HTTP/1.1
Pattern: (arn:[a-zA-Z0-9-]+:lambda:[a-zA-Z0-9-]+:\d{12}:layer:[a-zA-Z0-9-_]+)|
[a-zA-Z0-9-_]+
Required: Yes
VersionNumber (p. 574)
Required: Yes
Request Body
The request does not have a request body.
Response Syntax
HTTP/1.1 200
Content-type: application/json
{
"CompatibleRuntimes": [ "string" ],
"Content": {
"CodeSha256": "string",
"CodeSize": number,
"Location": "string"
},
"CreatedDate": "string",
"Description": "string",
"LayerArn": "string",
"LayerVersionArn": "string",
"LicenseInfo": "string",
"Version": number
}
Response Elements
If the action is successful, the service sends back an HTTP 200 response.
574
AWS Lambda Guía para desarrolladores
GetLayerVersion
The date that the layer version was created, in ISO-8601 format (YYYY-MM-DDThh:mm:ss.sTZD).
Type: String
Description (p. 574)
Type: String
Type: String
Pattern: arn:[a-zA-Z0-9-]+:lambda:[a-zA-Z0-9-]+:\d{12}:layer:[a-zA-Z0-9-_]+
LayerVersionArn (p. 574)
Type: String
Pattern: arn:[a-zA-Z0-9-]+:lambda:[a-zA-Z0-9-]+:\d{12}:layer:[a-zA-Z0-9-_]+:
[0-9]+
LicenseInfo (p. 574)
Type: String
575
AWS Lambda Guía para desarrolladores
GetLayerVersion
Type: Long
Errors
InvalidParameterValueException
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
576
AWS Lambda Guía para desarrolladores
GetLayerVersionByArn
GetLayerVersionByArn
Returns information about a version of an AWS Lambda layer, with a link to download the layer archive
that's valid for 10 minutes.
Request Syntax
GET /2018-10-31/layers?find=LayerVersion&Arn=Arn HTTP/1.1
Pattern: arn:[a-zA-Z0-9-]+:lambda:[a-zA-Z0-9-]+:\d{12}:layer:[a-zA-Z0-9-_]+:
[0-9]+
Required: Yes
Request Body
The request does not have a request body.
Response Syntax
HTTP/1.1 200
Content-type: application/json
{
"CompatibleRuntimes": [ "string" ],
"Content": {
"CodeSha256": "string",
"CodeSize": number,
"Location": "string"
},
"CreatedDate": "string",
"Description": "string",
"LayerArn": "string",
"LayerVersionArn": "string",
"LicenseInfo": "string",
"Version": number
}
Response Elements
If the action is successful, the service sends back an HTTP 200 response.
577
AWS Lambda Guía para desarrolladores
GetLayerVersionByArn
The date that the layer version was created, in ISO-8601 format (YYYY-MM-DDThh:mm:ss.sTZD).
Type: String
Description (p. 577)
Type: String
Type: String
Pattern: arn:[a-zA-Z0-9-]+:lambda:[a-zA-Z0-9-]+:\d{12}:layer:[a-zA-Z0-9-_]+
LayerVersionArn (p. 577)
Type: String
Pattern: arn:[a-zA-Z0-9-]+:lambda:[a-zA-Z0-9-]+:\d{12}:layer:[a-zA-Z0-9-_]+:
[0-9]+
LicenseInfo (p. 577)
Type: String
Type: Long
578
AWS Lambda Guía para desarrolladores
GetLayerVersionByArn
Errors
InvalidParameterValueException
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
579
AWS Lambda Guía para desarrolladores
GetLayerVersionPolicy
GetLayerVersionPolicy
Returns the permission policy for a version of an AWS Lambda layer. For more information, see
AddLayerVersionPermission (p. 506).
Request Syntax
GET /2018-10-31/layers/LayerName/versions/VersionNumber/policy HTTP/1.1
Pattern: (arn:[a-zA-Z0-9-]+:lambda:[a-zA-Z0-9-]+:\d{12}:layer:[a-zA-Z0-9-_]+)|
[a-zA-Z0-9-_]+
Required: Yes
VersionNumber (p. 580)
Required: Yes
Request Body
The request does not have a request body.
Response Syntax
HTTP/1.1 200
Content-type: application/json
{
"Policy": "string",
"RevisionId": "string"
}
Response Elements
If the action is successful, the service sends back an HTTP 200 response.
Type: String
580
AWS Lambda Guía para desarrolladores
GetLayerVersionPolicy
Type: String
Errors
InvalidParameterValueException
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
581
AWS Lambda Guía para desarrolladores
GetPolicy
GetPolicy
Returns the resource-based IAM policy for a function, version, or alias.
Request Syntax
GET /2015-03-31/functions/FunctionName/policy?Qualifier=Qualifier HTTP/1.1
Name formats
• Function name - my-function (name-only), my-function:v1 (with alias).
• Function ARN - arn:aws:lambda:us-west-2:123456789012:function:my-function.
• Partial ARN - 123456789012:function:my-function.
You can append a version number or alias to any of the formats. The length constraint applies only to
the full ARN. If you specify only the function name, it is limited to 64 characters in length.
Pattern: (arn:(aws[a-zA-Z-]*)?:lambda:)?([a-z]{2}(-gov)?-[a-z]+-\d{1}:)?
(\d{12}:)?(function:)?([a-zA-Z0-9-_\.]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Required: Yes
Qualifier (p. 582)
Pattern: (|[a-zA-Z0-9$_-]+)
Request Body
The request does not have a request body.
Response Syntax
HTTP/1.1 200
Content-type: application/json
{
"Policy": "string",
"RevisionId": "string"
}
Response Elements
If the action is successful, the service sends back an HTTP 200 response.
582
AWS Lambda Guía para desarrolladores
GetPolicy
Type: String
RevisionId (p. 582)
Type: String
Errors
InvalidParameterValueException
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
583
AWS Lambda Guía para desarrolladores
GetProvisionedConcurrencyConfig
GetProvisionedConcurrencyConfig
Retrieves the provisioned concurrency configuration for a function's alias or version.
Request Syntax
GET /2019-09-30/functions/FunctionName/provisioned-concurrency?Qualifier=Qualifier HTTP/1.1
Name formats
• Function name - my-function.
• Function ARN - arn:aws:lambda:us-west-2:123456789012:function:my-function.
• Partial ARN - 123456789012:function:my-function.
The length constraint applies only to the full ARN. If you specify only the function name, it is limited to
64 characters in length.
Pattern: (arn:(aws[a-zA-Z-]*)?:lambda:)?([a-z]{2}(-gov)?-[a-z]+-\d{1}:)?
(\d{12}:)?(function:)?([a-zA-Z0-9-_]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Required: Yes
Qualifier (p. 584)
Pattern: (|[a-zA-Z0-9$_-]+)
Required: Yes
Request Body
The request does not have a request body.
Response Syntax
HTTP/1.1 200
Content-type: application/json
{
"AllocatedProvisionedConcurrentExecutions": number,
"AvailableProvisionedConcurrentExecutions": number,
"LastModified": "string",
"RequestedProvisionedConcurrentExecutions": number,
"Status": "string",
584
AWS Lambda Guía para desarrolladores
GetProvisionedConcurrencyConfig
"StatusReason": "string"
}
Response Elements
If the action is successful, the service sends back an HTTP 200 response.
Type: Integer
Type: Integer
The date and time that a user last updated the configuration, in ISO 8601 format.
Type: String
RequestedProvisionedConcurrentExecutions (p. 584)
Type: Integer
Type: String
For failed allocations, the reason that provisioned concurrency could not be allocated.
Type: String
Errors
InvalidParameterValueException
585
AWS Lambda Guía para desarrolladores
GetProvisionedConcurrencyConfig
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
586
AWS Lambda Guía para desarrolladores
Invoke
Invoke
Invokes a Lambda function. You can invoke a function synchronously (and wait for the response), or
asynchronously. To invoke a function asynchronously, set InvocationType to Event.
For synchronous invocation, details about the function response, including errors, are included in the
response body and headers. For either invocation type, you can find more information in the execution log
and trace.
When an error occurs, your function may be invoked multiple times. Retry behavior varies by error type,
client, event source, and invocation type. For example, if you invoke a function asynchronously and it
returns an error, Lambda executes the function up to two more times. For more information, see Retry
Behavior.
For asynchronous invocation, Lambda adds events to a queue before sending them to your function. If your
function does not have enough capacity to keep up with the queue, events may be lost. Occasionally, your
function may receive the same event multiple times, even if no error occurs. To retain events that were not
processed, configure your function with a dead-letter queue.
The status code in the API response doesn't reflect function errors. Error codes are reserved
for errors that prevent your function from executing, such as permissions errors, limit
errors, or issues with your function's code and configuration. For example, Lambda returns
TooManyRequestsException if executing the function would cause you to exceed a concurrency
limit at either the account level (ConcurrentInvocationLimitExceeded) or function level
(ReservedFunctionConcurrentInvocationLimitExceeded).
For functions with a long timeout, your client might be disconnected during synchronous invocation while it
waits for a response. Configure your HTTP client, SDK, firewall, proxy, or operating system to allow for long
connections with timeout or keep-alive settings.
Request Syntax
POST /2015-03-31/functions/FunctionName/invocations?Qualifier=Qualifier HTTP/1.1
X-Amz-Invocation-Type: InvocationType
X-Amz-Log-Type: LogType
X-Amz-Client-Context: ClientContext
Payload
Up to 3583 bytes of base64-encoded data about the invoking client to pass to the function in the
context object.
FunctionName (p. 587)
Name formats
• Function name - my-function (name-only), my-function:v1 (with alias).
• Function ARN - arn:aws:lambda:us-west-2:123456789012:function:my-function.
587
AWS Lambda Guía para desarrolladores
Invoke
You can append a version number or alias to any of the formats. The length constraint applies only to
the full ARN. If you specify only the function name, it is limited to 64 characters in length.
Pattern: (arn:(aws[a-zA-Z-]*)?:lambda:)?([a-z]{2}(-gov)?-[a-z]+-\d{1}:)?
(\d{12}:)?(function:)?([a-zA-Z0-9-_\.]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Required: Yes
InvocationType (p. 587)
Pattern: (|[a-zA-Z0-9$_-]+)
Request Body
The request accepts the following binary data.
The JSON that you want to provide to your Lambda function as input.
Response Syntax
HTTP/1.1 StatusCode
X-Amz-Function-Error: FunctionError
X-Amz-Log-Result: LogResult
X-Amz-Executed-Version: ExecutedVersion
Payload
Response Elements
If the action is successful, the service sends back the following HTTP response.
588
AWS Lambda Guía para desarrolladores
Invoke
The HTTP status code is in the 200 range for a successful request. For the RequestResponse
invocation type, this status code is 200. For the Event invocation type, this status code is 202. For the
DryRun invocation type, the status code is 204.
The version of the function that executed. When you invoke a function with an alias, this indicates
which version the alias resolved to.
Pattern: (\$LATEST|[0-9]+)
FunctionError (p. 588)
If present, indicates that an error occurred during function execution. Details about the error are
included in the response payload.
LogResult (p. 588)
Errors
EC2AccessDeniedException
AWS Lambda was throttled by Amazon EC2 during Lambda function initialization using the execution
role provided for the Lambda function.
AWS Lambda received an unexpected EC2 client exception while setting up for the Lambda function.
The function couldn't make a network connection to the configured file system.
589
AWS Lambda Guía para desarrolladores
Invoke
The function couldn't mount the configured file system due to a permission or configuration issue.
The function was able to make a network connection to the configured file system, but the mount
operation timed out.
AWS Lambda was not able to create an elastic network interface in the VPC, specified as part of
Lambda function configuration, because the limit for network interfaces has been reached.
The Security Group ID provided in the Lambda function VPC configuration is invalid.
Lambda was unable to decrypt the environment variables because KMS access was denied. Check the
Lambda function's KMS permissions.
Lambda was unable to decrypt the environment variables because the KMS key used is disabled.
Check the Lambda function's KMS key settings.
590
AWS Lambda Guía para desarrolladores
Invoke
Lambda was unable to decrypt the environment variables because the KMS key used is in an invalid
state for Decrypt. Check the function's KMS key settings.
Lambda was unable to decrypt the environment variables because the KMS key was not found. Check
the function's KMS key settings.
The request payload exceeded the Invoke request body JSON input limit. For more information, see
Limits.
The function is inactive and its VPC connection is no longer available. Wait for the VPC connection to
reestablish and try again.
AWS Lambda was not able to set up VPC access for the Lambda function because one or more
configured subnets has no available IP addresses.
591
AWS Lambda Guía para desarrolladores
Invoke
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
592
AWS Lambda Guía para desarrolladores
InvokeAsync
InvokeAsync
This action has been deprecated.
Important
Request Syntax
POST /2014-11-13/functions/FunctionName/invoke-async/ HTTP/1.1
InvokeArgs
Name formats
• Function name - my-function.
• Function ARN - arn:aws:lambda:us-west-2:123456789012:function:my-function.
• Partial ARN - 123456789012:function:my-function.
The length constraint applies only to the full ARN. If you specify only the function name, it is limited to
64 characters in length.
Pattern: (arn:(aws[a-zA-Z-]*)?:lambda:)?([a-z]{2}(-gov)?-[a-z]+-\d{1}:)?
(\d{12}:)?(function:)?([a-zA-Z0-9-_\.]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Required: Yes
Request Body
The request accepts the following binary data.
The JSON that you want to provide to your Lambda function as input.
Required: Yes
Response Syntax
HTTP/1.1 Status
593
AWS Lambda Guía para desarrolladores
InvokeAsync
Response Elements
If the action is successful, the service sends back the following HTTP response.
Errors
InvalidRequestContentException
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
594
AWS Lambda Guía para desarrolladores
ListAliases
ListAliases
Returns a list of aliases for a Lambda function.
Request Syntax
GET /2015-03-31/functions/FunctionName/aliases?
FunctionVersion=FunctionVersion&Marker=Marker&MaxItems=MaxItems HTTP/1.1
Name formats
• Function name - MyFunction.
• Function ARN - arn:aws:lambda:us-west-2:123456789012:function:MyFunction.
• Partial ARN - 123456789012:function:MyFunction.
The length constraint applies only to the full ARN. If you specify only the function name, it is limited to
64 characters in length.
Pattern: (arn:(aws[a-zA-Z-]*)?:lambda:)?([a-z]{2}(-gov)?-[a-z]+-\d{1}:)?
(\d{12}:)?(function:)?([a-zA-Z0-9-_]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Required: Yes
FunctionVersion (p. 595)
Specify a function version to only list aliases that invoke that version.
Pattern: (\$LATEST|[0-9]+)
Marker (p. 595)
Specify the pagination token that's returned by a previous request to retrieve the next page of results.
MaxItems (p. 595)
Request Body
The request does not have a request body.
Response Syntax
HTTP/1.1 200
595
AWS Lambda Guía para desarrolladores
ListAliases
Content-type: application/json
{
"Aliases": [
{
"AliasArn": "string",
"Description": "string",
"FunctionVersion": "string",
"Name": "string",
"RevisionId": "string",
"RoutingConfig": {
"AdditionalVersionWeights": {
"string" : number
}
}
}
],
"NextMarker": "string"
}
Response Elements
If the action is successful, the service sends back an HTTP 200 response.
A list of aliases.
Type: String
Errors
InvalidParameterValueException
596
AWS Lambda Guía para desarrolladores
ListAliases
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
597
AWS Lambda Guía para desarrolladores
ListEventSourceMappings
ListEventSourceMappings
Lists event source mappings. Specify an EventSourceArn to only show event source mappings for a
single event source.
Request Syntax
GET /2015-03-31/event-source-mappings/?
EventSourceArn=EventSourceArn&FunctionName=FunctionName&Marker=Marker&MaxItems=MaxItems
HTTP/1.1
Pattern: arn:(aws[a-zA-Z0-9-]*):([a-zA-Z0-9\-])+:([a-z]{2}(-gov)?-[a-z]+-
\d{1})?:(\d{12})?:(.*)
FunctionName (p. 598)
Name formats
• Function name - MyFunction.
• Function ARN - arn:aws:lambda:us-west-2:123456789012:function:MyFunction.
• Version or Alias ARN - arn:aws:lambda:us-
west-2:123456789012:function:MyFunction:PROD.
• Partial ARN - 123456789012:function:MyFunction.
The length constraint applies only to the full ARN. If you specify only the function name, it's limited to
64 characters in length.
Pattern: (arn:(aws[a-zA-Z-]*)?:lambda:)?([a-z]{2}(-gov)?-[a-z]+-\d{1}:)?
(\d{12}:)?(function:)?([a-zA-Z0-9-_]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Marker (p. 598)
Request Body
The request does not have a request body.
598
AWS Lambda Guía para desarrolladores
ListEventSourceMappings
Response Syntax
HTTP/1.1 200
Content-type: application/json
{
"EventSourceMappings": [
{
"BatchSize": number,
"BisectBatchOnFunctionError": boolean,
"DestinationConfig": {
"OnFailure": {
"Destination": "string"
},
"OnSuccess": {
"Destination": "string"
}
},
"EventSourceArn": "string",
"FunctionArn": "string",
"LastModified": number,
"LastProcessingResult": "string",
"MaximumBatchingWindowInSeconds": number,
"MaximumRecordAgeInSeconds": number,
"MaximumRetryAttempts": number,
"ParallelizationFactor": number,
"State": "string",
"StateTransitionReason": "string",
"Topics": [ "string" ],
"UUID": "string"
}
],
"NextMarker": "string"
}
Response Elements
If the action is successful, the service sends back an HTTP 200 response.
A pagination token that's returned when the response doesn't contain all event source mappings.
Type: String
Errors
InvalidParameterValueException
599
AWS Lambda Guía para desarrolladores
ListEventSourceMappings
ResourceNotFoundException
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
600
AWS Lambda Guía para desarrolladores
ListFunctionEventInvokeConfigs
ListFunctionEventInvokeConfigs
Retrieves a list of configurations for asynchronous invocation for a function.
Request Syntax
GET /2019-09-25/functions/FunctionName/event-invoke-config/list?
Marker=Marker&MaxItems=MaxItems HTTP/1.1
Name formats
• Function name - my-function.
• Function ARN - arn:aws:lambda:us-west-2:123456789012:function:my-function.
• Partial ARN - 123456789012:function:my-function.
The length constraint applies only to the full ARN. If you specify only the function name, it is limited to
64 characters in length.
Pattern: (arn:(aws[a-zA-Z-]*)?:lambda:)?([a-z]{2}(-gov)?-[a-z]+-\d{1}:)?
(\d{12}:)?(function:)?([a-zA-Z0-9-_]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Required: Yes
Marker (p. 601)
Specify the pagination token that's returned by a previous request to retrieve the next page of results.
MaxItems (p. 601)
Request Body
The request does not have a request body.
Response Syntax
HTTP/1.1 200
Content-type: application/json
{
"FunctionEventInvokeConfigs": [
{
"DestinationConfig": {
"OnFailure": {
601
AWS Lambda Guía para desarrolladores
ListFunctionEventInvokeConfigs
"Destination": "string"
},
"OnSuccess": {
"Destination": "string"
}
},
"FunctionArn": "string",
"LastModified": number,
"MaximumEventAgeInSeconds": number,
"MaximumRetryAttempts": number
}
],
"NextMarker": "string"
}
Response Elements
If the action is successful, the service sends back an HTTP 200 response.
A list of configurations.
Type: String
Errors
InvalidParameterValueException
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
602
AWS Lambda Guía para desarrolladores
ListFunctionEventInvokeConfigs
603
AWS Lambda Guía para desarrolladores
ListFunctions
ListFunctions
Returns a list of Lambda functions, with the version-specific configuration of each. Lambda returns up to 50
functions per call.
Set FunctionVersion to ALL to include all published versions of each function in addition to the
unpublished version. To get more information about a function or version, use GetFunction (p. 559).
Request Syntax
GET /2015-03-31/functions/?
FunctionVersion=FunctionVersion&Marker=Marker&MasterRegion=MasterRegion&MaxItems=MaxItems
HTTP/1.1
Set to ALL to include entries for all published versions of each function.
Specify the pagination token that's returned by a previous request to retrieve the next page of results.
MasterRegion (p. 604)
For Lambda@Edge functions, the AWS Region of the master function. For example, us-east-1 filters
the list of functions to only include Lambda@Edge functions replicated from a master function in US
East (N. Virginia). If specified, you must set FunctionVersion to ALL.
Pattern: ALL|[a-z]{2}(-gov)?-[a-z]+-\d{1}
MaxItems (p. 604)
Request Body
The request does not have a request body.
Response Syntax
HTTP/1.1 200
Content-type: application/json
{
"Functions": [
{
"CodeSha256": "string",
"CodeSize": number,
"DeadLetterConfig": {
"TargetArn": "string"
},
604
AWS Lambda Guía para desarrolladores
ListFunctions
"Description": "string",
"Environment": {
"Error": {
"ErrorCode": "string",
"Message": "string"
},
"Variables": {
"string" : "string"
}
},
"FileSystemConfigs": [
{
"Arn": "string",
"LocalMountPath": "string"
}
],
"FunctionArn": "string",
"FunctionName": "string",
"Handler": "string",
"KMSKeyArn": "string",
"LastModified": "string",
"LastUpdateStatus": "string",
"LastUpdateStatusReason": "string",
"LastUpdateStatusReasonCode": "string",
"Layers": [
{
"Arn": "string",
"CodeSize": number
}
],
"MasterArn": "string",
"MemorySize": number,
"RevisionId": "string",
"Role": "string",
"Runtime": "string",
"State": "string",
"StateReason": "string",
"StateReasonCode": "string",
"Timeout": number,
"TracingConfig": {
"Mode": "string"
},
"Version": "string",
"VpcConfig": {
"SecurityGroupIds": [ "string" ],
"SubnetIds": [ "string" ],
"VpcId": "string"
}
}
],
"NextMarker": "string"
}
Response Elements
If the action is successful, the service sends back an HTTP 200 response.
605
AWS Lambda Guía para desarrolladores
ListFunctions
Type: String
Errors
InvalidParameterValueException
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
606
AWS Lambda Guía para desarrolladores
ListLayers
ListLayers
Lists AWS Lambda layers and shows information about the latest version of each. Specify a runtime
identifier to list only layers that indicate that they're compatible with that runtime.
Request Syntax
GET /2018-10-31/layers?CompatibleRuntime=CompatibleRuntime&Marker=Marker&MaxItems=MaxItems
HTTP/1.1
Request Body
The request does not have a request body.
Response Syntax
HTTP/1.1 200
Content-type: application/json
{
"Layers": [
{
"LatestMatchingVersion": {
"CompatibleRuntimes": [ "string" ],
"CreatedDate": "string",
"Description": "string",
"LayerVersionArn": "string",
"LicenseInfo": "string",
"Version": number
},
"LayerArn": "string",
"LayerName": "string"
}
],
"NextMarker": "string"
607
AWS Lambda Guía para desarrolladores
ListLayers
Response Elements
If the action is successful, the service sends back an HTTP 200 response.
A pagination token returned when the response doesn't contain all layers.
Type: String
Errors
InvalidParameterValueException
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
608
AWS Lambda Guía para desarrolladores
ListLayerVersions
ListLayerVersions
Lists the versions of an AWS Lambda layer. Versions that have been deleted aren't listed. Specify a
runtime identifier to list only versions that indicate that they're compatible with that runtime.
Request Syntax
GET /2018-10-31/layers/LayerName/versions?
CompatibleRuntime=CompatibleRuntime&Marker=Marker&MaxItems=MaxItems HTTP/1.1
Pattern: (arn:[a-zA-Z0-9-]+:lambda:[a-zA-Z0-9-]+:\d{12}:layer:[a-zA-Z0-9-_]+)|
[a-zA-Z0-9-_]+
Required: Yes
Marker (p. 609)
Request Body
The request does not have a request body.
Response Syntax
HTTP/1.1 200
Content-type: application/json
{
"LayerVersions": [
{
"CompatibleRuntimes": [ "string" ],
"CreatedDate": "string",
609
AWS Lambda Guía para desarrolladores
ListLayerVersions
"Description": "string",
"LayerVersionArn": "string",
"LicenseInfo": "string",
"Version": number
}
],
"NextMarker": "string"
}
Response Elements
If the action is successful, the service sends back an HTTP 200 response.
A list of versions.
A pagination token returned when the response doesn't contain all versions.
Type: String
Errors
InvalidParameterValueException
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
610
AWS Lambda Guía para desarrolladores
ListLayerVersions
611
AWS Lambda Guía para desarrolladores
ListProvisionedConcurrencyConfigs
ListProvisionedConcurrencyConfigs
Retrieves a list of provisioned concurrency configurations for a function.
Request Syntax
GET /2019-09-30/functions/FunctionName/provisioned-concurrency?
List=ALL&Marker=Marker&MaxItems=MaxItems HTTP/1.1
Name formats
• Function name - my-function.
• Function ARN - arn:aws:lambda:us-west-2:123456789012:function:my-function.
• Partial ARN - 123456789012:function:my-function.
The length constraint applies only to the full ARN. If you specify only the function name, it is limited to
64 characters in length.
Pattern: (arn:(aws[a-zA-Z-]*)?:lambda:)?([a-z]{2}(-gov)?-[a-z]+-\d{1}:)?
(\d{12}:)?(function:)?([a-zA-Z0-9-_]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Required: Yes
Marker (p. 612)
Specify the pagination token that's returned by a previous request to retrieve the next page of results.
MaxItems (p. 612)
Request Body
The request does not have a request body.
Response Syntax
HTTP/1.1 200
Content-type: application/json
{
"NextMarker": "string",
"ProvisionedConcurrencyConfigs": [
{
"AllocatedProvisionedConcurrentExecutions": number,
"AvailableProvisionedConcurrentExecutions": number,
612
AWS Lambda Guía para desarrolladores
ListProvisionedConcurrencyConfigs
"FunctionArn": "string",
"LastModified": "string",
"RequestedProvisionedConcurrentExecutions": number,
"Status": "string",
"StatusReason": "string"
}
]
}
Response Elements
If the action is successful, the service sends back an HTTP 200 response.
Type: String
ProvisionedConcurrencyConfigs (p. 612)
Errors
InvalidParameterValueException
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
613
AWS Lambda Guía para desarrolladores
ListProvisionedConcurrencyConfigs
614
AWS Lambda Guía para desarrolladores
ListTags
ListTags
Returns a function's tags. You can also view tags with GetFunction (p. 559).
Request Syntax
GET /2017-03-31/tags/ARN HTTP/1.1
Pattern: arn:(aws[a-zA-Z-]*)?:lambda:[a-z]{2}(-gov)?-[a-z]+-\d{1}:
\d{12}:function:[a-zA-Z0-9-_]+(:(\$LATEST|[a-zA-Z0-9-_]+))?
Required: Yes
Request Body
The request does not have a request body.
Response Syntax
HTTP/1.1 200
Content-type: application/json
{
"Tags": {
"string" : "string"
}
}
Response Elements
If the action is successful, the service sends back an HTTP 200 response.
Errors
InvalidParameterValueException
615
AWS Lambda Guía para desarrolladores
ListTags
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
616
AWS Lambda Guía para desarrolladores
ListVersionsByFunction
ListVersionsByFunction
Returns a list of versions, with the version-specific configuration of each. Lambda returns up to 50 versions
per call.
Request Syntax
GET /2015-03-31/functions/FunctionName/versions?Marker=Marker&MaxItems=MaxItems HTTP/1.1
Name formats
• Function name - MyFunction.
• Function ARN - arn:aws:lambda:us-west-2:123456789012:function:MyFunction.
• Partial ARN - 123456789012:function:MyFunction.
The length constraint applies only to the full ARN. If you specify only the function name, it is limited to
64 characters in length.
Pattern: (arn:(aws[a-zA-Z-]*)?:lambda:)?([a-z]{2}(-gov)?-[a-z]+-\d{1}:)?
(\d{12}:)?(function:)?([a-zA-Z0-9-_\.]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Required: Yes
Marker (p. 617)
Specify the pagination token that's returned by a previous request to retrieve the next page of results.
MaxItems (p. 617)
Request Body
The request does not have a request body.
Response Syntax
HTTP/1.1 200
Content-type: application/json
{
"NextMarker": "string",
"Versions": [
{
"CodeSha256": "string",
"CodeSize": number,
617
AWS Lambda Guía para desarrolladores
ListVersionsByFunction
"DeadLetterConfig": {
"TargetArn": "string"
},
"Description": "string",
"Environment": {
"Error": {
"ErrorCode": "string",
"Message": "string"
},
"Variables": {
"string" : "string"
}
},
"FileSystemConfigs": [
{
"Arn": "string",
"LocalMountPath": "string"
}
],
"FunctionArn": "string",
"FunctionName": "string",
"Handler": "string",
"KMSKeyArn": "string",
"LastModified": "string",
"LastUpdateStatus": "string",
"LastUpdateStatusReason": "string",
"LastUpdateStatusReasonCode": "string",
"Layers": [
{
"Arn": "string",
"CodeSize": number
}
],
"MasterArn": "string",
"MemorySize": number,
"RevisionId": "string",
"Role": "string",
"Runtime": "string",
"State": "string",
"StateReason": "string",
"StateReasonCode": "string",
"Timeout": number,
"TracingConfig": {
"Mode": "string"
},
"Version": "string",
"VpcConfig": {
"SecurityGroupIds": [ "string" ],
"SubnetIds": [ "string" ],
"VpcId": "string"
}
}
]
}
Response Elements
If the action is successful, the service sends back an HTTP 200 response.
618
AWS Lambda Guía para desarrolladores
ListVersionsByFunction
Type: String
Versions (p. 617)
Errors
InvalidParameterValueException
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
619
AWS Lambda Guía para desarrolladores
PublishLayerVersion
PublishLayerVersion
Creates an AWS Lambda layer from a ZIP archive. Each time you call PublishLayerVersion with the
same layer name, a new version is created.
Add layers to your function with CreateFunction (p. 524) or UpdateFunctionConfiguration (p. 667).
Request Syntax
POST /2018-10-31/layers/LayerName/versions HTTP/1.1
Content-type: application/json
{
"CompatibleRuntimes": [ "string" ],
"Content": {
"S3Bucket": "string",
"S3Key": "string",
"S3ObjectVersion": "string",
"ZipFile": blob
},
"Description": "string",
"LicenseInfo": "string"
}
Pattern: (arn:[a-zA-Z0-9-]+:lambda:[a-zA-Z0-9-]+:\d{12}:layer:[a-zA-Z0-9-_]+)|
[a-zA-Z0-9-_]+
Required: Yes
Request Body
The request accepts the following data in JSON format.
A list of compatible function runtimes. Used for filtering with ListLayers (p. 607) and
ListLayerVersions (p. 609).
620
AWS Lambda Guía para desarrolladores
PublishLayerVersion
Required: No
Content (p. 620)
Required: Yes
Description (p. 620)
Type: String
Required: No
LicenseInfo (p. 620)
Type: String
Required: No
Response Syntax
HTTP/1.1 201
Content-type: application/json
{
"CompatibleRuntimes": [ "string" ],
"Content": {
"CodeSha256": "string",
"CodeSize": number,
"Location": "string"
},
"CreatedDate": "string",
"Description": "string",
"LayerArn": "string",
"LayerVersionArn": "string",
"LicenseInfo": "string",
"Version": number
}
Response Elements
If the action is successful, the service sends back an HTTP 201 response.
621
AWS Lambda Guía para desarrolladores
PublishLayerVersion
The date that the layer version was created, in ISO-8601 format (YYYY-MM-DDThh:mm:ss.sTZD).
Type: String
Description (p. 621)
Type: String
Type: String
Pattern: arn:[a-zA-Z0-9-]+:lambda:[a-zA-Z0-9-]+:\d{12}:layer:[a-zA-Z0-9-_]+
LayerVersionArn (p. 621)
Type: String
Pattern: arn:[a-zA-Z0-9-]+:lambda:[a-zA-Z0-9-]+:\d{12}:layer:[a-zA-Z0-9-_]+:
[0-9]+
LicenseInfo (p. 621)
Type: String
Type: Long
622
AWS Lambda Guía para desarrolladores
PublishLayerVersion
Errors
CodeStorageExceededException
You have exceeded your maximum total code size per account. Learn more
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
623
AWS Lambda Guía para desarrolladores
PublishVersion
PublishVersion
Creates a version from the current code and configuration of a function. Use versions to create a snapshot
of your function code and configuration that doesn't change.
AWS Lambda doesn't publish a version if the function's configuration and code haven't changed since the
last version. Use UpdateFunctionCode (p. 659) or UpdateFunctionConfiguration (p. 667) to update the
function before publishing a version.
Clients can invoke versions directly or with an alias. To create an alias, use CreateAlias (p. 513).
Request Syntax
POST /2015-03-31/functions/FunctionName/versions HTTP/1.1
Content-type: application/json
{
"CodeSha256": "string",
"Description": "string",
"RevisionId": "string"
}
Name formats
• Function name - MyFunction.
• Function ARN - arn:aws:lambda:us-west-2:123456789012:function:MyFunction.
• Partial ARN - 123456789012:function:MyFunction.
The length constraint applies only to the full ARN. If you specify only the function name, it is limited to
64 characters in length.
Pattern: (arn:(aws[a-zA-Z-]*)?:lambda:)?([a-z]{2}(-gov)?-[a-z]+-\d{1}:)?
(\d{12}:)?(function:)?([a-zA-Z0-9-_]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Required: Yes
Request Body
The request accepts the following data in JSON format.
Only publish a version if the hash value matches the value that's specified. Use this option to avoid
publishing a version if the function code has changed since you last updated it. You can get the hash
for the version that you uploaded from the output of UpdateFunctionCode (p. 659).
Type: String
624
AWS Lambda Guía para desarrolladores
PublishVersion
Required: No
Description (p. 624)
A description for the version to override the description in the function configuration.
Type: String
Required: No
RevisionId (p. 624)
Only update the function if the revision ID matches the ID that's specified. Use this option to avoid
publishing a version if the function configuration has changed since you last updated it.
Type: String
Required: No
Response Syntax
HTTP/1.1 201
Content-type: application/json
{
"CodeSha256": "string",
"CodeSize": number,
"DeadLetterConfig": {
"TargetArn": "string"
},
"Description": "string",
"Environment": {
"Error": {
"ErrorCode": "string",
"Message": "string"
},
"Variables": {
"string" : "string"
}
},
"FileSystemConfigs": [
{
"Arn": "string",
"LocalMountPath": "string"
}
],
"FunctionArn": "string",
"FunctionName": "string",
"Handler": "string",
"KMSKeyArn": "string",
"LastModified": "string",
"LastUpdateStatus": "string",
"LastUpdateStatusReason": "string",
"LastUpdateStatusReasonCode": "string",
"Layers": [
{
"Arn": "string",
"CodeSize": number
}
],
"MasterArn": "string",
"MemorySize": number,
625
AWS Lambda Guía para desarrolladores
PublishVersion
"RevisionId": "string",
"Role": "string",
"Runtime": "string",
"State": "string",
"StateReason": "string",
"StateReasonCode": "string",
"Timeout": number,
"TracingConfig": {
"Mode": "string"
},
"Version": "string",
"VpcConfig": {
"SecurityGroupIds": [ "string" ],
"SubnetIds": [ "string" ],
"VpcId": "string"
}
}
Response Elements
If the action is successful, the service sends back an HTTP 201 response.
Type: String
CodeSize (p. 625)
Type: Long
DeadLetterConfig (p. 625)
Type: String
626
AWS Lambda Guía para desarrolladores
PublishVersion
Type: String
Pattern: arn:(aws[a-zA-Z-]*)?:lambda:[a-z]{2}(-gov)?-[a-z]+-\d{1}:
\d{12}:function:[a-zA-Z0-9-_\.]+(:(\$LATEST|[a-zA-Z0-9-_]+))?
FunctionName (p. 625)
Type: String
Pattern: (arn:(aws[a-zA-Z-]*)?:lambda:)?([a-z]{2}(-gov)?-[a-z]+-\d{1}:)?
(\d{12}:)?(function:)?([a-zA-Z0-9-_\.]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Handler (p. 625)
Type: String
Pattern: [^\s]+
KMSKeyArn (p. 625)
The KMS key that's used to encrypt the function's environment variables. This key is only returned if
you've configured a customer managed CMK.
Type: String
Pattern: (arn:(aws[a-zA-Z-]*)?:[a-z0-9-.]+:.*)|()
LastModified (p. 625)
The date and time that the function was last updated, in ISO-8601 format (YYYY-MM-
DDThh:mm:ss.sTZD).
Type: String
LastUpdateStatus (p. 625)
The status of the last update that was performed on the function. This is first set to Successful after
function creation completes.
Type: String
The reason for the last update that was performed on the function.
Type: String
LastUpdateStatusReasonCode (p. 625)
The reason code for the last update that was performed on the function.
Type: String
627
AWS Lambda Guía para desarrolladores
PublishVersion
Type: String
Pattern: arn:(aws[a-zA-Z-]*)?:lambda:[a-z]{2}(-gov)?-[a-z]+-\d{1}:
\d{12}:function:[a-zA-Z0-9-_]+(:(\$LATEST|[a-zA-Z0-9-_]+))?
MemorySize (p. 625)
Type: Integer
Type: String
Role (p. 625)
Type: String
Pattern: arn:(aws[a-zA-Z-]*)?:iam::\d{12}:role/?[a-zA-Z_0-9+=,.@\-_/]+
Runtime (p. 625)
Type: String
The current state of the function. When the state is Inactive, you can reactivate the function by
invoking it.
Type: String
Type: String
StateReasonCode (p. 625)
The reason code for the function's current state. When the code is Creating, you can't invoke or
modify the function.
628
AWS Lambda Guía para desarrolladores
PublishVersion
Type: String
The amount of time in seconds that Lambda allows a function to run before stopping it.
Type: Integer
Type: String
Pattern: (\$LATEST|[0-9]+)
VpcConfig (p. 625)
Errors
CodeStorageExceededException
You have exceeded your maximum total code size per account. Learn more
The RevisionId provided does not match the latest RevisionId for the Lambda function or alias. Call the
GetFunction or the GetAlias API to retrieve the latest RevisionId for your resource.
629
AWS Lambda Guía para desarrolladores
PublishVersion
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
630
AWS Lambda Guía para desarrolladores
PutFunctionConcurrency
PutFunctionConcurrency
Sets the maximum number of simultaneous executions for a function, and reserves capacity for that
concurrency level.
Concurrency settings apply to the function as a whole, including all published versions and the unpublished
version. Reserving concurrency both ensures that your function has capacity to process the specified
number of events simultaneously, and prevents it from scaling beyond that level. Use GetFunction (p. 559)
to see the current setting for a function.
Use GetAccountSettings (p. 550) to see your Regional concurrency limit. You can reserve concurrency for
as many functions as you like, as long as you leave at least 100 simultaneous executions unreserved for
functions that aren't configured with a per-function limit. For more information, see Managing Concurrency.
Request Syntax
PUT /2017-10-31/functions/FunctionName/concurrency HTTP/1.1
Content-type: application/json
{
"ReservedConcurrentExecutions": number
}
Name formats
• Function name - my-function.
• Function ARN - arn:aws:lambda:us-west-2:123456789012:function:my-function.
• Partial ARN - 123456789012:function:my-function.
The length constraint applies only to the full ARN. If you specify only the function name, it is limited to
64 characters in length.
Pattern: (arn:(aws[a-zA-Z-]*)?:lambda:)?([a-z]{2}(-gov)?-[a-z]+-\d{1}:)?
(\d{12}:)?(function:)?([a-zA-Z0-9-_]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Required: Yes
Request Body
The request accepts the following data in JSON format.
Type: Integer
631
AWS Lambda Guía para desarrolladores
PutFunctionConcurrency
Required: Yes
Response Syntax
HTTP/1.1 200
Content-type: application/json
{
"ReservedConcurrentExecutions": number
}
Response Elements
If the action is successful, the service sends back an HTTP 200 response.
The number of concurrent executions that are reserved for this function. For more information, see
Managing Concurrency.
Type: Integer
Errors
InvalidParameterValueException
632
AWS Lambda Guía para desarrolladores
PutFunctionConcurrency
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
633
AWS Lambda Guía para desarrolladores
PutFunctionEventInvokeConfig
PutFunctionEventInvokeConfig
Configures options for asynchronous invocation on a function, version, or alias. If a configuration
already exists for a function, version, or alias, this operation overwrites it. If you exclude any settings,
they are removed. To set one option without affecting existing settings for other options, use
UpdateFunctionEventInvokeConfig (p. 676).
By default, Lambda retries an asynchronous invocation twice if the function returns an error. It retains
events in a queue for up to six hours. When an event fails all processing attempts or stays in the
asynchronous invocation queue for too long, Lambda discards it. To retain discarded events, configure a
dead-letter queue with UpdateFunctionConfiguration (p. 667).
To send an invocation record to a queue, topic, function, or event bus, specify a destination. You can
configure separate destinations for successful invocations (on-success) and events that fail all processing
attempts (on-failure). You can configure destinations in addition to or instead of a dead-letter queue.
Request Syntax
PUT /2019-09-25/functions/FunctionName/event-invoke-config?Qualifier=Qualifier HTTP/1.1
Content-type: application/json
{
"DestinationConfig": {
"OnFailure": {
"Destination": "string"
},
"OnSuccess": {
"Destination": "string"
}
},
"MaximumEventAgeInSeconds": number,
"MaximumRetryAttempts": number
}
Name formats
• Function name - my-function (name-only), my-function:v1 (with alias).
• Function ARN - arn:aws:lambda:us-west-2:123456789012:function:my-function.
• Partial ARN - 123456789012:function:my-function.
You can append a version number or alias to any of the formats. The length constraint applies only to
the full ARN. If you specify only the function name, it is limited to 64 characters in length.
Pattern: (arn:(aws[a-zA-Z-]*)?:lambda:)?([a-z]{2}(-gov)?-[a-z]+-\d{1}:)?
(\d{12}:)?(function:)?([a-zA-Z0-9-_]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Required: Yes
634
AWS Lambda Guía para desarrolladores
PutFunctionEventInvokeConfig
Pattern: (|[a-zA-Z0-9$_-]+)
Request Body
The request accepts the following data in JSON format.
A destination for events after they have been sent to a function for processing.
Destinations
• Function - The Amazon Resource Name (ARN) of a Lambda function.
• Queue - The ARN of an SQS queue.
• Topic - The ARN of an SNS topic.
• Event Bus - The ARN of an Amazon EventBridge event bus.
Required: No
MaximumEventAgeInSeconds (p. 634)
The maximum age of a request that Lambda sends to a function for processing.
Type: Integer
Required: No
MaximumRetryAttempts (p. 634)
The maximum number of times to retry when the function returns an error.
Type: Integer
Required: No
Response Syntax
HTTP/1.1 200
Content-type: application/json
{
"DestinationConfig": {
"OnFailure": {
"Destination": "string"
},
"OnSuccess": {
"Destination": "string"
}
635
AWS Lambda Guía para desarrolladores
PutFunctionEventInvokeConfig
},
"FunctionArn": "string",
"LastModified": number,
"MaximumEventAgeInSeconds": number,
"MaximumRetryAttempts": number
}
Response Elements
If the action is successful, the service sends back an HTTP 200 response.
A destination for events after they have been sent to a function for processing.
Destinations
• Function - The Amazon Resource Name (ARN) of a Lambda function.
• Queue - The ARN of an SQS queue.
• Topic - The ARN of an SNS topic.
• Event Bus - The ARN of an Amazon EventBridge event bus.
Type: String
Pattern: arn:(aws[a-zA-Z-]*)?:lambda:[a-z]{2}(-gov)?-[a-z]+-\d{1}:
\d{12}:function:[a-zA-Z0-9-_]+(:(\$LATEST|[a-zA-Z0-9-_]+))?
LastModified (p. 635)
The date and time that the configuration was last updated, in Unix time seconds.
Type: Timestamp
MaximumEventAgeInSeconds (p. 635)
The maximum age of a request that Lambda sends to a function for processing.
Type: Integer
The maximum number of times to retry when the function returns an error.
Type: Integer
Errors
InvalidParameterValueException
636
AWS Lambda Guía para desarrolladores
PutFunctionEventInvokeConfig
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
637
AWS Lambda Guía para desarrolladores
PutProvisionedConcurrencyConfig
PutProvisionedConcurrencyConfig
Adds a provisioned concurrency configuration to a function's alias or version.
Request Syntax
PUT /2019-09-30/functions/FunctionName/provisioned-concurrency?Qualifier=Qualifier HTTP/1.1
Content-type: application/json
{
"ProvisionedConcurrentExecutions": number
}
Name formats
• Function name - my-function.
• Function ARN - arn:aws:lambda:us-west-2:123456789012:function:my-function.
• Partial ARN - 123456789012:function:my-function.
The length constraint applies only to the full ARN. If you specify only the function name, it is limited to
64 characters in length.
Pattern: (arn:(aws[a-zA-Z-]*)?:lambda:)?([a-z]{2}(-gov)?-[a-z]+-\d{1}:)?
(\d{12}:)?(function:)?([a-zA-Z0-9-_]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Required: Yes
Qualifier (p. 638)
Pattern: (|[a-zA-Z0-9$_-]+)
Required: Yes
Request Body
The request accepts the following data in JSON format.
Type: Integer
638
AWS Lambda Guía para desarrolladores
PutProvisionedConcurrencyConfig
Required: Yes
Response Syntax
HTTP/1.1 202
Content-type: application/json
{
"AllocatedProvisionedConcurrentExecutions": number,
"AvailableProvisionedConcurrentExecutions": number,
"LastModified": "string",
"RequestedProvisionedConcurrentExecutions": number,
"Status": "string",
"StatusReason": "string"
}
Response Elements
If the action is successful, the service sends back an HTTP 202 response.
Type: Integer
Type: Integer
The date and time that a user last updated the configuration, in ISO 8601 format.
Type: String
RequestedProvisionedConcurrentExecutions (p. 639)
Type: Integer
Type: String
For failed allocations, the reason that provisioned concurrency could not be allocated.
639
AWS Lambda Guía para desarrolladores
PutProvisionedConcurrencyConfig
Type: String
Errors
InvalidParameterValueException
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
640
AWS Lambda Guía para desarrolladores
RemoveLayerVersionPermission
RemoveLayerVersionPermission
Removes a statement from the permissions policy for a version of an AWS Lambda layer. For more
information, see AddLayerVersionPermission (p. 506).
Request Syntax
DELETE /2018-10-31/layers/LayerName/versions/VersionNumber/policy/StatementId?
RevisionId=RevisionId HTTP/1.1
Pattern: (arn:[a-zA-Z0-9-]+:lambda:[a-zA-Z0-9-]+:\d{12}:layer:[a-zA-Z0-9-_]+)|
[a-zA-Z0-9-_]+
Required: Yes
RevisionId (p. 641)
Only update the policy if the revision ID matches the ID specified. Use this option to avoid modifying a
policy that has changed since you last read it.
StatementId (p. 641)
The identifier that was specified when the statement was added.
Pattern: ([a-zA-Z0-9-_]+)
Required: Yes
VersionNumber (p. 641)
Required: Yes
Request Body
The request does not have a request body.
Response Syntax
HTTP/1.1 204
Response Elements
If the action is successful, the service sends back an HTTP 204 response with an empty HTTP body.
641
AWS Lambda Guía para desarrolladores
RemoveLayerVersionPermission
Errors
InvalidParameterValueException
The RevisionId provided does not match the latest RevisionId for the Lambda function or alias. Call the
GetFunction or the GetAlias API to retrieve the latest RevisionId for your resource.
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
642
AWS Lambda Guía para desarrolladores
RemovePermission
RemovePermission
Revokes function-use permission from an AWS service or another account. You can get the ID of the
statement from the output of GetPolicy (p. 582).
Request Syntax
DELETE /2015-03-31/functions/FunctionName/policy/StatementId?
Qualifier=Qualifier&RevisionId=RevisionId HTTP/1.1
Name formats
• Function name - my-function (name-only), my-function:v1 (with alias).
• Function ARN - arn:aws:lambda:us-west-2:123456789012:function:my-function.
• Partial ARN - 123456789012:function:my-function.
You can append a version number or alias to any of the formats. The length constraint applies only to
the full ARN. If you specify only the function name, it is limited to 64 characters in length.
Pattern: (arn:(aws[a-zA-Z-]*)?:lambda:)?([a-z]{2}(-gov)?-[a-z]+-\d{1}:)?
(\d{12}:)?(function:)?([a-zA-Z0-9-_]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Required: Yes
Qualifier (p. 643)
Specify a version or alias to remove permissions from a published version of the function.
Pattern: (|[a-zA-Z0-9$_-]+)
RevisionId (p. 643)
Only update the policy if the revision ID matches the ID that's specified. Use this option to avoid
modifying a policy that has changed since you last read it.
StatementId (p. 643)
Pattern: ([a-zA-Z0-9-_.]+)
Required: Yes
Request Body
The request does not have a request body.
643
AWS Lambda Guía para desarrolladores
RemovePermission
Response Syntax
HTTP/1.1 204
Response Elements
If the action is successful, the service sends back an HTTP 204 response with an empty HTTP body.
Errors
InvalidParameterValueException
The RevisionId provided does not match the latest RevisionId for the Lambda function or alias. Call the
GetFunction or the GetAlias API to retrieve the latest RevisionId for your resource.
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
644
AWS Lambda Guía para desarrolladores
TagResource
TagResource
Adds tags to a function.
Request Syntax
POST /2017-03-31/tags/ARN HTTP/1.1
Content-type: application/json
{
"Tags": {
"string" : "string"
}
}
Pattern: arn:(aws[a-zA-Z-]*)?:lambda:[a-z]{2}(-gov)?-[a-z]+-\d{1}:
\d{12}:function:[a-zA-Z0-9-_]+(:(\$LATEST|[a-zA-Z0-9-_]+))?
Required: Yes
Request Body
The request accepts the following data in JSON format.
Required: Yes
Response Syntax
HTTP/1.1 204
Response Elements
If the action is successful, the service sends back an HTTP 204 response with an empty HTTP body.
Errors
InvalidParameterValueException
645
AWS Lambda Guía para desarrolladores
TagResource
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
646
AWS Lambda Guía para desarrolladores
UntagResource
UntagResource
Removes tags from a function.
Request Syntax
DELETE /2017-03-31/tags/ARN?tagKeys=TagKeys HTTP/1.1
Pattern: arn:(aws[a-zA-Z-]*)?:lambda:[a-z]{2}(-gov)?-[a-z]+-\d{1}:
\d{12}:function:[a-zA-Z0-9-_]+(:(\$LATEST|[a-zA-Z0-9-_]+))?
Required: Yes
TagKeys (p. 647)
Required: Yes
Request Body
The request does not have a request body.
Response Syntax
HTTP/1.1 204
Response Elements
If the action is successful, the service sends back an HTTP 204 response with an empty HTTP body.
Errors
InvalidParameterValueException
647
AWS Lambda Guía para desarrolladores
UntagResource
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
648
AWS Lambda Guía para desarrolladores
UpdateAlias
UpdateAlias
Updates the configuration of a Lambda function alias.
Request Syntax
PUT /2015-03-31/functions/FunctionName/aliases/Name HTTP/1.1
Content-type: application/json
{
"Description": "string",
"FunctionVersion": "string",
"RevisionId": "string",
"RoutingConfig": {
"AdditionalVersionWeights": {
"string" : number
}
}
}
Name formats
• Function name - MyFunction.
• Function ARN - arn:aws:lambda:us-west-2:123456789012:function:MyFunction.
• Partial ARN - 123456789012:function:MyFunction.
The length constraint applies only to the full ARN. If you specify only the function name, it is limited to
64 characters in length.
Pattern: (arn:(aws[a-zA-Z-]*)?:lambda:)?([a-z]{2}(-gov)?-[a-z]+-\d{1}:)?
(\d{12}:)?(function:)?([a-zA-Z0-9-_]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Required: Yes
Name (p. 649)
Pattern: (?!^[0-9]+$)([a-zA-Z0-9-_]+)
Required: Yes
Request Body
The request accepts the following data in JSON format.
649
AWS Lambda Guía para desarrolladores
UpdateAlias
Type: String
Required: No
FunctionVersion (p. 649)
Type: String
Pattern: (\$LATEST|[0-9]+)
Required: No
RevisionId (p. 649)
Only update the alias if the revision ID matches the ID that's specified. Use this option to avoid
modifying an alias that has changed since you last read it.
Type: String
Required: No
RoutingConfig (p. 649)
Required: No
Response Syntax
HTTP/1.1 200
Content-type: application/json
{
"AliasArn": "string",
"Description": "string",
"FunctionVersion": "string",
"Name": "string",
"RevisionId": "string",
"RoutingConfig": {
"AdditionalVersionWeights": {
"string" : number
}
}
}
Response Elements
If the action is successful, the service sends back an HTTP 200 response.
650
AWS Lambda Guía para desarrolladores
UpdateAlias
Type: String
Pattern: arn:(aws[a-zA-Z-]*)?:lambda:[a-z]{2}(-gov)?-[a-z]+-\d{1}:
\d{12}:function:[a-zA-Z0-9-_]+(:(\$LATEST|[a-zA-Z0-9-_]+))?
Description (p. 650)
Type: String
Type: String
Pattern: (\$LATEST|[0-9]+)
Name (p. 650)
Type: String
Pattern: (?!^[0-9]+$)([a-zA-Z0-9-_]+)
RevisionId (p. 650)
Type: String
RoutingConfig (p. 650)
Errors
InvalidParameterValueException
The RevisionId provided does not match the latest RevisionId for the Lambda function or alias. Call the
GetFunction or the GetAlias API to retrieve the latest RevisionId for your resource.
651
AWS Lambda Guía para desarrolladores
UpdateAlias
ResourceConflictException
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
652
AWS Lambda Guía para desarrolladores
UpdateEventSourceMapping
UpdateEventSourceMapping
Updates an event source mapping. You can change the function that AWS Lambda invokes, or pause
invocation and resume later from the same location.
The following error handling options are only available for stream sources (DynamoDB and Kinesis):
• BisectBatchOnFunctionError - If the function returns an error, split the batch in two and retry.
• DestinationConfig - Send discarded records to an Amazon SQS queue or Amazon SNS topic.
• MaximumRecordAgeInSeconds - Discard records older than the specified age. Default -1 (infinite).
Minimum 60. Maximum 604800.
• MaximumRetryAttempts - Discard records after the specified number of retries. Default -1 (infinite).
Minimum 0. Maximum 10000. When infinite, failed records will be retried until the record expires.
• ParallelizationFactor - Process multiple batches from each shard concurrently.
Request Syntax
PUT /2015-03-31/event-source-mappings/UUID HTTP/1.1
Content-type: application/json
{
"BatchSize": number,
"BisectBatchOnFunctionError": boolean,
"DestinationConfig": {
"OnFailure": {
"Destination": "string"
},
"OnSuccess": {
"Destination": "string"
}
},
"Enabled": boolean,
"FunctionName": "string",
"MaximumBatchingWindowInSeconds": number,
"MaximumRecordAgeInSeconds": number,
"MaximumRetryAttempts": number,
"ParallelizationFactor": number
}
Required: Yes
Request Body
The request accepts the following data in JSON format.
653
AWS Lambda Guía para desarrolladores
UpdateEventSourceMapping
Type: Integer
Required: No
BisectBatchOnFunctionError (p. 653)
(Streams) If the function returns an error, split the batch in two and retry.
Type: Boolean
Required: No
DestinationConfig (p. 653)
(Streams) An Amazon SQS queue or Amazon SNS topic destination for discarded records.
Required: No
Enabled (p. 653)
If true, the event source mapping is active. Set to false to pause polling and invocation.
Type: Boolean
Required: No
FunctionName (p. 653)
Name formats
• Function name - MyFunction.
• Function ARN - arn:aws:lambda:us-west-2:123456789012:function:MyFunction.
• Version or Alias ARN - arn:aws:lambda:us-
west-2:123456789012:function:MyFunction:PROD.
• Partial ARN - 123456789012:function:MyFunction.
The length constraint applies only to the full ARN. If you specify only the function name, it's limited to
64 characters in length.
Type: String
Pattern: (arn:(aws[a-zA-Z-]*)?:lambda:)?([a-z]{2}(-gov)?-[a-z]+-\d{1}:)?
(\d{12}:)?(function:)?([a-zA-Z0-9-_]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Required: No
MaximumBatchingWindowInSeconds (p. 653)
(Streams) The maximum amount of time to gather records before invoking the function, in seconds.
654
AWS Lambda Guía para desarrolladores
UpdateEventSourceMapping
Type: Integer
Required: No
MaximumRecordAgeInSeconds (p. 653)
(Streams) Discard records older than the specified age. The default value is infinite (-1).
Type: Integer
Required: No
MaximumRetryAttempts (p. 653)
(Streams) Discard records after the specified number of retries. The default value is infinite (-1). When
set to infinite (-1), failed records will be retried until the record expires.
Type: Integer
Required: No
ParallelizationFactor (p. 653)
Type: Integer
Required: No
Response Syntax
HTTP/1.1 202
Content-type: application/json
{
"BatchSize": number,
"BisectBatchOnFunctionError": boolean,
"DestinationConfig": {
"OnFailure": {
"Destination": "string"
},
"OnSuccess": {
"Destination": "string"
}
},
"EventSourceArn": "string",
"FunctionArn": "string",
"LastModified": number,
"LastProcessingResult": "string",
"MaximumBatchingWindowInSeconds": number,
"MaximumRecordAgeInSeconds": number,
"MaximumRetryAttempts": number,
"ParallelizationFactor": number,
"State": "string",
"StateTransitionReason": "string",
655
AWS Lambda Guía para desarrolladores
UpdateEventSourceMapping
"Topics": [ "string" ],
"UUID": "string"
}
Response Elements
If the action is successful, the service sends back an HTTP 202 response.
Type: Integer
(Streams) If the function returns an error, split the batch in two and retry.
Type: Boolean
DestinationConfig (p. 655)
(Streams) An Amazon SQS queue or Amazon SNS topic destination for discarded records.
Type: String
Pattern: arn:(aws[a-zA-Z0-9-]*):([a-zA-Z0-9\-])+:([a-z]{2}(-gov)?-[a-z]+-
\d{1})?:(\d{12})?:(.*)
FunctionArn (p. 655)
Type: String
Pattern: arn:(aws[a-zA-Z-]*)?:lambda:[a-z]{2}(-gov)?-[a-z]+-\d{1}:
\d{12}:function:[a-zA-Z0-9-_]+(:(\$LATEST|[a-zA-Z0-9-_]+))?
LastModified (p. 655)
The date that the event source mapping was last updated, or its state changed, in Unix time seconds.
Type: Timestamp
LastProcessingResult (p. 655)
The result of the last AWS Lambda invocation of your Lambda function.
Type: String
MaximumBatchingWindowInSeconds (p. 655)
(Streams) The maximum amount of time to gather records before invoking the function, in seconds.
Type: Integer
656
AWS Lambda Guía para desarrolladores
UpdateEventSourceMapping
(Streams) The maximum age of a record that Lambda sends to a function for processing.
Type: Integer
(Streams) The maximum number of times to retry when the function returns an error.
Type: Integer
Type: Integer
The state of the event source mapping. It can be one of the following: Creating, Enabling,
Enabled, Disabling, Disabled, Updating, or Deleting.
Type: String
StateTransitionReason (p. 655)
Indicates whether the last change to the event source mapping was made by a user, or by the Lambda
service.
Type: String
Topics (p. 655)
Pattern: ^[^.]([a-zA-Z0-9\-_.]+)
UUID (p. 655)
Type: String
Errors
InvalidParameterValueException
657
AWS Lambda Guía para desarrolladores
UpdateEventSourceMapping
ResourceConflictException
The operation conflicts with the resource's availability. For example, you attempted to update an
EventSource Mapping in CREATING, or tried to delete a EventSource mapping currently in the
UPDATING state.
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
658
AWS Lambda Guía para desarrolladores
UpdateFunctionCode
UpdateFunctionCode
Updates a Lambda function's code.
The function's code is locked when you publish a version. You can't modify the code of a published version,
only the unpublished version.
Request Syntax
PUT /2015-03-31/functions/FunctionName/code HTTP/1.1
Content-type: application/json
{
"DryRun": boolean,
"Publish": boolean,
"RevisionId": "string",
"S3Bucket": "string",
"S3Key": "string",
"S3ObjectVersion": "string",
"ZipFile": blob
}
Name formats
• Function name - my-function.
• Function ARN - arn:aws:lambda:us-west-2:123456789012:function:my-function.
• Partial ARN - 123456789012:function:my-function.
The length constraint applies only to the full ARN. If you specify only the function name, it is limited to
64 characters in length.
Pattern: (arn:(aws[a-zA-Z-]*)?:lambda:)?([a-z]{2}(-gov)?-[a-z]+-\d{1}:)?
(\d{12}:)?(function:)?([a-zA-Z0-9-_]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Required: Yes
Request Body
The request accepts the following data in JSON format.
Set to true to validate the request parameters and access permissions without modifying the function
code.
Type: Boolean
Required: No
659
AWS Lambda Guía para desarrolladores
UpdateFunctionCode
Set to true to publish a new version of the function after updating the code. This has the same effect as
calling PublishVersion (p. 624) separately.
Type: Boolean
Required: No
RevisionId (p. 659)
Only update the function if the revision ID matches the ID that's specified. Use this option to avoid
modifying a function that has changed since you last read it.
Type: String
Required: No
S3Bucket (p. 659)
An Amazon S3 bucket in the same AWS Region as your function. The bucket can be in a different
AWS account.
Type: String
Pattern: ^[0-9A-Za-z\.\-_]*(?<!\.)$
Required: No
S3Key (p. 659)
Type: String
Required: No
S3ObjectVersion (p. 659)
For versioned objects, the version of the deployment package object to use.
Type: String
Required: No
ZipFile (p. 659)
The base64-encoded contents of the deployment package. AWS SDK and AWS CLI clients handle the
encoding for you.
Required: No
Response Syntax
HTTP/1.1 200
Content-type: application/json
660
AWS Lambda Guía para desarrolladores
UpdateFunctionCode
"CodeSha256": "string",
"CodeSize": number,
"DeadLetterConfig": {
"TargetArn": "string"
},
"Description": "string",
"Environment": {
"Error": {
"ErrorCode": "string",
"Message": "string"
},
"Variables": {
"string" : "string"
}
},
"FileSystemConfigs": [
{
"Arn": "string",
"LocalMountPath": "string"
}
],
"FunctionArn": "string",
"FunctionName": "string",
"Handler": "string",
"KMSKeyArn": "string",
"LastModified": "string",
"LastUpdateStatus": "string",
"LastUpdateStatusReason": "string",
"LastUpdateStatusReasonCode": "string",
"Layers": [
{
"Arn": "string",
"CodeSize": number
}
],
"MasterArn": "string",
"MemorySize": number,
"RevisionId": "string",
"Role": "string",
"Runtime": "string",
"State": "string",
"StateReason": "string",
"StateReasonCode": "string",
"Timeout": number,
"TracingConfig": {
"Mode": "string"
},
"Version": "string",
"VpcConfig": {
"SecurityGroupIds": [ "string" ],
"SubnetIds": [ "string" ],
"VpcId": "string"
}
}
Response Elements
If the action is successful, the service sends back an HTTP 200 response.
661
AWS Lambda Guía para desarrolladores
UpdateFunctionCode
Type: String
CodeSize (p. 660)
Type: Long
DeadLetterConfig (p. 660)
Type: String
Type: String
Pattern: arn:(aws[a-zA-Z-]*)?:lambda:[a-z]{2}(-gov)?-[a-z]+-\d{1}:
\d{12}:function:[a-zA-Z0-9-_\.]+(:(\$LATEST|[a-zA-Z0-9-_]+))?
FunctionName (p. 660)
Type: String
Pattern: (arn:(aws[a-zA-Z-]*)?:lambda:)?([a-z]{2}(-gov)?-[a-z]+-\d{1}:)?
(\d{12}:)?(function:)?([a-zA-Z0-9-_\.]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Handler (p. 660)
Type: String
Pattern: [^\s]+
662
AWS Lambda Guía para desarrolladores
UpdateFunctionCode
The KMS key that's used to encrypt the function's environment variables. This key is only returned if
you've configured a customer managed CMK.
Type: String
Pattern: (arn:(aws[a-zA-Z-]*)?:[a-z0-9-.]+:.*)|()
LastModified (p. 660)
The date and time that the function was last updated, in ISO-8601 format (YYYY-MM-
DDThh:mm:ss.sTZD).
Type: String
LastUpdateStatus (p. 660)
The status of the last update that was performed on the function. This is first set to Successful after
function creation completes.
Type: String
The reason for the last update that was performed on the function.
Type: String
LastUpdateStatusReasonCode (p. 660)
The reason code for the last update that was performed on the function.
Type: String
Type: String
Pattern: arn:(aws[a-zA-Z-]*)?:lambda:[a-z]{2}(-gov)?-[a-z]+-\d{1}:
\d{12}:function:[a-zA-Z0-9-_]+(:(\$LATEST|[a-zA-Z0-9-_]+))?
MemorySize (p. 660)
Type: Integer
663
AWS Lambda Guía para desarrolladores
UpdateFunctionCode
Type: String
Role (p. 660)
Type: String
Pattern: arn:(aws[a-zA-Z-]*)?:iam::\d{12}:role/?[a-zA-Z_0-9+=,.@\-_/]+
Runtime (p. 660)
Type: String
The current state of the function. When the state is Inactive, you can reactivate the function by
invoking it.
Type: String
Type: String
StateReasonCode (p. 660)
The reason code for the function's current state. When the code is Creating, you can't invoke or
modify the function.
Type: String
The amount of time in seconds that Lambda allows a function to run before stopping it.
Type: Integer
Type: String
664
AWS Lambda Guía para desarrolladores
UpdateFunctionCode
Pattern: (\$LATEST|[0-9]+)
VpcConfig (p. 660)
Errors
CodeStorageExceededException
You have exceeded your maximum total code size per account. Learn more
The RevisionId provided does not match the latest RevisionId for the Lambda function or alias. Call the
GetFunction or the GetAlias API to retrieve the latest RevisionId for your resource.
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
665
AWS Lambda Guía para desarrolladores
UpdateFunctionCode
666
AWS Lambda Guía para desarrolladores
UpdateFunctionConfiguration
UpdateFunctionConfiguration
Modify the version-specific settings of a Lambda function.
When you update a function, Lambda provisions an instance of the function and its supporting resources.
If your function connects to a VPC, this process can take a minute. During this time, you can't modify
the function, but you can still invoke it. The LastUpdateStatus, LastUpdateStatusReason, and
LastUpdateStatusReasonCode fields in the response from GetFunctionConfiguration (p. 565) indicate
when the update is complete and the function is processing events with the new configuration. For more
information, see Function States.
These settings can vary between versions of a function and are locked when you publish a version. You
can't modify the configuration of a published version, only the unpublished version.
To configure function concurrency, use PutFunctionConcurrency (p. 631). To grant invoke permissions to
an account or AWS service, use AddPermission (p. 509).
Request Syntax
PUT /2015-03-31/functions/FunctionName/configuration HTTP/1.1
Content-type: application/json
{
"DeadLetterConfig": {
"TargetArn": "string"
},
"Description": "string",
"Environment": {
"Variables": {
"string" : "string"
}
},
"FileSystemConfigs": [
{
"Arn": "string",
"LocalMountPath": "string"
}
],
"Handler": "string",
"KMSKeyArn": "string",
"Layers": [ "string" ],
"MemorySize": number,
"RevisionId": "string",
"Role": "string",
"Runtime": "string",
"Timeout": number,
"TracingConfig": {
"Mode": "string"
},
"VpcConfig": {
"SecurityGroupIds": [ "string" ],
"SubnetIds": [ "string" ]
}
}
667
AWS Lambda Guía para desarrolladores
UpdateFunctionConfiguration
Name formats
• Function name - my-function.
• Function ARN - arn:aws:lambda:us-west-2:123456789012:function:my-function.
• Partial ARN - 123456789012:function:my-function.
The length constraint applies only to the full ARN. If you specify only the function name, it is limited to
64 characters in length.
Pattern: (arn:(aws[a-zA-Z-]*)?:lambda:)?([a-z]{2}(-gov)?-[a-z]+-\d{1}:)?
(\d{12}:)?(function:)?([a-zA-Z0-9-_]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Required: Yes
Request Body
The request accepts the following data in JSON format.
A dead letter queue configuration that specifies the queue or topic where Lambda sends asynchronous
events when they fail processing. For more information, see Dead Letter Queues.
Required: No
Description (p. 667)
Type: String
Required: No
Environment (p. 667)
Environment variables that are accessible from function code during execution.
Required: No
FileSystemConfigs (p. 667)
Required: No
668
AWS Lambda Guía para desarrolladores
UpdateFunctionConfiguration
The name of the method within your code that Lambda calls to execute your function. The format
includes the file name. It can also include namespaces and other qualifiers, depending on the runtime.
For more information, see Programming Model.
Type: String
Pattern: [^\s]+
Required: No
KMSKeyArn (p. 667)
The ARN of the AWS Key Management Service (AWS KMS) key that's used to encrypt your function's
environment variables. If it's not provided, AWS Lambda uses a default service key.
Type: String
Pattern: (arn:(aws[a-zA-Z-]*)?:[a-z0-9-.]+:.*)|()
Required: No
Layers (p. 667)
A list of function layers to add to the function's execution environment. Specify each layer by its ARN,
including the version.
Pattern: arn:[a-zA-Z0-9-]+:lambda:[a-zA-Z0-9-]+:\d{12}:layer:[a-zA-Z0-9-_]+:
[0-9]+
Required: No
MemorySize (p. 667)
The amount of memory that your function has access to. Increasing the function's memory also
increases its CPU allocation. The default value is 128 MB. The value must be a multiple of 64 MB.
Type: Integer
Required: No
RevisionId (p. 667)
Only update the function if the revision ID matches the ID that's specified. Use this option to avoid
modifying a function that has changed since you last read it.
Type: String
Required: No
Role (p. 667)
Type: String
Pattern: arn:(aws[a-zA-Z-]*)?:iam::\d{12}:role/?[a-zA-Z_0-9+=,.@\-_/]+
669
AWS Lambda Guía para desarrolladores
UpdateFunctionConfiguration
Required: No
Runtime (p. 667)
Type: String
Required: No
Timeout (p. 667)
The amount of time that Lambda allows a function to run before stopping it. The default is 3 seconds.
The maximum allowed value is 900 seconds.
Type: Integer
Required: No
TracingConfig (p. 667)
Set Mode to Active to sample and trace a subset of incoming requests with AWS X-Ray.
Required: No
VpcConfig (p. 667)
For network connectivity to AWS resources in a VPC, specify a list of security groups and subnets in
the VPC. When you connect a function to a VPC, it can only access resources and the internet through
that VPC. For more information, see VPC Settings.
Required: No
Response Syntax
HTTP/1.1 200
Content-type: application/json
{
"CodeSha256": "string",
"CodeSize": number,
"DeadLetterConfig": {
"TargetArn": "string"
},
"Description": "string",
"Environment": {
"Error": {
"ErrorCode": "string",
"Message": "string"
},
"Variables": {
"string" : "string"
670
AWS Lambda Guía para desarrolladores
UpdateFunctionConfiguration
}
},
"FileSystemConfigs": [
{
"Arn": "string",
"LocalMountPath": "string"
}
],
"FunctionArn": "string",
"FunctionName": "string",
"Handler": "string",
"KMSKeyArn": "string",
"LastModified": "string",
"LastUpdateStatus": "string",
"LastUpdateStatusReason": "string",
"LastUpdateStatusReasonCode": "string",
"Layers": [
{
"Arn": "string",
"CodeSize": number
}
],
"MasterArn": "string",
"MemorySize": number,
"RevisionId": "string",
"Role": "string",
"Runtime": "string",
"State": "string",
"StateReason": "string",
"StateReasonCode": "string",
"Timeout": number,
"TracingConfig": {
"Mode": "string"
},
"Version": "string",
"VpcConfig": {
"SecurityGroupIds": [ "string" ],
"SubnetIds": [ "string" ],
"VpcId": "string"
}
}
Response Elements
If the action is successful, the service sends back an HTTP 200 response.
Type: String
CodeSize (p. 670)
Type: Long
DeadLetterConfig (p. 670)
671
AWS Lambda Guía para desarrolladores
UpdateFunctionConfiguration
Type: String
Type: String
Pattern: arn:(aws[a-zA-Z-]*)?:lambda:[a-z]{2}(-gov)?-[a-z]+-\d{1}:
\d{12}:function:[a-zA-Z0-9-_\.]+(:(\$LATEST|[a-zA-Z0-9-_]+))?
FunctionName (p. 670)
Type: String
Pattern: (arn:(aws[a-zA-Z-]*)?:lambda:)?([a-z]{2}(-gov)?-[a-z]+-\d{1}:)?
(\d{12}:)?(function:)?([a-zA-Z0-9-_\.]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Handler (p. 670)
Type: String
Pattern: [^\s]+
KMSKeyArn (p. 670)
The KMS key that's used to encrypt the function's environment variables. This key is only returned if
you've configured a customer managed CMK.
Type: String
Pattern: (arn:(aws[a-zA-Z-]*)?:[a-z0-9-.]+:.*)|()
LastModified (p. 670)
The date and time that the function was last updated, in ISO-8601 format (YYYY-MM-
DDThh:mm:ss.sTZD).
Type: String
672
AWS Lambda Guía para desarrolladores
UpdateFunctionConfiguration
The status of the last update that was performed on the function. This is first set to Successful after
function creation completes.
Type: String
The reason for the last update that was performed on the function.
Type: String
LastUpdateStatusReasonCode (p. 670)
The reason code for the last update that was performed on the function.
Type: String
Type: String
Pattern: arn:(aws[a-zA-Z-]*)?:lambda:[a-z]{2}(-gov)?-[a-z]+-\d{1}:
\d{12}:function:[a-zA-Z0-9-_]+(:(\$LATEST|[a-zA-Z0-9-_]+))?
MemorySize (p. 670)
Type: Integer
Type: String
Role (p. 670)
Type: String
Pattern: arn:(aws[a-zA-Z-]*)?:iam::\d{12}:role/?[a-zA-Z_0-9+=,.@\-_/]+
Runtime (p. 670)
Type: String
673
AWS Lambda Guía para desarrolladores
UpdateFunctionConfiguration
The current state of the function. When the state is Inactive, you can reactivate the function by
invoking it.
Type: String
Type: String
StateReasonCode (p. 670)
The reason code for the function's current state. When the code is Creating, you can't invoke or
modify the function.
Type: String
The amount of time in seconds that Lambda allows a function to run before stopping it.
Type: Integer
Type: String
Pattern: (\$LATEST|[0-9]+)
VpcConfig (p. 670)
Errors
InvalidParameterValueException
674
AWS Lambda Guía para desarrolladores
UpdateFunctionConfiguration
The RevisionId provided does not match the latest RevisionId for the Lambda function or alias. Call the
GetFunction or the GetAlias API to retrieve the latest RevisionId for your resource.
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
675
AWS Lambda Guía para desarrolladores
UpdateFunctionEventInvokeConfig
UpdateFunctionEventInvokeConfig
Updates the configuration for asynchronous invocation for a function, version, or alias.
Request Syntax
POST /2019-09-25/functions/FunctionName/event-invoke-config?Qualifier=Qualifier HTTP/1.1
Content-type: application/json
{
"DestinationConfig": {
"OnFailure": {
"Destination": "string"
},
"OnSuccess": {
"Destination": "string"
}
},
"MaximumEventAgeInSeconds": number,
"MaximumRetryAttempts": number
}
Name formats
• Function name - my-function (name-only), my-function:v1 (with alias).
• Function ARN - arn:aws:lambda:us-west-2:123456789012:function:my-function.
• Partial ARN - 123456789012:function:my-function.
You can append a version number or alias to any of the formats. The length constraint applies only to
the full ARN. If you specify only the function name, it is limited to 64 characters in length.
Pattern: (arn:(aws[a-zA-Z-]*)?:lambda:)?([a-z]{2}(-gov)?-[a-z]+-\d{1}:)?
(\d{12}:)?(function:)?([a-zA-Z0-9-_]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Required: Yes
Qualifier (p. 676)
Pattern: (|[a-zA-Z0-9$_-]+)
Request Body
The request accepts the following data in JSON format.
676
AWS Lambda Guía para desarrolladores
UpdateFunctionEventInvokeConfig
A destination for events after they have been sent to a function for processing.
Destinations
• Function - The Amazon Resource Name (ARN) of a Lambda function.
• Queue - The ARN of an SQS queue.
• Topic - The ARN of an SNS topic.
• Event Bus - The ARN of an Amazon EventBridge event bus.
Required: No
MaximumEventAgeInSeconds (p. 676)
The maximum age of a request that Lambda sends to a function for processing.
Type: Integer
Required: No
MaximumRetryAttempts (p. 676)
The maximum number of times to retry when the function returns an error.
Type: Integer
Required: No
Response Syntax
HTTP/1.1 200
Content-type: application/json
{
"DestinationConfig": {
"OnFailure": {
"Destination": "string"
},
"OnSuccess": {
"Destination": "string"
}
},
"FunctionArn": "string",
"LastModified": number,
"MaximumEventAgeInSeconds": number,
"MaximumRetryAttempts": number
}
Response Elements
If the action is successful, the service sends back an HTTP 200 response.
677
AWS Lambda Guía para desarrolladores
UpdateFunctionEventInvokeConfig
A destination for events after they have been sent to a function for processing.
Destinations
• Function - The Amazon Resource Name (ARN) of a Lambda function.
• Queue - The ARN of an SQS queue.
• Topic - The ARN of an SNS topic.
• Event Bus - The ARN of an Amazon EventBridge event bus.
Type: String
Pattern: arn:(aws[a-zA-Z-]*)?:lambda:[a-z]{2}(-gov)?-[a-z]+-\d{1}:
\d{12}:function:[a-zA-Z0-9-_]+(:(\$LATEST|[a-zA-Z0-9-_]+))?
LastModified (p. 677)
The date and time that the configuration was last updated, in Unix time seconds.
Type: Timestamp
MaximumEventAgeInSeconds (p. 677)
The maximum age of a request that Lambda sends to a function for processing.
Type: Integer
The maximum number of times to retry when the function returns an error.
Type: Integer
Errors
InvalidParameterValueException
678
AWS Lambda Guía para desarrolladores
Data Types
TooManyRequestsException
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
Data Types
The following data types are supported:
679
AWS Lambda Guía para desarrolladores
Data Types
680
AWS Lambda Guía para desarrolladores
AccountLimit
AccountLimit
Limits that are related to concurrency and storage. All file and storage sizes are in bytes.
Contents
CodeSizeUnzipped
The maximum size of a function's deployment package and layers when they're extracted.
Type: Long
Required: No
CodeSizeZipped
The maximum size of a deployment package when it's uploaded directly to AWS Lambda. Use Amazon
S3 for larger files.
Type: Long
Required: No
ConcurrentExecutions
Type: Integer
Required: No
TotalCodeSize
The amount of storage space that you can use for all deployment packages and layer archives.
Type: Long
Required: No
UnreservedConcurrentExecutions
The maximum number of simultaneous function executions, minus the capacity that's reserved for
individual functions with PutFunctionConcurrency (p. 631).
Type: Integer
Required: No
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
681
AWS Lambda Guía para desarrolladores
AccountUsage
AccountUsage
The number of functions and amount of storage in use.
Contents
FunctionCount
Type: Long
Required: No
TotalCodeSize
The amount of storage space, in bytes, that's being used by deployment packages and layer archives.
Type: Long
Required: No
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
682
AWS Lambda Guía para desarrolladores
AliasConfiguration
AliasConfiguration
Provides configuration information about a Lambda function alias.
Contents
AliasArn
Type: String
Pattern: arn:(aws[a-zA-Z-]*)?:lambda:[a-z]{2}(-gov)?-[a-z]+-\d{1}:
\d{12}:function:[a-zA-Z0-9-_]+(:(\$LATEST|[a-zA-Z0-9-_]+))?
Required: No
Description
Type: String
Required: No
FunctionVersion
Type: String
Pattern: (\$LATEST|[0-9]+)
Required: No
Name
Type: String
Pattern: (?!^[0-9]+$)([a-zA-Z0-9-_]+)
Required: No
RevisionId
Type: String
Required: No
RoutingConfig
683
AWS Lambda Guía para desarrolladores
AliasConfiguration
Required: No
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
684
AWS Lambda Guía para desarrolladores
AliasRoutingConfiguration
AliasRoutingConfiguration
The traffic-shifting configuration of a Lambda function alias.
Contents
AdditionalVersionWeights
The second version, and the percentage of traffic that's routed to it.
Required: No
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
685
AWS Lambda Guía para desarrolladores
Concurrency
Concurrency
Contents
ReservedConcurrentExecutions
The number of concurrent executions that are reserved for this function. For more information, see
Managing Concurrency.
Type: Integer
Required: No
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
686
AWS Lambda Guía para desarrolladores
DeadLetterConfig
DeadLetterConfig
The dead-letter queue for failed asynchronous invocations.
Contents
TargetArn
The Amazon Resource Name (ARN) of an Amazon SQS queue or Amazon SNS topic.
Type: String
Pattern: (arn:(aws[a-zA-Z-]*)?:[a-z0-9-.]+:.*)|()
Required: No
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
687
AWS Lambda Guía para desarrolladores
DestinationConfig
DestinationConfig
A configuration object that specifies the destination of an event after Lambda processes it.
Contents
OnFailure
Required: No
OnSuccess
Required: No
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
688
AWS Lambda Guía para desarrolladores
Environment
Environment
A function's environment variable settings.
Contents
Variables
Required: No
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
689
AWS Lambda Guía para desarrolladores
EnvironmentError
EnvironmentError
Error messages for environment variables that couldn't be applied.
Contents
ErrorCode
Type: String
Required: No
Message
Type: String
Required: No
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
690
AWS Lambda Guía para desarrolladores
EnvironmentResponse
EnvironmentResponse
The results of an operation to update or read environment variables. If the operation is successful, the
response contains the environment variables. If it failed, the response contains details about the error.
Contents
Error
Required: No
Variables
Required: No
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
691
AWS Lambda Guía para desarrolladores
EventSourceMappingConfiguration
EventSourceMappingConfiguration
A mapping between an AWS resource and an AWS Lambda function. See
CreateEventSourceMapping (p. 517) for details.
Contents
BatchSize
Type: Integer
Required: No
BisectBatchOnFunctionError
(Streams) If the function returns an error, split the batch in two and retry.
Type: Boolean
Required: No
DestinationConfig
(Streams) An Amazon SQS queue or Amazon SNS topic destination for discarded records.
Required: No
EventSourceArn
Type: String
Pattern: arn:(aws[a-zA-Z0-9-]*):([a-zA-Z0-9\-])+:([a-z]{2}(-gov)?-[a-z]+-
\d{1})?:(\d{12})?:(.*)
Required: No
FunctionArn
Type: String
Pattern: arn:(aws[a-zA-Z-]*)?:lambda:[a-z]{2}(-gov)?-[a-z]+-\d{1}:
\d{12}:function:[a-zA-Z0-9-_]+(:(\$LATEST|[a-zA-Z0-9-_]+))?
Required: No
LastModified
The date that the event source mapping was last updated, or its state changed, in Unix time seconds.
Type: Timestamp
Required: No
692
AWS Lambda Guía para desarrolladores
EventSourceMappingConfiguration
LastProcessingResult
The result of the last AWS Lambda invocation of your Lambda function.
Type: String
Required: No
MaximumBatchingWindowInSeconds
(Streams) The maximum amount of time to gather records before invoking the function, in seconds.
Type: Integer
Required: No
MaximumRecordAgeInSeconds
(Streams) The maximum age of a record that Lambda sends to a function for processing.
Type: Integer
Required: No
MaximumRetryAttempts
(Streams) The maximum number of times to retry when the function returns an error.
Type: Integer
Required: No
ParallelizationFactor
Type: Integer
Required: No
State
The state of the event source mapping. It can be one of the following: Creating, Enabling,
Enabled, Disabling, Disabled, Updating, or Deleting.
Type: String
Required: No
StateTransitionReason
Indicates whether the last change to the event source mapping was made by a user, or by the Lambda
service.
Type: String
Required: No
693
AWS Lambda Guía para desarrolladores
EventSourceMappingConfiguration
Topics
Pattern: ^[^.]([a-zA-Z0-9\-_.]+)
Required: No
UUID
Type: String
Required: No
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
694
AWS Lambda Guía para desarrolladores
FileSystemConfig
FileSystemConfig
Details about the connection between a Lambda function and an Amazon EFS file system.
Contents
Arn
The Amazon Resource Name (ARN) of the Amazon EFS access point that provides access to the file
system.
Type: String
Pattern: arn:aws[a-zA-Z-]*:elasticfilesystem:[a-z]{2}((-gov)|(-iso(b?)))?-[a-
z]+-\d{1}:\d{12}:access-point/fsap-[a-f0-9]{17}
Required: Yes
LocalMountPath
The path where the function can access the file system, starting with /mnt/.
Type: String
Pattern: ^/mnt/[a-zA-Z0-9-_.]+$
Required: Yes
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
695
AWS Lambda Guía para desarrolladores
FunctionCode
FunctionCode
The code for the Lambda function. You can specify either an object in Amazon S3, or upload a deployment
package directly.
Contents
S3Bucket
An Amazon S3 bucket in the same AWS Region as your function. The bucket can be in a different
AWS account.
Type: String
Pattern: ^[0-9A-Za-z\.\-_]*(?<!\.)$
Required: No
S3Key
Type: String
Required: No
S3ObjectVersion
For versioned objects, the version of the deployment package object to use.
Type: String
Required: No
ZipFile
The base64-encoded contents of the deployment package. AWS SDK and AWS CLI clients handle the
encoding for you.
Required: No
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
696
AWS Lambda Guía para desarrolladores
FunctionCodeLocation
FunctionCodeLocation
Details about a function's deployment package.
Contents
Location
A presigned URL that you can use to download the deployment package.
Type: String
Required: No
RepositoryType
Type: String
Required: No
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
697
AWS Lambda Guía para desarrolladores
FunctionConfiguration
FunctionConfiguration
Details about a function's configuration.
Contents
CodeSha256
Type: String
Required: No
CodeSize
Type: Long
Required: No
DeadLetterConfig
Required: No
Description
Type: String
Required: No
Environment
Required: No
FileSystemConfigs
Required: No
FunctionArn
Type: String
698
AWS Lambda Guía para desarrolladores
FunctionConfiguration
Pattern: arn:(aws[a-zA-Z-]*)?:lambda:[a-z]{2}(-gov)?-[a-z]+-\d{1}:
\d{12}:function:[a-zA-Z0-9-_\.]+(:(\$LATEST|[a-zA-Z0-9-_]+))?
Required: No
FunctionName
Type: String
Pattern: (arn:(aws[a-zA-Z-]*)?:lambda:)?([a-z]{2}(-gov)?-[a-z]+-\d{1}:)?
(\d{12}:)?(function:)?([a-zA-Z0-9-_\.]+)(:(\$LATEST|[a-zA-Z0-9-_]+))?
Required: No
Handler
Type: String
Pattern: [^\s]+
Required: No
KMSKeyArn
The KMS key that's used to encrypt the function's environment variables. This key is only returned if
you've configured a customer managed CMK.
Type: String
Pattern: (arn:(aws[a-zA-Z-]*)?:[a-z0-9-.]+:.*)|()
Required: No
LastModified
The date and time that the function was last updated, in ISO-8601 format (YYYY-MM-
DDThh:mm:ss.sTZD).
Type: String
Required: No
LastUpdateStatus
The status of the last update that was performed on the function. This is first set to Successful after
function creation completes.
Type: String
Required: No
LastUpdateStatusReason
The reason for the last update that was performed on the function.
Type: String
699
AWS Lambda Guía para desarrolladores
FunctionConfiguration
Required: No
LastUpdateStatusReasonCode
The reason code for the last update that was performed on the function.
Type: String
Required: No
Layers
Required: No
MasterArn
Type: String
Pattern: arn:(aws[a-zA-Z-]*)?:lambda:[a-z]{2}(-gov)?-[a-z]+-\d{1}:
\d{12}:function:[a-zA-Z0-9-_]+(:(\$LATEST|[a-zA-Z0-9-_]+))?
Required: No
MemorySize
Type: Integer
Required: No
RevisionId
Type: String
Required: No
Role
Type: String
Pattern: arn:(aws[a-zA-Z-]*)?:iam::\d{12}:role/?[a-zA-Z_0-9+=,.@\-_/]+
Required: No
Runtime
Type: String
700
AWS Lambda Guía para desarrolladores
FunctionConfiguration
Required: No
State
The current state of the function. When the state is Inactive, you can reactivate the function by
invoking it.
Type: String
Required: No
StateReason
Type: String
Required: No
StateReasonCode
The reason code for the function's current state. When the code is Creating, you can't invoke or
modify the function.
Type: String
Required: No
Timeout
The amount of time in seconds that Lambda allows a function to run before stopping it.
Type: Integer
Required: No
TracingConfig
Required: No
Version
Type: String
Pattern: (\$LATEST|[0-9]+)
701
AWS Lambda Guía para desarrolladores
FunctionConfiguration
Required: No
VpcConfig
Required: No
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
702
AWS Lambda Guía para desarrolladores
FunctionEventInvokeConfig
FunctionEventInvokeConfig
Contents
DestinationConfig
A destination for events after they have been sent to a function for processing.
Destinations
• Function - The Amazon Resource Name (ARN) of a Lambda function.
• Queue - The ARN of an SQS queue.
• Topic - The ARN of an SNS topic.
• Event Bus - The ARN of an Amazon EventBridge event bus.
Required: No
FunctionArn
Type: String
Pattern: arn:(aws[a-zA-Z-]*)?:lambda:[a-z]{2}(-gov)?-[a-z]+-\d{1}:
\d{12}:function:[a-zA-Z0-9-_]+(:(\$LATEST|[a-zA-Z0-9-_]+))?
Required: No
LastModified
The date and time that the configuration was last updated, in Unix time seconds.
Type: Timestamp
Required: No
MaximumEventAgeInSeconds
The maximum age of a request that Lambda sends to a function for processing.
Type: Integer
Required: No
MaximumRetryAttempts
The maximum number of times to retry when the function returns an error.
Type: Integer
Required: No
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
703
AWS Lambda Guía para desarrolladores
FunctionEventInvokeConfig
704
AWS Lambda Guía para desarrolladores
Layer
Layer
An AWS Lambda layer.
Contents
Arn
Type: String
Pattern: arn:[a-zA-Z0-9-]+:lambda:[a-zA-Z0-9-]+:\d{12}:layer:[a-zA-Z0-9-_]+:
[0-9]+
Required: No
CodeSize
Type: Long
Required: No
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
705
AWS Lambda Guía para desarrolladores
LayersListItem
LayersListItem
Details about an AWS Lambda layer.
Contents
LatestMatchingVersion
Required: No
LayerArn
Type: String
Pattern: arn:[a-zA-Z0-9-]+:lambda:[a-zA-Z0-9-]+:\d{12}:layer:[a-zA-Z0-9-_]+
Required: No
LayerName
Type: String
Pattern: (arn:[a-zA-Z0-9-]+:lambda:[a-zA-Z0-9-]+:\d{12}:layer:[a-zA-Z0-9-_]+)|
[a-zA-Z0-9-_]+
Required: No
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
706
AWS Lambda Guía para desarrolladores
LayerVersionContentInput
LayerVersionContentInput
A ZIP archive that contains the contents of an AWS Lambda layer. You can specify either an Amazon S3
location, or upload a layer archive directly.
Contents
S3Bucket
Type: String
Pattern: ^[0-9A-Za-z\.\-_]*(?<!\.)$
Required: No
S3Key
Type: String
Required: No
S3ObjectVersion
For versioned objects, the version of the layer archive object to use.
Type: String
Required: No
ZipFile
The base64-encoded contents of the layer archive. AWS SDK and AWS CLI clients handle the
encoding for you.
Required: No
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
707
AWS Lambda Guía para desarrolladores
LayerVersionContentOutput
LayerVersionContentOutput
Details about a version of an AWS Lambda layer.
Contents
CodeSha256
Type: String
Required: No
CodeSize
Type: Long
Required: No
Location
Type: String
Required: No
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
708
AWS Lambda Guía para desarrolladores
LayerVersionsListItem
LayerVersionsListItem
Details about a version of an AWS Lambda layer.
Contents
CompatibleRuntimes
Required: No
CreatedDate
The date that the version was created, in ISO 8601 format. For example,
2018-11-27T15:10:45.123+0000.
Type: String
Required: No
Description
Type: String
Required: No
LayerVersionArn
Type: String
Pattern: arn:[a-zA-Z0-9-]+:lambda:[a-zA-Z0-9-]+:\d{12}:layer:[a-zA-Z0-9-_]+:
[0-9]+
Required: No
LicenseInfo
Type: String
Required: No
709
AWS Lambda Guía para desarrolladores
LayerVersionsListItem
Version
Type: Long
Required: No
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
710
AWS Lambda Guía para desarrolladores
OnFailure
OnFailure
A destination for events that failed processing.
Contents
Destination
Type: String
Pattern: ^$|arn:(aws[a-zA-Z0-9-]*):([a-zA-Z0-9\-])+:([a-z]{2}(-gov)?-[a-z]+-
\d{1})?:(\d{12})?:(.*)
Required: No
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
711
AWS Lambda Guía para desarrolladores
OnSuccess
OnSuccess
A destination for events that were processed successfully.
Contents
Destination
Type: String
Pattern: ^$|arn:(aws[a-zA-Z0-9-]*):([a-zA-Z0-9\-])+:([a-z]{2}(-gov)?-[a-z]+-
\d{1})?:(\d{12})?:(.*)
Required: No
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
712
AWS Lambda Guía para desarrolladores
ProvisionedConcurrencyConfigListItem
ProvisionedConcurrencyConfigListItem
Details about the provisioned concurrency configuration for a function alias or version.
Contents
AllocatedProvisionedConcurrentExecutions
Type: Integer
Required: No
AvailableProvisionedConcurrentExecutions
Type: Integer
Required: No
FunctionArn
Type: String
Pattern: arn:(aws[a-zA-Z-]*)?:lambda:[a-z]{2}(-gov)?-[a-z]+-\d{1}:
\d{12}:function:[a-zA-Z0-9-_]+(:(\$LATEST|[a-zA-Z0-9-_]+))?
Required: No
LastModified
The date and time that a user last updated the configuration, in ISO 8601 format.
Type: String
Required: No
RequestedProvisionedConcurrentExecutions
Type: Integer
Required: No
Status
Type: String
Required: No
713
AWS Lambda Guía para desarrolladores
ProvisionedConcurrencyConfigListItem
StatusReason
For failed allocations, the reason that provisioned concurrency could not be allocated.
Type: String
Required: No
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
714
AWS Lambda Guía para desarrolladores
TracingConfig
TracingConfig
The function's AWS X-Ray tracing configuration. To sample and record incoming requests, set Mode to
Active.
Contents
Mode
Type: String
Required: No
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
715
AWS Lambda Guía para desarrolladores
TracingConfigResponse
TracingConfigResponse
The function's AWS X-Ray tracing configuration.
Contents
Mode
Type: String
Required: No
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
716
AWS Lambda Guía para desarrolladores
VpcConfig
VpcConfig
The VPC security groups and subnets that are attached to a Lambda function. For more information, see
VPC Settings.
Contents
SecurityGroupIds
Required: No
SubnetIds
Required: No
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
717
AWS Lambda Guía para desarrolladores
VpcConfigResponse
VpcConfigResponse
The VPC security groups and subnets that are attached to a Lambda function.
Contents
SecurityGroupIds
Required: No
SubnetIds
Required: No
VpcId
Type: String
Required: No
See Also
For more information about using this API in one of the language-specific AWS SDKs, see the following:
• Las versiones de Microsoft Windows con actualizaciones instaladas a partir de enero de 2005 o fechas
posteriores, contienen al menos uno de los CA necesarios en su lista de confianza.
• Mac OS X 10.4 con Java para Mac OS X 10.4 Release 5 (febrero de 2007), Mac OS X 10.5 (octubre de
2007) y las versiones posteriores contienen al menos uno de los CA necesarios en su lista de confianza.
718
AWS Lambda Guía para desarrolladores
Errores de los certificados cuando se utiliza un SDK
• Red Hat Enterprise Linux 5 (marzo de 2007), 6 y 7 y CentOS 5, 6 y 7 contienen al menos uno de los CA
necesarios en su lista de confianza predeterminada.
• Java 1.4.2_12 (mayo de 2006), 5 Update 2 (marzo de 2005) y todas las versiones posteriores, incluido
Java 6 (diciembre de 2006), 7 y 8, contienen al menos uno de los CA necesarios en su lista de confianza
predeterminada.
Cuando obtenga acceso a los puntos de enlace de la consola de administración de AWS Lambda o de la
API de AWS Lambda, ya sea a través de un navegador o mediante programación, deberá asegurarse de
que las máquinas cliente admiten alguna de las siguientes entidades de certificación:
• Amazon Root CA 1
• Starfield Services Root Certificate Authority - G2
• Starfield Class 2 Certification Authority
Los certificados raíz de las primeras dos entidades están disponibles en Amazon Trust Services, aunque
mantener el equipo actualizado es la solución más sencilla. Para obtener más información sobre los
certificados proporcionados por ACM, consulte Preguntas frecuentes sobre AWS Certificate Manager.
719
AWS Lambda Guía para desarrolladores
AWS glossary
For the latest AWS terminology, see the AWS glossary in the AWS General Reference.
720