

# Solución de problemas de errores de SnapStart para funciones de Lambda
<a name="snapstart-troubleshooting"></a>

En esta página se abordan los problemas comunes que se producen al usar SnapStart de Lambda, incluidos los errores de creación de instantáneas, los errores de tiempo de espera y los errores de servicio interno.

## SnapStartNotReadyException
<a name="snapstartnotreadyexception"></a>

**Error:** se produjo un error (SnapStartNotReadyException) al llamar a la operación Invoke20150331: Lambda está inicializando la función. Estará lista para invocarse una vez que el estado de la función pase a estar ACTIVO.

### Causas habituales
<a name="snapstartnotreadyexception-cause"></a>

Este error se produce al intentar invocar una versión de función que se encuentra en el [estado](snapstart-activate.md#snapstart-function-states) `Inactive`. La versión de la función pasa a un estado `Inactive` cuando no se ha invocado durante 14 días o cuando Lambda recicla periódicamente el entorno de ejecución.

### Resolución
<a name="snapstartnotreadyexception-resolution"></a>

Espere hasta que la versión de la función alcance el estado `Active` y, a continuación, vuelva a invocarla.

## SnapStartTimeoutException
<a name="snapstart-invocation-failure"></a>

**Problema:** recibe una excepción `SnapStartTimeoutException` cuando intenta invocar una versión de la función SnapStart.

### Causa habitual
<a name="snapstart-invocation-failure-cause"></a>

Durante la fase de [Restauración](lambda-runtime-environment.md#runtimes-lifecycle-restore), Lambda restaura el tiempo de ejecución de Java y ejecuta todos los [enlaces en tiempo de ejecución](snapstart-runtime-hooks.md) posteriores a la restauración. Si un enlace de tiempo de ejecución posterior a la restauración se ejecuta durante más de 10 segundos, la fase `Restore` expira y se obtiene un error cuando se intenta invocar la función. Los problemas con la conexión de red y las credenciales también pueden provocar tiempos de espera de la fase `Restore`.

### Resolución
<a name="snapstart-invocation-failure-resolution"></a>

Compruebe los registros de CloudWatch de la función para ver si hay errores de tiempo de espera que se hayan producido durante la fase [Restore](lambda-runtime-environment.md#runtimes-lifecycle-restore). Asegúrese de que todos los enlaces posteriores a la restauración se completen en menos de 10 segundos.

**Example Registro de CloudWatch**  

```
{ "cause": "Lambda couldn't restore the snapshot within the timeout limit. (Service: Lambda, Status Code: 408, Request ID: 11a222c3-410f-427c-ab22-931d6bcbf4f2)", "error": "Lambda.SnapStartTimeoutException"}
```

## Error de servicio interno 500
<a name="snapstart-500-error"></a>

**Error:** Lambda no ha podido crear una nueva instantánea porque ha alcanzado el límite de creación simultánea de instantáneas.

### Causa habitual
<a name="snapstart-500-error-cause"></a>

Un error 500 es un error interno del propio servicio de Lambda y no un problema con la función o el código. Estos errores suelen ser intermitentes.

### Resolución
<a name="snapstart-500-error-resolution"></a>

Intente volver a publicar la versión de la función.

## 401 sin autorización
<a name="snapstart-401-unauthorized"></a>

**Error:** el token de sesión o la clave de cabecera son incorrectos

### Causa habitual
<a name="snapstart-401-unauthorized-cause"></a>

Este error se produce al utilizar el [Almacén de parámetros de AWS Systems Manager y la extensión AWS Secrets Manager](with-secrets-manager.md) con SnapStart de Lambda.

### Resolución
<a name="snapstart-401-unauthorized-resolution"></a>

El Almacén de parámetros de AWS Systems Manager y la extensión AWS Secrets Manager no son compatibles con SnapStart. La extensión genera credenciales para comunicarse con AWS Secrets Manager durante la inicialización de la función, lo que provoca errores en las credenciales caducadas cuando se utiliza con SnapStart.

## UnknownHostException (Java)
<a name="snapstart-dns-caching"></a>

**Error:** no se puede ejecutar la solicitud HTTP: el certificado `abc.us-east-1.amazonaws.com` no coincide con ninguno de los nombres alternativos del asunto.

### Causa habitual
<a name="snapstart-dns-caching-cause"></a>

Las funciones de Lambda ya almacenan en caché las respuestas de DNS. Si utiliza otra caché de DNS con SnapStart, es posible que se agoten los tiempos de espera de conexión cuando la función se reanude a partir de una instantánea.

### Resolución
<a name="snapstart-dns-caching-resolution"></a>

Para evitar errores `UnknownHostException` en el tiempo de ejecución de Java 11, se recomienda establecer el valor `networkaddress.cache.negative.ttl` en 0. En Java 17 y tiempos de ejecución posteriores, este paso no es necesario. Puede establecer esta propiedad para una función de Lambda con la variable de entorno `AWS_LAMBDA_JAVA_NETWORKADDRESS_CACHE_NEGATIVE_TTL=0`.

## Fallos en la creación de la instantánea
<a name="snapstart-creation-failure"></a>

**Error:** AWS Lambda no pudo invocar la función SnapStart. Si el error persiste, compruebe los registros de CloudWatch de su función para comprobar si hay errores de inicialización.

### Resolución
<a name="snapstart-creation-failure-resolution"></a>

Revise los registros de Amazon CloudWatch de su función para ver los tiempos de espera de los [enlaces de tiempo de ejecución](snapstart-runtime-hooks.md) anteriores a la comprobación. También puede intentar publicar una nueva versión de la función, lo que a veces puede resolver el problema.

## Latencia de creación de instantáneas
<a name="snapstart-creation-latency"></a>

**Problema:** al publicar una nueva versión de una función, la función permanece en el [estado](snapstart-activate.md#snapstart-function-states) `Pending` durante mucho tiempo.

### Causa habitual
<a name="snapstart-creation-latency-cause"></a>

Cuando Lambda crea una instantánea, el código de inicialización puede ejecutarse durante un máximo de 15 minutos. El límite de tiempo es de 130 segundos o el [tiempo de espera de la función configurado](configuration-timeout.md) (máximo de 900 segundos), lo que sea mayor.

Si la función está [adjunta a una VPC](configuration-vpc.md#configuration-vpc-attaching), es posible que Lambda también necesite crear interfaces de red antes de que la función pase a un estado `Active`. Si intenta invocar la versión de la función mientras la función está en estado `Pending`, es posible que obtenga un error 409 `ResourceConflictException`. Si la función se invoca mediante un punto de conexión de Amazon API Gateway, es posible que aparezca un error 500 en API Gateway.

### Resolución
<a name="snapstart-creation-latency-resolution"></a>

Espere al menos 15 minutos a que se inicialice la versión de la función antes de invocarla.