Ausführen und Aufrufen der Lambda-Funktion

In diesem Kapitel werden der Prozess zum Ausführen und Aufrufen der Lambda-Funktion und die damit verbundenen Schritte ausführlich erläutert.

AWS Lambda-Ausführungsmodell

Die Ausführung von AWS hängt von den Konfigurationsdetails ab, die für die AWS Lambda-Funktion hinzugefügt wurden. Wenn die Funktion erstellt wird, gibt es einememory und time allotted, die für die Ausführung der AWS Lambda-Funktion verwendet wird.

Mit Hilfe der Konfigurationsdetails erstellt AWS Lambda einen Ausführungskontext. Der Ausführungskontext ist eine temporäre Laufzeitumgebung, die mit externen Abhängigkeiten wie Datenbankverbindungen, http-Endpunkten, Bibliotheken von Drittanbietern usw. ausgestattet ist.

Wenn die AWS Lambda-Funktion zum ersten Mal aufgerufen wird oder wenn die Lambda-Funktion aktualisiert wird, wird aufgrund der Einrichtung des Ausführungskontexts nur eine geringe Latenz hinzugefügt. Die nachfolgenden Anrufe sind jedoch schneller als die ersten. AWS Lambda versucht, den Ausführungskontext erneut zu verwenden, wenn die Lambda-Funktion in kürzerer Zeit aufgerufen wird.

Die Wiederverwendung des Ausführungskontexts hat folgende Auswirkungen:

  • Wenn für die Ausführung von Lambda eine Datenbankverbindung hergestellt wurde, wird die Verbindung zur Wiederverwendung beibehalten. Der Lambda-Code muss also so sein, dass die Verbindung zuerst überprüft werden muss - falls vorhanden und wiederverwendet; Andernfalls müssen wir eine neue Verbindung herstellen.

  • Der Ausführungskontext verwaltet einen Speicherplatz von 500 MB in /tmpVerzeichnis. Die erforderlichen Daten werden in diesem Verzeichnis zwischengespeichert. Sie können den Code zusätzlich überprüfen lassen, um festzustellen, ob die Daten vorhanden sind.

  • Wenn die Rückrufe oder einige Hintergrundprozesse nicht vollständig sind, als die Lambda-Funktion aufgerufen wurde, wird die Ausführung gestartet, wenn die Lambda-Funktion erneut aufgerufen wird. Falls dies nicht erforderlich ist, stellen Sie sicher, dass alle Prozesse ordnungsgemäß abgeschlossen sind, wenn die Funktionsausführung abgeschlossen ist.

Sie sollten den Ausführungskontext und die im tmp-Verzeichnis gespeicherten Daten verwenden. Sie müssen dem Code die erforderlichen Überprüfungen hinzufügen, um festzustellen, ob die erforderlichen Daten vorhanden sind, bevor Sie neue erstellen. Dies spart Zeit bei der Ausführung und beschleunigt die Ausführung.

Aufrufen der AWS Lambda-Funktion

Wir können AWS manuell mit aufrufen aws cli. Wir haben bereits gesehen, wie AWS Lambda mit erstellt und bereitgestellt wirdcli. Hier erstellen wir zunächst eine Funktion mitaws cli und rufen Sie das gleiche auf.

Erstellen einer AWS Lambda-Funktion mit AWS CLI

Mit den folgenden Befehlen können Sie die AWS Lambda-Funktion mit erstellen aws cli - -

Commands

create-function 
--function-name <value>
--runtime <value>
--role <value>
--handler <value>
[--code <value>] 
[--description <value>] 
[--timeout <value>] 
[--memory-size <value>] 
[--environment <value>] 
[--kms-key-arn <value>] 
[--tags <value>] 
[--zip-file <value>] 
[--cli-input-json <value>]

Command with values

