Arbeiten mit Ebenen für Java-Lambda-Funktionen - AWS Lambda

Die vorliegende Übersetzung wurde maschinell erstellt. Im Falle eines Konflikts oder eines Widerspruchs zwischen dieser übersetzten Fassung und der englischen Fassung (einschließlich infolge von Verzögerungen bei der Übersetzung) ist die englische Fassung maßgeblich.

Arbeiten mit Ebenen für Java-Lambda-Funktionen

Eine Lambda-Schicht ist ein ZIP-Dateiarchiv, das zusätzlichen Code oder Daten enthält. Ebenen enthalten üblicherweise Bibliotheksabhängigkeiten, eine benutzerdefinierte Laufzeit oder Konfigurationsdateien. Das Erstellen einer Ebene umfasst drei allgemeine Schritte:

  1. Package Sie Ihren Layer-Inhalt. Das bedeutet, dass Sie ein ZIP-Dateiarchiv erstellen müssen, das die Abhängigkeiten enthält, die Sie in Ihren Funktionen verwenden möchten.

  2. Erstellen Sie die Ebene in Lambda.

  3. Fügen Sie die Ebene zu Ihren Funktionen hinzu.

Dieses Thema enthält Schritte und Anleitungen zum ordnungsgemäßen Verpacken und Erstellen einer Java-Lambda-Schicht mit externen Bibliotheksabhängigkeiten.

Voraussetzungen

Um die Schritte in diesem Abschnitt ausführen zu können, benötigen Sie Folgendes:

Anmerkung

Stellen Sie sicher, dass die Java-Version, auf die sich Maven bezieht, mit der Java-Version der Funktion übereinstimmt, die Sie bereitstellen möchten. Für eine Java 21-Funktion sollte der mvn -v Befehl beispielsweise die Java-Version 21 in der Ausgabe auflisten:

Apache Maven 3.8.6 ... Java version: 21.0.2, vendor: Oracle Corporation, runtime: /Library/Java/JavaVirtualMachines/jdk-21.jdk/Contents/Home ...

In diesem Thema verweisen wir auf die layer-javaBeispielanwendung im awsdocs-Repository GitHub . Diese Anwendung enthält Skripte, die die Abhängigkeiten herunterladen und die Ebene generieren. Die Anwendung enthält auch eine entsprechende Funktion, die Abhängigkeiten aus der Ebene verwendet. Nachdem Sie eine Ebene erstellt haben, können Sie die entsprechende Funktion bereitstellen und aufrufen, um zu überprüfen, ob alles ordnungsgemäß funktioniert. Da Sie die Java 21-Runtime für die Funktionen verwenden, müssen die Ebenen auch mit Java 21 kompatibel sein.

Die layer-java Beispielanwendung enthält ein einzelnes Beispiel in zwei Unterverzeichnissen. Das layer Verzeichnis enthält eine pom.xml Datei, die die Layer-Abhängigkeiten definiert, sowie Skripts zur Generierung der Ebene. Das function Verzeichnis enthält eine Beispielfunktion, mit deren Hilfe getestet werden kann, ob der Layer funktioniert. In diesem Tutorial wird beschrieben, wie Sie diesen Layer erstellen und verpacken.

Java-Layer-Kompatibilität mit Amazon Linux

Der erste Schritt beim Erstellen einer Ebene besteht darin, den gesamten Ebeneninhalt in einem ZIP-Dateiarchiv zu bündeln. Da Lambda-Funktionen unter Amazon Linux ausgeführt werden, muss Ihr Ebeneninhalt in einer Linux-Umgebung kompiliert und erstellt werden können.

Java-Code ist plattformunabhängig konzipiert, sodass Sie Ihre Ebenen auf Ihrem lokalen Computer packen können, auch wenn dieser keine Linux-Umgebung verwendet. Nachdem Sie den Java-Layer auf Lambda hochgeladen haben, ist er weiterhin mit Amazon Linux kompatibel.

Layer-Pfade für Java-Laufzeiten

