Création de fonctions Lambda avec Java - AWS Lambda

Création de fonctions Lambda avec Java

Vous pouvez exécuter du code Java dans AWS Lambda. Lambda fournit des runtimes pour Java qui exécutent votre code afin de traiter des événements. Votre code s’exécute dans un environnement Amazon Linux incluant les informations d’identification AWS d’un rôle AWS Identity and Access Management (IAM) que vous gérez.

Lambda prend en charge les environnements d’exécution Java suivants.

Java
Nom Identifiant Système d’exploitation Architectures Obsolescence (Phase 1)

Java 11

java11

Amazon Linux 2

x86_64, arm64

Java 8

java8.al2

Amazon Linux 2

x86_64, arm64

Java 8

java8

Amazon Linux

x86_64

Lambda fournit les bibliothèques suivantes pour les fonctions Java :

Les fonctions Lambda utilisent un rôle d’exécution pour obtenir l’autorisation d’écrire des journaux dans Amazon CloudWatch Logs, ainsi que d’accéder à d’autres services et ressources. Si vous ne possédez pas encore de rôle d’exécution pour le développement de fonctions, créez-en un.

Pour créer un rôle d’exécution
  1. Ouvrez la page Roles (Rôles) dans la console IAM.

  2. Sélectionnez Créer un rôle.

  3. Créez un rôle avec les propriétés suivantes :

    • Entité de confianceLambda.

    • AutorisationsAWSLambdaBasicExecutionRole.

    • Nom de rôlelambda-role.

    La stratégie AWSLambdaBasicExecutionRole possède les autorisations dont la fonction a besoin pour écrire des journaux dans CloudWatch Logs.

Vous pouvez ajouter des autorisations pour ce rôle plus tard, ou le remplacer par un autre rôle spécifique à une fonction particulière.

Pour créer une fonction Java
  1. Ouvrez la console Lambda.

  2. Sélectionnez Créer une fonction.

  3. Configurez les paramètres suivants :

    • Nommy-function.

    • RuntimeJava 11.

    • RoleChoisissez un rôle existant.

    • Rôle existantlambda-role.

  4. Sélectionnez Créer une fonction.

  5. Pour configurer un événement de test, choisissez Test.

  6. Dans Event name (Nom de l’événement), saisissez test.

  7. Sélectionnez Save Changes.

  8. Pour appeler la fonction, choisissez Test.

La console crée une fonction Lambda avec une classe de gestionnaire nommée Hello. Étant donné que Java est un langage compilé, vous ne pouvez pas afficher ou modifier le code source dans la console Lambda, mais vous pouvez modifier sa configuration, l’appeler et configurer des déclencheurs.

Note

Pour commencer à développer des applications dans votre environnement local, déployez l'un des exemples d'applications disponibles dans le référentiel GitHub de ce guide.

La classe Hello comporte une fonction nommée handleRequest qui accepte un objet d'événement et un objet de contexte. Il s'agit de la fonction de gestionnaire que Lambda appelle lors de l'appel de la fonction. Le runtime de la fonction Java obtient les événements d’appels à partir de Lambda et les transmet au gestionnaire. Dans la configuration de fonction, la valeur de gestionnaire est example.Hello::handleRequest.

Pour mettre à jour le code de la fonction, vous créez un package de déploiement, qui est une archive .zip contenant le code de votre fonction. Au fur et à mesure du développement de votre fonction, nous vous conseillons de stocker le code de votre fonction dans le contrôle de code source, d’ajouter des bibliothèques et d’automatiser les déploiements. Commencez par créer un package de déploiement et mettre à jour votre code dans la ligne de commande.

Le runtime de la fonction transmet un objet de contexte au gestionnaire, en plus de l’événement d’appel. L’objet de contexte contient des informations supplémentaires sur l’appel, la fonction et l’environnement d’exécution. Des informations supplémentaires sont disponibles dans les variables d’environnement.

Votre fonction Lambda intègre un groupe de journaux CloudWatch Logs. Le runtime de la fonction envoie à CloudWatch Logs des détails sur chaque appel. Il relaie tous les journaux que votre fonction génère pendant l’appel. Si votre fonction renvoie une erreur, Lambda met en forme l’erreur et la renvoie à l’appelant.