aws lambda create-function 
--function-name "lambdainvoke" 
--runtime "nodejs8.10" 
--role "arn:aws:iam::625297745038:role/lambdaapipolicy" 
--handler "index.handler" 
--timeout 5 
--memory-size 256 
--zip-file "fileb://C:\nodeproject\index.zip"

Die Ausgabe ist wie unten gezeigt -

Die in der AWS-Konsole erstellte Funktion ist wie folgt:

Jetzt können Sie die Funktion mit dem folgenden Befehl aufrufen:invoke

--function-name <value>
[--invocation-type <value>]
[--log-type <value>]
[--client-context <value>]
[--payload <value>]
[--qualifier <value>]
outfile <value>

Options

--function-name − Geben Sie den Namen der Funktion an, die Sie aufrufen möchten.

--invocation-type(string) − Standardmäßig ist der Aufruftyp requestresponse. Die Werte, die für den Aufruftyp verfügbar sind, sindRequestResponse, Event und DryRun.

  • Der Ereignisaufruftyp soll für die asynchrone Antwort verwendet werden.

  • DryRun ist zu verwenden, wenn Sie die Lambda-Funktion überprüfen möchten, ohne sie ausführen zu müssen.

--log-type − Es wird sein Tailwenn der Aufruftyp RequestResponse ist. Es gibt die letzten 4 KB Base64-codierten Protokolldaten an. Mögliche Werte sindTail und None.

--client-context −Sie können kundenspezifische Details an die Lambda-Funktion übergeben. Der Client-Kontext muss im JSON-Format und Base64-codiert sein. Die maximale Dateigröße beträgt 3583 Byte.

--payload − Eingabe des JSON-Formats in Ihre Lambda-Funktion.

--qualifier −Sie können die Lambda-Funktionsversion oder den Aliasnamen angeben. Wenn Sie die Funktionsversion übergeben, verwendet die API die qualifizierte Funktion arn, um die Lambda-Funktion aufzurufen. Wenn Sie einen Aliasnamen angeben, verwendet die API den Alias ​​ARN, um die Lambda-Funktion aufzurufen.

outfile − Dies ist der Dateiname, in dem der Inhalt gespeichert wird.

Command with values

aws lambda invoke --function-name "lambdainvoke" --log-type 
Tail C:\nodeproject\outputfile.txt

Sie können die Payload-Option verwenden, um ein Dummy-Ereignis im JSON-Format an die Lambda-Funktion zu senden, wie unten gezeigt.

Der zugehörige AWS Lambda-Code lautet wie folgt:

exports.handler = async (event, callback) => {
   console.log("Hello => "+ event.name);
   console.log("Address =>"+ event.addr);
   callback(null, 'Hello '+event.name +" and address is "+ event.addr);
};

Beachten Sie, dass wir im Code eine Konsole haben event.name und event.addr. Lassen Sie uns nun die Payload-Option in aws cli verwenden, um das Ereignis mit Namen und Adresse wie folgt zu senden:

aws lambda invoke --function-name "lambdainvoke" --log-type 
Tail --payload file://C:\clioutput\input.txt C:\clioutput\outputfile.txt

Thenpayload nimmt die Eingabe als Dateipfad mit json-Eingabe wie gezeigt -

{"name":"Roy Singh", "addr":"Mumbai"}

Die entsprechende Ausgabe ist wie unten gezeigt -

Die Ausgabe wird in der Datei gespeichert C:\clioutput\outputfile.txt wie folgt -

"Hello Roy Singh and address is Mumbai"

Beispielereignisse

Sie können die AWS Lambda-Funktion testen, indem Sie ein Beispielereignis übergeben. Dieser Abschnitt enthält einige Beispielereignisse für AWS Services. Du kannst den ... benutzeninvokeBefehl zum Testen der Ausgabe, wenn sie mit einem der Dienste ausgelöst wird. Beachten Sie die Codes für die entsprechenden Beispielereignisse unten -

Amazon S3 Put-Beispielereignis