Wenn Sie einer Funktion eine Ebene hinzufügen, lädt Lambda den Ebeneninhalt in das Verzeichnis /opt der Ausführungsumgebung. Für jede Lambda-Laufzeit enthält die Variable PATH bereits spezifische Ordnerpfade innerhalb des Verzeichnisses /opt. Um sicherzustellen, dass die PATH Variable Ihren Layer-Inhalt aufnimmt, sollte Ihre Layer-.zip-Datei ihre Abhängigkeiten in den folgenden Ordnerpfaden haben:

  • java/lib

Die resultierende Layer-ZIP-Datei, die Sie in diesem Tutorial erstellen, hat beispielsweise die folgende Verzeichnisstruktur:

layer_content.zip └ java └ lib └ layer-java-layer-1.0-SNAPSHOT.jar

Die layer-java-layer-1.0-SNAPSHOT.jar JAR-Datei (eine Uber-JAR-Datei, die alle unsere erforderlichen Abhängigkeiten enthält) befindet sich korrekt im Verzeichnis. java/lib Dadurch wird sichergestellt, dass Lambda die Bibliothek bei Funktionsaufrufen finden kann.

Verpacken des Layer-Inhalts

In diesem Beispiel packen Sie die folgenden zwei Java-Bibliotheken in eine einzige JAR-Datei:

  • aws-lambda-java-core— Ein minimaler Satz von Schnittstellendefinitionen für die Arbeit mit Java in AWS Lambda

  • Jackson — Eine beliebte Suite von Datenverarbeitungstools, insbesondere für die Arbeit mit JSON.

Gehen Sie wie folgt vor, um den Layer-Inhalt zu installieren und zu verpacken.

So installieren und verpacken Sie Ihre Layer-Inhalte
  1. Klonen Sie das aws-lambda-developer-guide GitHub Repo, das den Beispielcode enthält, den Sie im sample-apps/layer-java Verzeichnis benötigen.

    git clone https://github.com/awsdocs/aws-lambda-developer-guide.git
  2. Navigieren Sie zum layer Verzeichnis der layer-java Beispiel-App. Dieses Verzeichnis enthält die Skripts, die Sie verwenden, um den Layer ordnungsgemäß zu erstellen und zu verpacken.

    cd aws-lambda-developer-guide/sample-apps/layer-java/layer
  3. Untersuchen Sie die pom.xmlDatei. In <dependencies> diesem Abschnitt definieren Sie die Abhängigkeiten, die Sie in die Ebene aufnehmen möchten, nämlich die jackson-databind Bibliotheken aws-lambda-java-core und. Sie können diese Datei so aktualisieren, dass sie alle Abhängigkeiten enthält, die Sie in Ihre eigene Ebene aufnehmen möchten.

    Beispiel pom.xml
    <dependencies> <dependency> <groupId>com.amazonaws</groupId> <artifactId>aws-lambda-java-core</artifactId> <version>1.2.3</version> </dependency> <dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-databind</artifactId> <version>2.17.0</version> </dependency> </dependencies>
    Anmerkung

    Der <build> Abschnitt dieser pom.xml Datei enthält zwei Plugins. Das maven-compiler-pluginkompiliert den Quellcode. Das maven-shade-pluginpackt deine Artefakte in ein einziges Uber-Jar.

  4. Stellen Sie sicher, dass Sie berechtigt sind, beide Skripts auszuführen.

    chmod 744 1-install.sh && chmod 744 2-package.sh
  5. Führen Sie das 1-install.shSkript mit dem folgenden Befehl aus:

    ./1-install.sh

    Dieses Skript wird mvn clean install im aktuellen Verzeichnis ausgeführt. Dadurch wird das Uber-Jar mit allen erforderlichen Abhängigkeiten im target/ Verzeichnis erstellt.

    Beispiel 1-install.sh
    mvn clean install
  6. Führen Sie das 2-package.shSkript mit dem folgenden Befehl aus:

    ./2-package.sh

    Dieses Skript erstellt die java/lib Verzeichnisstruktur, die Sie benötigen, um Ihren Layer-Inhalt ordnungsgemäß zu verpacken. Anschließend kopiert es die Uber-Jar-Datei aus dem /target Verzeichnis in das neu erstellte java/lib Verzeichnis. Schließlich komprimiert das Skript den Inhalt des java Verzeichnisses in eine Datei mit dem Namen. layer_content.zip Dies ist die ZIP-Datei für Ihren Layer. Sie können die Datei entpacken und überprüfen, ob sie die richtige Dateistruktur enthält, wie im Layer-Pfade für Java-Laufzeiten Abschnitt gezeigt.

    Beispiel 2-package.sh
    mkdir java mkdir java/lib cp -r target/layer-java-layer-1.0-SNAPSHOT.jar java/lib/ zip -r layer_content.zip java

