Verwenden der Lambda-Funktion mit CloudTrail

AWS CloudTrailist ein bei Amazon verfügbarer Dienst, mit dem alle in der AWS-Konsole ausgeführten Aktivitäten protokolliert werden können. Es protokolliert alle API-Aufrufe und speichert den Verlauf, der später zum Debuggen verwendet werden kann. Beachten Sie, dass wir Lambda nicht über CloudTrail auslösen können. Stattdessen speichert CloudTrail den gesamten Verlauf in Form von Protokollen im S3-Bucket, und wir können AWS Lambda von S3 aus auslösen. Sobald Protokolle verarbeitet werden sollen, wird AWS Lambda ausgelöst, wenn Protokolle zum S3-Bucket hinzugefügt werden.

Voraussetzungen

Bevor Sie mit AWS CloudTrail, S3 und AWS Lambda arbeiten, müssen Sie folgende Schritte ausführen:

  • Erstellen Sie einen S3-Bucket zum Speichern von CloudTrail-Protokollen
  • Erstellen Sie einen SNS-Dienst
  • Erstellen Sie einen Trail in CloudTrail und weisen Sie den S3-Bucket und den SNS-Service zu
  • Erstellen Sie eine IAM-Rolle mit Berechtigung.
  • Erstellen Sie eine aws Lambda-Funktion
  • AWS Lambda-Konfiguration

Beispiel

Betrachten wir ein Beispiel, das die Funktionsweise von AWS CloudTrail, S3 und AWS Lambda zeigt. Hier erstellen wir einen Bucket in S3, in dem alle Protokolle für alle in der AWS-Konsole durchgeführten Interaktionen gespeichert werden. Lassen Sie uns ein SNS-Thema erstellen und veröffentlichen. Für diese Aktion werden die Protokolle in S3 als Datei eingegeben. AWS Lambda wird ausgelöst, das E-Mails über den Amazon SES-Dienst sendet.

Das Blockdiagramm zur Erläuterung dieses Vorgangs ist wie folgt:

Erstellen Sie einen S3-Bucket zum Speichern von CloudTrail-Protokollen

Gehen Sie zur AWS-Konsole und klicken Sie auf S3-Dienst. KlickenCreate bucket und geben Sie den Namen des Buckets ein, in dem Sie Cloudtrail-Protokolle speichern möchten, wie gezeigt -

Beachten Sie, dass wir hier einen S3-Bucket erstellt haben cloudtraillogsaws zum Speichern der Protokolle.

Erstellen Sie einen SNS-Dienst

Gehen Sie zur AWS-Konsole und klicken Sie auf Simple notification Service. Wählen Sie Themen auf der linken Seite aus und klicken Sie auf die Schaltfläche Neues Thema erstellen.

Wir haben ein Thema namens erstellt displaytrailein Thema veröffentlichen. Die Details werden in S3bucket gespeichert, das oben erstellt wurde.

Erstellen Sie einen Trail in Cloudtrail und weisen Sie den S3-Bucket und den SNS-Service zu

Gehen Sie zur AWS-Konsole und klicken Sie auf CloudTrail Service von Management-Tools wie gezeigt -

Klicken Trails von der linken Seite wie unten gezeigt -

Klicken Create TrailTaste. Geben Sie dieTrail name, Apply trail to all regions und wähle Yes. Dann werden die Protokolle für die gesamte Region angewendet.

Zum Read/Write events, wählen All. Ergänzen Sie dieS3 bucket und SNS topicDetails wie unten gezeigt. Sie können hier eine neue erstellen oder eine vorhandene hinzufügen.

Beachten Sie, dass Optionen für verfügbar sind encrypt log files, enable log file validation, send sns notification for every log file deliveryusw. Ich habe hier die Standardwerte verwendet. Sie können die Dateiverschlüsselung zulassen und es wird nach dem Verschlüsselungsschlüssel gefragt. Klicken Sie auf die Schaltfläche Trail erstellen, sobald die Details hinzugefügt wurden.

Erstellen Sie eine IAM-Rolle mit Berechtigung

Gehen Sie zur AWS-Konsole und wählen Sie IAM. Erstellen Sie eine Rolle mit Berechtigung für S3, Lambda, CloudTrail und SES zum Senden von E-Mails. Die erstellte Rolle ist wie folgt:

Erstellen Sie eine AWS Lambda-Funktion

Gehen Sie zum AWS-Service und klicken Sie auf LambdaBedienung. Fügen Sie den Funktionsnamen hinzu und wählen Sie Laufzeit alsnodejsund wählen Sie die Rolle aus, die für die Lambda-Funktion erstellt wurde. Es folgt die erstellte Lambda-Funktion.

AWS Lambda-Konfiguration

Als nächstes müssen wir S3 als Auslöser für das erstellte AWS-Lambda hinzufügen.

Fügen Sie die S3-Bucket-Details hinzu, um den Trigger hinzuzufügen, und fügen Sie den folgenden AWS Lambda-Code hinzu:

const aws =  require("aws-sdk");
const sns = new aws.SNS({
region:'us-east-1'
});
var ses = new aws.SES({
   region: 'us-east-1'
});
exports.handler = function(event, context, callback) {
   console.log("AWS lambda and SNS trigger ");
   console.log(event);
   const s3message = "Bucket Name:"+event.Records[0].s3.bucket.name+"\nLog details:"+event.Records[0].s3.object.key;
   console.log(s3message);
   var eParams = {
      Destination: {
         ToAddresses: ["[email protected]"]
      },
      Message: {
         Body: {
            Text: {
               Data:s3message
            }
         },
         Subject: {
            Data: "cloudtrail logs"
         }
      },
      Source: "[email protected]"
   };
   var email = ses.sendEmail(eParams, function(err, data) {
      if (err) console.log(err);
      else {
         console.log("===EMAIL SENT===");
         console.log("EMAIL CODE END");
         console.log('EMAIL: ', email);
         context.succeed(event);
         callback(null, "email is send");
      }
   });
};

Beachten Sie, dass wir den S3-Bucket und die Protokolldetails aus dem Ereignis übernehmen und E-Mails mit dem SES-Dienst senden, wie oben gezeigt.

Jedes Mal, wenn eine Aktivität in der AWS-Konsole stattfindet, werden die Protokolle an den S3-Bucket gesendet. Gleichzeitig wird AWS Lambda ausgelöst und die E-Mail an die im Code angegebene E-Mail-ID gesendet.

Beachten Sie, dass Sie die Protokolle gemäß Ihren Anforderungen in AWS Lambda verarbeiten können.