{
  "Records": [{
      "eventVersion": "2.0",
      "eventTime": "1970-01-01T00:00:00.000Z",
      "requestParameters": {
         "SourceIPAddress": "127.0.0.1"
      },
      "s3": {
         "configurationId": "testConfigRule",
         "object": {
            "eTag": "0123456789abcdef0123456789abcdef",
            "sequencer": "0A1B2C3D4E5F678901",
            "key": "HappyFace.jpg",
            "size": 1024
         },
         "bucket": { 
            "arn": bucketarn,
            "name": "Sourcebucket",
            "ownerIdentity": {
               "principalId": "EXAMPLE"
            }
         },
         "s3SchemaVersion": "1.0"
      },
      "responseElements": {
         "x-amz-id-2": "EXAMPLE123/5678abcdefghijklambdaisawesome/mnopqrstuvwxyzABCDEFGH",
         "x-amz-request-id": "EXAMPLE123456789"
      },
      "awsRegion": "us-east-1",
      "eventName": "ObjectCreated:Put",
      "userIdentity": {
         "principalId": "EXAMPLE"
      },
      "eventSource": "aws:s3"
   }]
}

Um das zu bekommen details of the file from the s3 put eventkönnen Sie den folgenden Befehl verwenden:

event.Records[0].s3.object.key   //will display the name of the file

Zu get the bucket namekönnen Sie den folgenden Befehl verwenden:

event.Records[0].s3.bucket.name  //will give the name of the bucket.

Zu see the EventNamekönnen Sie den folgenden Befehl verwenden:

event.Records[0].eventName    // will display the eventname

Amazon S3 Beispielereignis löschen

{
   "Records": [{
      "eventVersion": "2.0",
      "eventTime": "1970-01-01T00:00:00.000Z",
      "requestParameters": {
         "SourceIPAddress": "127.0.0.1"
      },
      "s3": {
         "configurationId": "testConfigRule",
         "object": {
            "sequencer": "0A1B2C3D4E5F678901",
            "key": "HappyFace.jpg"
         },
         "bucket": {
            "arn": bucketarn,
            "name": "Sourcebucket",
            "ownerIdentity": {
               "principalId": "EXAMPLE"
            }
         },
        "s3SchemaVersion": "1.0"
      },
      "responseElements": {
         "x-amz-id-2": "EXAMPLE123/5678abcdefghijklambdaisawesome/mnopqrstuvwxyzABCDEFGH",
         "x-amz-request-id": "EXAMPLE123456789"
      },
      "awsRegion": "us-east-1",
      "eventName": "ObjectRemoved:Delete",
      "userIdentity": {
         "principalId": "EXAMPLE"
      },
      "eventSource": "aws:s3"
   }]
}

Amazon DynamoDB

Amazon DynamoDB kann ein Ereignis in AWS Lambda sein, wenn Änderungen an der DynamoDB-Tabelle vorgenommen werden. Wir können Vorgänge wie das Hinzufügen von Einträgen, das Aktualisieren und Löschen von Datensätzen aus der DynamodDB-Tabelle ausführen.

Ein Beispielereignis für das Hinzufügen, Einfügen und Löschen von DynamoDB-Ereignissen wird hier angezeigt.