Die Ebene erstellen

In diesem Abschnitt nehmen Sie die layer_content.zip Datei, die Sie im vorherigen Abschnitt generiert haben, und laden sie als Lambda-Schicht hoch. Sie können eine Ebene mit der AWS Management Console oder der Lambda-API über die AWS Command Line Interface (AWS CLI) hochladen. Wenn Sie Ihre Layer-.zip-Datei hochladen, geben Sie java21 im folgenden PublishLayerVersion AWS CLI Befehl die kompatible Laufzeit und die kompatible arm64 Architektur an.

aws lambda publish-layer-version --layer-name java-jackson-layer \ --zip-file fileb://layer_content.zip \ --compatible-runtimes java21 \ --compatible-architectures "arm64"

Notieren Sie sich aus der Antwort denLayerVersionArn, der wie arn:aws:lambda:us-east-1:123456789012:layer:java-jackson-layer:1 aussieht. Sie benötigen diesen Amazon-Ressourcennamen (ARN) im nächsten Schritt dieses Tutorials, wenn Sie den Layer zu Ihrer Funktion hinzufügen.

Hinzufügen der Ebene zu Ihrer Funktion

In diesem Abschnitt stellen Sie eine Lambda-Beispielfunktion bereit, die die Jackson-Bibliothek in ihrem Funktionscode verwendet, und fügen dann den Layer hinzu. Um die Funktion bereitzustellen, benötigen Sie eineDefinieren von Lambda-Funktionsberechtigungen mit einer Ausführungsrolle. Wenn Sie noch keine Ausführungsrolle haben, folgen Sie den Schritten im Abschnitt „Zusammenklappbar“. Fahren Sie andernfalls mit dem nächsten Abschnitt fort, um die Funktion bereitzustellen.

