

Le traduzioni sono generate tramite traduzione automatica. In caso di conflitto tra il contenuto di una traduzione e la versione originale in Inglese, quest'ultima prevarrà.

# Creazione di una regola che si attiva su un evento Amazon Aurora
<a name="rds-cloud-watch-events"></a>

Con Amazon EventBridge, puoi automatizzare AWS i servizi e rispondere a eventi di sistema come problemi di disponibilità delle applicazioni o modifiche delle risorse. 

**Topics**
+ [Tutorial: registra le modifiche allo stato delle istanze DB utilizzando Amazon EventBridge](#log-rds-instance-state)

## Tutorial: registra le modifiche allo stato delle istanze DB utilizzando Amazon EventBridge
<a name="log-rds-instance-state"></a>

In questo tutorial, crei una AWS Lambda funzione che registra le modifiche di stato per un'istanza Successivamente crei una regola che esegua la funzione ogni volta che si verifica un cambiamento di stato di un'istanza database RDS esistente. Il tutorial presuppone che si dispone di una piccola istanza di test in esecuzione che è possibile arrestare temporaneamente.

**Importante**  
Non eseguire questo tutorial su un'istanza database di produzione in esecuzione.

**Topics**
+ [Fase 1: Creare una funzione AWS Lambda](#rds-create-lambda-function)
+ [Fase 2: Creazione di una regola](#rds-create-rule)
+ [Fase 3: Test della regola](#rds-test-rule)

### Fase 1: Creare una funzione AWS Lambda
<a name="rds-create-lambda-function"></a>

Crea una funzione Lambda per registrare gli eventi di modifica dello stato. È necessario specificare questa funzione alla creazione della regola.

**Per creare una funzione Lambda**

1. Apri la AWS Lambda console all'indirizzo [https://console.aws.amazon.com/lambda/](https://console.aws.amazon.com/lambda/).

1. Se è la prima volta che utilizzi Lambda, verrà visualizzata una pagina di benvenuto. Selezionare **Get Started Now** (Inizia subito). Altrimenti, scegliere **Create function (Crea funzione)**.

1. Scegli **Author from scratch** (Crea da zero).

1. Nella pagina **Create function (Crea funzione)**, procedere come segue:

   1. Digitare un nome e una descrizione per la funzione Lambda. Ad esempio, denomina la funzione **RDSInstanceStateChange**. 

   1. In **Runtime**, seleziona **Node.js 16x**. 

   1. In **Architecture** (Architettura), scegli **x86\$164**.

   1. In **Execution role (Ruolo di esecuzione)**, esegui una delle operazioni seguenti:
      + Scegliere **Create a new role with basic Lambda permissions (Crea un nuovo ruolo con le autorizzazioni Lambda di base)**.
      + In **Execution role** (Ruolo di esecuzione), sceglie **Use an existing role** (Utilizza un ruolo esistente). Scegli il ruolo che desideri usare. 

   1. Scegli **Crea funzione**.

1. Nella **RDSInstanceStateChange**pagina, procedi come segue:

   1. In **Origine codice**, seleziona **index.js**. 

   1. Nel riquadro di **index.js**, elimina il codice esistente.

   1. Immetti il seguente codice:

      ```
      console.log('Loading function');
      
      exports.handler = async (event, context) => {
          console.log('Received event:', JSON.stringify(event));
      };
      ```

   1. Selezionare **Deploy (Distribuisci)**.

### Fase 2: Creazione di una regola
<a name="rds-create-rule"></a>

Crea una regola per l'esecuzione della funzione Lambda ogni volta che avvii un'istanza Amazon RDS.

**Per creare la EventBridge regola**

1. Apri la EventBridge console Amazon all'indirizzo [https://console.aws.amazon.com/events/](https://console.aws.amazon.com/events/).

1. Nel pannello di navigazione, scegli **Regole**.

1. Scegli **Crea regola**.

1. Immettere un nome e una descrizione per la regola. Ad esempio, specifica **RDSInstanceStateChangeRule**.

1. Scegli **Rule with an event pattern** (Regola con un modello di eventi), quindi seleziona **Next** (Successivo).

1. Per **Event source**, scegli **AWS eventi o eventi per i EventBridge partner**.

1. Scorri verso il basso fino alla sezione **Event pattern** (Modello di eventi).

1. In **Event source (Origine eventi)**, selezionare **Servizi AWS**.

1. In **AWS service** (Servizio AWS ), scegli **Relational Database Service (RDS)**.

1. Per **Tipo di evento**, seleziona **Evento istanza database RDS**.

1. Lascia il modello di eventi predefinito. Quindi scegli **Successivo**.

1. Per **Tipi di destinazione**, scegli **servizio AWS **.

1. Per **Select a target** (Seleziona destinazione), scegli **Lambda function** (Funzione Lambda).

1. In **Function** (Funzione), seleziona la funzione Lambda che hai creato. Quindi scegli **Successivo**.

1. In **Configure tags** (Configura tag), scegli **Next** (Successivo).

1. Esamina i passaggi nella regola. Quindi scegli **Create rule** (Crea regola).

### Fase 3: Test della regola
<a name="rds-test-rule"></a>

Per verificare la regola, arresta un'istanza database RDS. Dopo aver atteso alcuni minuti perché l'istanza venga avviata e inizializzata, verifica che la funzione Lambda sia stata richiamata.

**Per effettuare il test della regola arrestando un'istanza database**

1. Aprire la console Amazon RDS all'indirizzo [https://console.aws.amazon.com/rds/](https://console.aws.amazon.com/rds/).

1. Arresta un'istanza database RDS.

1. Apri la EventBridge console Amazon all'indirizzo [https://console.aws.amazon.com/events/](https://console.aws.amazon.com/events/).

1. Nel pannello di navigazione, seleziona **Regole**, scegli il nome della regola creata.

1. In **Dettagli della regola** scegli **Monitoraggio**.

   Verrai reindirizzato alla CloudWatch console Amazon. Se non vieni reindirizzato, fai clic su **Visualizza le metriche in**. CloudWatch

1. In **Tutti i parametri**, seleziona il nome della regola creata.

   Il grafico deve indicare che la regola è stata richiamata.

1. Nel pannello di navigazione, selezionare **Log groups (Gruppi di log)**.

1. Scegli il nome del gruppo di log per la tua funzione Lambda (***function-name*/aws/lambda/**).

1. Scegliere il nome del flusso di log per visualizzare i dati forniti dalla funzione per l'istanza avviata. Sarà visualizzato un evento ricevuto simile a quello seguente:

   ```
   {
       "version": "0",
       "id": "12a345b6-78c9-01d2-34e5-123f4ghi5j6k",
       "detail-type": "RDS DB Instance Event",
       "source": "aws.rds",
       "account": "111111111111",
       "time": "2021-03-19T19:34:09Z",
       "region": "us-east-1",
       "resources": [
           "arn:aws:rds:us-east-1:111111111111:db:testdb"
       ],
       "detail": {
           "EventCategories": [
               "notification"
           ],
           "SourceType": "DB_INSTANCE",
           "SourceArn": "arn:aws:rds:us-east-1:111111111111:db:testdb",
           "Date": "2021-03-19T19:34:09.293Z",
           "Message": "DB instance stopped",
           "SourceIdentifier": "testdb",
           "EventID": "RDS-EVENT-0087"
       }
   }
   ```

   Per altri esempi di eventi RDS in formato JSON, vedere [Panoramica degli eventi per Aurora](working-with-events.md#rds-cloudwatch-events.sample).

1. (Facoltativo) Al termine, puoi aprire la console Amazon RDS e avviare l'istanza terminata.