{
  "Records": [{
      "eventID": "1",
      "eventVersion": "1.0",
      "dynamodb": {
         "Keys": {
            "Id": {
               "N": "101"
            }
         },
         "NewImage": {
            "Message": {
               "S": "New item!"
            },
            "Id": {
               "N": "101"
            }
         },
         "StreamViewType": "NEW_AND_OLD_IMAGES",
         "SequenceNumber": "111",
         "SizeBytes": 26
      },
      "awsRegion": "us-west-2",
      "eventName": "INSERT",
      "eventSourceARN": eventSourcearn,
      "eventSource": "aws:dynamodb"
   },
   {
      "eventID": "2",
      "eventVersion": "1.0",
      "dynamodb": {
         "OldImage": {
            "Message": {
               "S": "New item!"
            },
            "Id": {
               "N": "101"
            }
         },
        "SequenceNumber": "222",
        "Keys": {
            "Id": {
               "N": "101"
            }
         },
        "SizeBytes": 59,
        "NewImage": {
            "Message": {
               "S": "This item has changed"
            },
            "Id": {
				   "N": "101"
            }
         },
         "StreamViewType": "NEW_AND_OLD_IMAGES"
      },
      "awsRegion": "us-west-2",
      "eventName": "MODIFY",
      "eventSourceARN": Sourcearn,
      "eventSource": "aws:dynamodb"
   },
   {      
   "eventID": "3",
      "eventVersion": "1.0",
      "dynamodb": {
         "Keys": {
            "Id": {
               "N": "101"
            }
         },
         "SizeBytes": 38,
         "SequenceNumber": "333",
         "OldImage": {
            "Message": {
               "S": "This item has changed"
            },
            "Id": {
               "N": "101"
            }
         },
         "StreamViewType": "NEW_AND_OLD_IMAGES"
      },      "awsRegion": "us-west-2",
      "eventName": "REMOVE",
      "eventSourceARN": Sourcearn,
      "eventSource": "aws:dynamodb"    
   }]
}

Amazon Simple Notification Service

AWS Lambda kann hilfreich sein, um die in erstellte Benachrichtigung zu verarbeiten Simple Notification Service (SNS). Immer wenn eine Nachricht in SNS veröffentlicht wird, kann die Lambda-Funktion mit einem SNS-Ereignis ausgelöst werden, das Details zu den Nachrichten enthält. Diese Nachrichten können innerhalb der Lambda-Funktion verarbeitet und je nach Anforderung an andere Dienste gesendet werden.

Sobald die Nachricht eingegeben wurde, löst SNS die Lambda-Funktion aus. Wenn ein Fehler versucht, die Lambda-Funktion aufzurufen, versucht SNS erneut, die Lambda-Funktion bis zu dreimal aufzurufen.

Amazon SNS-Beispielereignis

Ein Beispielereignis, das alle Details enthält, die in der AWS Lambda-Funktion verfügbar sind, um den weiteren Prozess auszuführen, ist unten dargestellt -

{
  "Records": [{
      "EventVersion": "1.0",
      "EventSubscriptionArn": eventsubscriptionarn,
      "EventSource": "aws:sns",
      "Sns": {
         "SignatureVersion": "1",
         "Timestamp": "1970-01-01T00:00:00.000Z",
         "Signature": "EXAMPLE",
         "SigningCertUrl": "EXAMPLE",
         "MessageId": "95df01b4-ee98-5cb9-9903-4c221d41eb5e",
         "Message": "Hello from SNS!",
         "MessageAttributes": {
            "Test": {
               "Type": "String",
               "Value": "TestString"
            },
            "TestBinary": {
               "Type": "Binary",
               "Value": "TestBinary"
            }
         },
         "Type": "Notification",
         "UnsubscribeUrl": "EXAMPLE",
         "TopicArn": topicarn,
         "Subject": "TestInvoke"
      }
   }]
}

Amazon Simple Mail Service

Der Amazon Simple Mail Service kann zum Senden und Empfangen von Nachrichten verwendet werden. Die AWS Lambda-Funktion kann beim Empfang der Nachricht im Simple Mail Service aufgerufen werden.

Beispielereignis für Amazon SES-E-Mail-Empfang

Die Details des SES-Ereignisses bei Verwendung in AWS Lambda sind nachstehend aufgeführt:

