

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à.

# Richiamo di funzioni Lambda mediante notifiche Amazon SNS
<a name="with-sns"></a>

Si può utilizzare una funzione Lambda per elaborare le notifiche Amazon Simple Notification Service (Amazon SNS). Amazon SNS supporta le funzioni Lambda come destinazione per i messaggi inviati a un argomento. Puoi sottoscrivere la funzione ad argomenti nello stesso account o in altri account AWS. Per la procedura guidata dettagliata, consulta [Tutorial: Utilizzo AWS Lambda con Amazon Simple Notification Service](with-sns-example.md).

Lambda supporta i trigger SNS solo per argomenti SNS standard. Gli argomenti FIFO non sono supportati.

Lambda elabora i messaggi SNS in modo asincrono mettendoli in coda e gestendo i nuovi tentativi. Se Amazon SNS non è in grado di raggiungere Lambda o il messaggio viene rifiutato, Amazon SNS riprova a intervalli crescenti per diverse ore. Per ulteriori informazioni, consulta [Affidabilità](https://aws.amazon.com/sns/faqs/#Reliability) nelle domande frequenti su Amazon SNS.

**avvertimento**  
Gli strumenti di mappatura dell'origine degli eventi elaborano ogni evento almeno una volta e può verificarsi un'elaborazione duplicata dei record. Per evitare potenziali problemi legati agli eventi duplicati, ti consigliamo vivamente di rendere idempotente il codice della funzione. Per ulteriori informazioni, consulta [Come posso rendere idempotente la mia funzione Lambda](https://repost.aws/knowledge-center/lambda-function-idempotent) nel Knowledge Center AWS.

## Utilità di idempotenza di Powertools per Lambda AWS
<a name="services-sns-powertools-idempotency"></a>

L'utilità di idempotenza di Powertools for AWS Lambda rende le funzioni Lambda idempotenti. È disponibile per Python, TypeScript, Java e.NET. [https://docs.powertools.aws.dev/lambda/dotnet/utilities/idempotency/](https://docs.powertools.aws.dev/lambda/dotnet/utilities/idempotency/)

**Topics**
+ [Utilità di idempotenza di Powertools per Lambda AWS](#services-sns-powertools-idempotency)
+ [Aggiunta di un trigger di argomento Amazon SNS per una funzione Lambda utilizzando la console](#sns-trigger-console)
+ [Aggiunta manuale di un trigger di argomento Amazon SNS per una funzione Lambda](#sns-trigger-manual)
+ [Esempio di forma evento SNS](#sns-sample-event)
+ [Tutorial: Utilizzo AWS Lambda con Amazon Simple Notification Service](with-sns-example.md)

## Aggiunta di un trigger di argomento Amazon SNS per una funzione Lambda utilizzando la console
<a name="sns-trigger-console"></a>

Per aggiungere un argomento SNS come trigger per una funzione Lambda, il modo più semplice è utilizzare la console Lambda. Quando aggiungi il trigger tramite la console, Lambda configura automaticamente le autorizzazioni e gli abbonamenti necessari per iniziare a ricevere eventi dall'argomento SNS.

**Per aggiungere un argomento SNS come trigger per una funzione Lambda (console)**

1. Aprire la pagina [Funzioni](https://console.aws.amazon.com/lambda/home#/functions) della console Lambda.

1. Scegli il nome della funzione per la quale si desidera aggiungere il trigger.

1. Scegli **Configurazione**, quindi scegli **Trigger**.

1. Selezionare **Add trigger** (Aggiungi trigger).

1. In **Configurazione del trigger**, nell'elenco a discesa, scegli **SNS**.

1. Per **Argomento SNS**, scegli l'argomento SNS da sottoscrivere.

## Aggiunta manuale di un trigger di argomento Amazon SNS per una funzione Lambda
<a name="sns-trigger-manual"></a>

Per configurare manualmente un trigger SNS per una funzione Lambda, è necessario completare i seguenti passaggi:
+ Definisci una policy basata sulle risorse per la tua funzione per consentire a SNS di richiamarla.
+ Sottoscrivere la funzione Lambda all'argomento Amazon SNS.
**Nota**  
Se l'argomento SNS e la funzione Lambda si trovano in account AWS diversi, è inoltre necessario concedere autorizzazioni aggiuntive per consentire le sottoscrizioni tra account all'argomento SNS. Per maggiori informazioni, consulta [Concedere l'autorizzazioni tra account per la sottoscrizione di Amazon SNS](with-sns-example.md#with-sns-subscription-grant-permission).

Puoi usare la AWS Command Line Interface (AWS CLI) per completare entrambi questi passaggi. Innanzitutto, per definire una policy basata sulle risorse per una funzione Lambda che consenta le chiamate SNS, usa il comando AWS CLI seguente. Assicurati di sostituire il valore di `--function-name` con il nome della funzione Lambda e il valore di `--source-arn` con l'ARN dell'argomento SNS.

```
aws lambda add-permission --function-name {{example-function}} \
    --source-arn {{arn:aws:sns:us-east-1:123456789012:sns-topic-for-lambda}} \
    --statement-id function-with-sns --action "lambda:InvokeFunction" \
    --principal sns.amazonaws.com
```

Per sottoscrivere la tua funzione all'argomento SNS, usa il comando AWS CLI seguente. Assicurati di sostituire il valore di `--topic-arn` con l'ARN dell'argomento SNS e il valore di `--notification-endpoint` con l'ARN della funzione Lambda.

```
aws sns subscribe --protocol lambda \
    --region us-east-1 \
    --topic-arn {{arn:aws:sns:us-east-1:123456789012:sns-topic-for-lambda}} \
    --notification-endpoint {{arn:aws:lambda:us-east-1:123456789012:function:example-function}}
```

## Esempio di forma evento SNS
<a name="sns-sample-event"></a>

Amazon SNS richiama la funzione in modo [asincrono](invocation-async.md) con un evento che contiene un messaggio e dei metadati.

**Example Evento messaggio di Amazon SNS**  

```
{
  "Records": [
    {
      "EventVersion": "1.0",
      "EventSubscriptionArn": "arn:aws:sns:us-east-1: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-1.amazonaws.com/SimpleNotificationService-ac565b8b1a6c5d002d285f9598aa1d9b.pem",
        "MessageId": "95df01b4-ee98-5cb9-9903-4c221d41eb5e",
        "Message": "Hello from SNS!",
        "MessageAttributes": {
          "Test": {
            "Type": "String",
            "Value": "TestString"
          },
          "TestBinary": {
            "Type": "Binary",
            "Value": "TestBinary"
          }
        },
        "Type": "Notification",
        "UnsubscribeUrl": "https://sns.us-east-1.amazonaws.com/?Action=Unsubscribe&amp;SubscriptionArn=arn:aws:sns:us-east-1:123456789012:test-lambda:21be56ed-a058-49f5-8c98-aedd2564c486",
        "TopicArn":"arn:aws:sns:us-east-1:123456789012:sns-lambda",
        "Subject": "TestInvoke"
      }
    }
  ]
}
```