So erstellen Sie eine Ausführungsrolle
  1. Öffnen Sie die Seite Roles (Rollen) in der IAM-Konsole.

  2. Wählen Sie Rolle erstellen aus.

  3. Erstellen Sie eine Rolle mit den folgenden Eigenschaften.

    • Trusted entity (Vertrauenswürdige Entität)Lambda.

    • BerechtigungenAWSLambdaBasicExecutionRole.

    • Role name (Name der Rollelambda-role.

    Die AWSLambdaBasicExecutionRoleRichtlinie verfügt über die Berechtigungen, die die Funktion benötigt, um Protokolle in Logs zu CloudWatch schreiben.

So stellen Sie die Lambda-Funktion bereit
  1. Navigieren Sie zum function/ Verzeichnis . Wenn Sie sich derzeit in dem layer/ Verzeichnis befinden, führen Sie den folgenden Befehl aus:

    cd ../function
  2. Überprüfen Sie den Funktionscode. Die Funktion nimmt eine Map<String, String> als Eingabe auf und verwendet Jackson, um die Eingabe als JSON-Zeichenfolge zu schreiben, bevor sie in ein vordefiniertes F1Car-Java-Objekt konvertiert wird. Schließlich verwendet die Funktion Felder aus dem F1Car-Objekt, um einen String zu erstellen, den die Funktion zurückgibt.

    package example; import com.amazonaws.services.lambda.runtime.Context; import com.fasterxml.jackson.databind.ObjectMapper; import java.io.IOException; import java.util.Map; public class Handler { public String handleRequest(Map<String, String> input, Context context) throws IOException { // Parse the input JSON ObjectMapper objectMapper = new ObjectMapper(); F1Car f1Car = objectMapper.readValue(objectMapper.writeValueAsString(input), F1Car.class); StringBuilder finalString = new StringBuilder(); finalString.append(f1Car.getDriver()); finalString.append(" is a driver for team "); finalString.append(f1Car.getTeam()); return finalString.toString(); } }
  3. Erstellen Sie das Projekt mit dem folgenden Maven-Befehl:

    mvn package

    Dieser Befehl erzeugt eine JAR-Datei in dem target/ Verzeichnis mit dem Namenlayer-java-function-1.0-SNAPSHOT.jar.

  4. Stellen Sie die Funktion bereit. Ersetzen Sie im folgenden AWS CLI Befehl den --role Parameter durch den ARN Ihrer Ausführungsrolle:

    aws lambda create-function --function-name java_function_with_layer \ --runtime java21 \ --architectures "arm64" \ --handler example.Handler::handleRequest \ --timeout 30 \ --role arn:aws:iam::123456789012:role/lambda-role \ --zip-file fileb://target/layer-java-function-1.0-SNAPSHOT.jar

An dieser Stelle können Sie optional versuchen, Ihre Funktion aufzurufen, bevor Sie den Layer anhängen. Wenn Sie dies versuchen, sollten Sie eine erhalten, ClassNotFoundException da Ihre Funktion nicht auf das requests Paket verweisen kann. Verwenden Sie den folgenden AWS CLI Befehl, um Ihre Funktion aufzurufen:

aws lambda invoke --function-name java_function_with_layer \ --cli-binary-format raw-in-base64-out \ --payload '{ "driver": "Max Verstappen", "team": "Red Bull" }' response.json

Die Ausgabe sollte in etwa wie folgt aussehen:

{ "StatusCode": 200, "FunctionError": "Unhandled", "ExecutedVersion": "$LATEST" }

Um den spezifischen Fehler anzuzeigen, öffnen Sie die response.json Ausgabedatei. Sie sollten eine ClassNotFoundException mit der folgenden Fehlermeldung sehen:

"errorMessage":"com.fasterxml.jackson.databind.ObjectMapper","errorType":"java.lang.ClassNotFoundException"

Als Nächstes fügen Sie die Ebene Ihrer Funktion hinzu. Ersetzen Sie im folgenden AWS CLI Befehl den --layers Parameter durch den ARN der Layer-Version, den Sie zuvor notiert haben:

aws lambda update-function-configuration --function-name java_function_with_layer \ --cli-binary-format raw-in-base64-out \ --layers "arn:aws:lambda:us-east-1:123456789012:layer:java-jackson-layer:1"

Versuchen Sie abschließend, Ihre Funktion mit dem folgenden AWS CLI Befehl aufzurufen:

aws lambda invoke --function-name java_function_with_layer \ --cli-binary-format raw-in-base64-out \ --payload '{ "driver": "Max Verstappen", "team": "Red Bull" }' response.json

Die Ausgabe sollte in etwa wie folgt aussehen:

{ "StatusCode": 200, "ExecutedVersion": "$LATEST" }

Dies deutet darauf hin, dass die Funktion die Jackson-Abhängigkeit verwenden konnte, um die Funktion ordnungsgemäß auszuführen. Sie können überprüfen, ob die response.json Ausgabedatei den richtigen zurückgegebenen String enthält:

"Max Verstappen is a driver for team Red Bull"

Sie können jetzt die Ressourcen, die Sie für dieses Tutorial erstellt haben, löschen, es sei denn, Sie möchten sie behalten. Durch das Löschen von AWS Ressourcen, die Sie nicht mehr verwenden, vermeiden Sie unnötige Kosten für Ihre AWS-Konto.

Um die Lambda-Ebene zu löschen
  1. Öffnen Sie die Seite Ebenen der Lambda-Konsole.

  2. Wählen Sie die Ebene aus, die Sie erstellt haben.

  3. Wählen Sie „Löschen“ und anschließend erneut „Löschen“.

So löschen Sie die Lambda-Funktion:
  1. Öffnen Sie die Seite Funktionen der Lambda-Konsole.

  2. Wählen Sie die Funktion aus, die Sie erstellt haben.

  3. Wählen Sie Aktionen, Löschen aus.

  4. Geben Sie delete in das Texteingabefeld ein und wählen Sie Delete (Löschen) aus.