{
  "Records": [{
      "eventVersion": "1.0",
      "ses": {
         "mail": {
            "commonHeaders": {
               "from": [
                  "Jane Doe <[email protected]>"
               ],
            "to": [
               "[email protected]"
            ],
            "returnPath": "[email protected]",
            "messageId": "<0123456789Source.com>",
            "date": "Wed, 7 Oct 2015 12:34:56 -0700",
            "subject": "Test Subject"
         },
         "example": "[email protected]",
         "timestamp": "1970-01-01T00:00:00.000Z",
         "destination": [
            "[email protected]"
         ],
         "headers": [{
            "name": "Return-Path",
            "value": "<[email protected]>"
         },
         {
            "name": "Received",
            "value": "from mailer.example.com (mailer.example.com [203.0.113.1]) by inbound-smtp.us-west-2.amazonaws.com with SMTP id o3vrnil0e2ic for [email protected]; Wed, 07 Oct 2015 12:34:56 +0000 (UTC)"
         },
         {
            "name": "DKIM-Signature",
            "value": "v=1; a=rsa-sha256; c=relaxed/relaxed; d=example.com; s=example; h=mime-version:from:date:message-id:subject:to:content-type; bh=jX3F0bCAI7sIbkHyy3mLYO28ieDQz2R0P8HwQkklFj4=; b=sQwJ+LMe9RjkesGu+vqU56asvMhrLRRYrWCbV"
         },
         {
            "name": "MIME-Version",
            "value": "1.0"
         },
         {
            "name": "From",
            "value": "Jane Doe <[email protected]>"
         },
         {
            "name": "Date",
            "value": "Wed, 7 Oct 2015 12:34:56 -0700"
         },
         {
            "name": "Message-ID",
            "value": "<0123456789example.com>"
         },
         {
            "name": "Subject",
            "value": "Test Subject"
         },
         {
            "name": "To",
            "value": "[email protected]"
         },
         {
            "name": "Content-Type",
            "value": "text/plain; charset=UTF-8"
         }],
         "headersTruncated": false,
         "messageId": "o3vrnil0e2ic28tr"
      },
      "receipt": {
         "recipients": [
            "[email protected]"
         ],
         "timestamp": "1970-01-01T00:00:00.000Z",
         "spamVerdict": {
            "status": "PASS"
         },
         "dkimVerdict": {
            "status": "PASS"
         },
         "processingTimeMillis": 574,
         "action": {
            "type": "Lambda",
            "invocationType": "Event",
            "functionArn": "arn:aws:lambda:us-west-2:012345678912:function:example"
         },
         "spfVerdict": {
            "status": "PASS"
         },
         "virusVerdict": {
            "status": "PASS"
         }
      }
   },
   "eventexample": "aws:ses"
   }]
}

Amazon Cloudwatch-Protokolle

AWS Lambda kann über das Amazon CloudWatch-Protokoll ausgelöst werden CloudWatch Logs Subscriptions. CloudWatch Logs-Abonnements enthalten Echtzeitdaten zu den Protokollen, die in AWS Lambda verarbeitet und analysiert werden können oder zum Laden auf andere Systeme verwendet werden können.

Beispielereignis für Amazon CloudWatch-Protokolle

{
   "awslogs": {
      "data": "H4sIAAAAAAAAAHWPwQqCQBCGX0Xm7EFtK+smZBEUgXoLCdMhFtKV3akI8d0bLYmibvPPN3wz00CJxmQnTO41whwW
      QRIctmEcB6sQbFC3CjW3XW8kxpOpP+OC22d1Wml1qZkQGtoMsScxaczKN3plG8zlaHIta5KqWsozoTYw3/djzwhpL
      wivWFGHGpAFe7DL68JlBUk+l7KSN7tCOEJ4M3/qOI49vMHj+zCKdlFqLaU2ZHV2a4Ct/an0/ivdX8oYc1UVX860fQ
      DQiMdxRQEAAA=="
   }
}

Amazon API Gateway

Die AWS Lambda-Funktion kann am aufgerufen werden httpsURL. IT kann am durchgeführt werdenGET, POST, PUT. Wenn die https-URL aufgerufen wird, wird auch die AWS Lambda-Funktion ausgelöst und die mit get / post an https übergebenen Daten können in AWS Lambda zur Verfügung gestellt werden, um sie in DynamoDB einzufügen oder E-Mails zu senden usw.

