

Les traductions sont fournies par des outils de traduction automatique. En cas de conflit entre le contenu d'une traduction et celui de la version originale en anglais, la version anglaise prévaudra.

# Tutoriel : enregistrez l'état d'une instance Amazon EC2 à l'aide de EventBridge
<a name="eb-log-ec2-instance-state"></a>

Vous pouvez créer une fonction [AWS Lambda](https://docs.aws.amazon.com/lambda/latest/dg/welcome.html) qui journalise un changement d’état pour une instance [Amazon EC2](https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/concepts.html). Vous pouvez donc créer une [règle](eb-rules.md) qui exécute la fonction Lambda à chaque changement d’état ou chaque fois qu’une transition vers un ou plusieurs états notables se produit. Dans ce didacticiel, vous consignez le lancement d'une nouvelle instance.

**Topics**
+ [Étape 1 : Création d'une AWS Lambda fonction](#eb-ec2-create-lambda-function)
+ [Étape 2 : création d’une règle](#eb-ec2-create-rule)
+ [Étape 3 : test de la règle](#eb-api-test-rule)
+ [Étape 4 : Confirmer la bonne exécution](#success)
+ [Étape 5 : Nettoyer vos ressources](#cleanup)

## Étape 1 : Création d'une AWS Lambda fonction
<a name="eb-ec2-create-lambda-function"></a>

Créez une fonction Lambda pour journaliser les [évènements](eb-events.md) de changement d’état. Lorsque vous créerez la règle à l’étape 2, vous spécifierez cette fonction.

**Pour créer une fonction Lambda**

1. Ouvrez la AWS Lambda console à l'adresse [https://console.aws.amazon.com/lambda/](https://console.aws.amazon.com/lambda/).

1. Choisissez **Créer une fonction**.

1. Choisissez **Créer à partir de zéro**.

1. Saisissez un nom et une description pour la fonction Lambda. Par exemple, nommez la fonction `LogEC2InstanceStateChange`.

1. Gardez les autres options comme valeurs par défaut et choisissez **Créer une fonction**.

1. Dans l’onglet **Code** de la page de fonction, double-cliquez sur **index.js**.

1. Remplacez le code existant par le code suivant.

   ```
   'use strict';
   
   exports.handler = (event, context, callback) => {
       console.log('LogEC2InstanceStateChange');
       console.log('Received event:', JSON.stringify(event, null, 2));
       callback(null, 'Finished');
   };
   ```

1. Choisissez **Deploy** (Déployer).

## Étape 2 : création d’une règle
<a name="eb-ec2-create-rule"></a>

Créez une règle pour exécuter la fonction Lambda que vous avez créée à l’étape 1. La règle s’exécute lorsque vous lancez une instance Amazon EC2.

**Pour créer la EventBridge règle**

1. Ouvrez la EventBridge console Amazon à l'adresse [https://console.aws.amazon.com/events/](https://console.aws.amazon.com/events/).

1. Dans le panneau de navigation, choisissez **Rules**.

1. Choisissez **Créer une règle**.

1. Saisissez un nom et une description pour la règle. Par exemple, nommez la règle `TestRule`

1. Pour **Event bus** (Bus d'événement), sélectionnez le bus d'événement que vous souhaitez associer à cette règle. Si vous souhaitez que cette règle mette en correspondance les événements en provenance de votre compte, sélectionnez **Par défaut**. Lorsqu'un service AWS de votre compte émet un événement, il accède toujours au bus d'événement par défaut de votre compte.

1. Pour **Type de règle**, choisissez **Règle avec un modèle d’événement**.

1. Choisissez **Suivant**.

1. Pour **Source d'événement**, choisissez **Services AWS **.

1. Pour **Event pattern** (Modèle d’événement), procédez comme suit :

   1. Pour **Source d’événement**, sélectionnez **EC2** dans la liste déroulante.

   1. Pour **Type d’événement**, choisissez **Notifications de changement d’état d’instance EC2**.

   1. Choisissez **État(s) spécifique(s)**, puis **En cours d’exécution** dans la liste déroulante.

   1. Sélectionnez **Toute instance**.

1. Choisissez **Suivant**.

1. Pour **Types de cibles**, choisissez **service AWS **.

1. Pour **Sélectionner une cible**, choisissez **Fonction Lambda** dans la liste déroulante.

1. Pour **Fonction**, sélectionnez la fonction Lambda que vous avez créée dans la section **Étape 1 : Créer une fonction Lambda**. Dans cet exemple, sélectionnez `LogEC2InstanceStateChange`.

1. Choisissez **Suivant**.

1. Choisissez **Suivant**.

1. Consultez les détails de la règle et choisissez **Create rule** (Créer une règle).

## Étape 3 : test de la règle
<a name="eb-api-test-rule"></a>

Vous pouvez tester votre règle en arrêtant une instance Amazon EC2 à l'aide de la console Amazon EC2. Attendez quelques minutes que l'instance s'arrête, puis vérifiez vos AWS Lambda métriques sur la CloudWatch console pour vérifier que votre fonction s'est exécutée.

**Pour tester votre règle en arrêtant une instance**

1. Ouvrez la console Amazon EC2 à l’adresse [https://console.aws.amazon.com/ec2/](https://console.aws.amazon.com/ec2/).

1. Lancez une instance. Pour plus d'informations, consultez la section [Lancer votre instance](https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/LaunchingAndUsingInstances.html) dans le guide de l'*utilisateur Amazon EC2*.

1. Arrêtez l’instance. Pour plus d'informations, consultez la section [Arrêter et démarrer votre instance](https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/Stop_Start.html) dans le guide de l'*utilisateur Amazon EC2*.

1. Pour afficher la sortie de la fonction Lambda, procédez de la manière suivante :

   1. Ouvrez la CloudWatch console à l'adresse [https://console.aws.amazon.com/cloudwatch/](https://console.aws.amazon.com/cloudwatch/).

   1. Dans le panneau de navigation, sélectionnez **Logs** (Journaux).

   1. Sélectionnez le nom du groupe de journaux pour votre fonction Lambda (`/aws/lambda/function-name`).

   1. Sélectionnez le nom du flux de journaux pour afficher les données fournies par la fonction concernant l'instance que vous avez arrêtée.

1. (Facultatif) Lorsque vous avez terminé, mettez fin à l'instance arrêtée. Pour plus d’informations, consultez [Résilier une instance](https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/terminating-instances.html) dans le *Guide de l’utilisateur Amazon EC2*.

## Étape 4 : Confirmer la bonne exécution
<a name="success"></a>

Si vous voyez l'événement Lambda dans les CloudWatch journaux, cela signifie que vous avez terminé ce didacticiel avec succès. Si l'événement ne figure pas dans vos CloudWatch journaux, commencez le dépannage en vérifiant que la règle a été créée avec succès et, si la règle semble correcte, vérifiez que le code de votre fonction Lambda est correct.

## Étape 5 : Nettoyer vos ressources
<a name="cleanup"></a>

Vous pouvez maintenant supprimer les ressources que vous avez créées pour ce didacticiel, sauf si vous souhaitez les conserver. En supprimant AWS les ressources que vous n'utilisez plus, vous évitez des frais inutiles sur votre AWS compte.

**Pour supprimer la ou les EventBridge règles**

1. Ouvrez la [page Règles](https://console.aws.amazon.com/events/home#/rules) de la EventBridge console.

1. Sélectionnez la ou les règles que vous avez créées.

1. Sélectionnez **Delete (Supprimer)**.

1. Sélectionnez **Delete (Supprimer)**.

**Pour supprimer la ou les fonctions Lambda**

1. Ouvrez la [page Functions](https://console.aws.amazon.com/lambda/home#/functions) (Fonctions) de la console Lambda.

1. Sélectionnez la ou les fonctions que vous avez créées.

1. Sélectionnez **Actions**, **Supprimer**.

1. Sélectionnez **Supprimer**.