API-Gateway-Proxy-Anforderungsereignis

{
   "path": "/test/hello",
   "headers": {
      "Accept":  "text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8",
      "Accept-Encoding": "gzip, deflate, lzma, sdch, br",
      "Accept-Language": "en-US,en;q=0.8",
      "CloudFront-Forwarded-Proto": "https",
      "CloudFront-Is-Desktop-Viewer": "true",
      "CloudFront-Is-Mobile-Viewer": "false",
      "CloudFront-Is-SmartTV-Viewer": "false",
      "CloudFront-Is-Tablet-Viewer": "false",
      "CloudFront-Viewer-Country": "US",
      "Host": "wt6mne2s9k.execute-api.us-west-2.amazonaws.com",
      "Upgrade-Insecure-Requests": "1",
      "User-Agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_11_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/52.0.2743.82 Safari/537.36 OPR/39.0.2256.48",
      "Via": "1.1 fb7cca60f0ecd82ce07790c9c5eef16c.cloudfront.net (CloudFront)",
      "X-Amz-Cf-Id": "nBsWBOrSHMgnaROZJK1wGCZ9PcRcSpq_oSXZNQwQ10OTZL4cimZo3g==",
      "X-Forwarded-For": "192.168.100.1, 192.168.1.1",
      "X-Forwarded-Port": "443",
      "X-Forwarded-Proto": "https"
   },
   "pathParameters": {
      "proxy": "hello"
   },
   "requestContext": {
      "accountId": "123456789012",
      "reexampleId": "us4z18",
      "stage": "test",
      "requestId": "41b45ea3-70b5-11e6-b7bd-69b5aaebc7d9",
	   "identity": {
         "cognitoIdentityPoolId": "",
         "accountId": "",
         "cognitoIdentityId": "",
         "caller": "",
         "apiKey": "",
         "exampleIp": "192.168.100.1",
         "cognitoAuthenticationType": "",
         "cognitoAuthenticationProvider": "",
         "userArn": "",
         "userAgent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_11_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/52.0.2743.82 Safari/537.36 OPR/39.0.2256.48",
         "user": ""
      },
      "reexamplePath": "/{proxy+}",
      "httpMethod": "GET",
      "apiId": "wt6mne2s9k"
   },
   "reexample": "/{proxy+}",
   "httpMethod": "GET",
   "queryStringParameters": {
      "name": "me"
   },
   "stageVariables": {
      "stageVarName": "stageVarValue"
   }
}

API Gateway Proxy Response Event

{
   "statusCode": 200,
   "headers": {
      "Accept": "text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8",
      "Accept-Encoding": "gzip, deflate, lzma, sdch, br",
      "Accept-Language": "en-US,en;q=0.8",
      "CloudFront-Forwarded-Proto": "https",
      "CloudFront-Is-Desktop-Viewer": "true",
      "CloudFront-Is-Mobile-Viewer": "false",
      "CloudFront-Is-SmartTV-Viewer": "false",
      "CloudFront-Is-Tablet-Viewer": "false",
      "CloudFront-Viewer-Country": "US",
      "Host": "wt6mne2s9k.execute-api.us-west-2.amazonaws.com",
      "Upgrade-Insecure-Requests": "1",
      "User-Agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_11_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/52.0.2743.82 Safari/537.36 OPR/39.0.2256.48",
      "Via": "1.1 fb7cca60f0ecd82ce07790c9c5eef16c.cloudfront.net (CloudFront)",
      "X-Amz-Cf-Id": "nBsWBOrSHMgnaROZJK1wGCZ9PcRcSpq_oSXZNQwQ10OTZL4cimZo3g==",
      "X-Forwarded-For": "192.168.100.1, 192.168.1.1",
      "X-Forwarded-Port": "443",
      "X-Forwarded-Proto": "https"
   },
   "body": "Hello World"
}