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.
Wie Sie Probleme mit schreibgeschützten Eigenschaften in AWS::Lambda::Function-Ressourcen beheben
In diesem Thema wird erklärt, wie Sie Probleme mit schreibgeschützten Eigenschaften in AWS::Lambda::Function-Ressourcen beheben, wenn Sie den IaC-Generator verwenden.
Problem
Die Ressource AWS::Lambda::Function hat drei sich gegenseitig ausschließende Sätze von Eigenschaften zur Angabe des Lambda-Codes:
-
die Eigenschaften
Code/S3BucketundCode/S3Keyund optional die EigenschaftCode/S3ObjectVersion. -
Code/ImageUriEigenschaft -
Code/ZipFileEigenschaft
Für eine bestimmte AWS::Lambda::Function-Ressource kann nur eines dieser Sets verwendet werden.
Der IaC-Generator kann nicht feststellen, welcher Satz von exklusiven schreibgeschützten Eigenschaften zum Erstellen oder Aktualisieren der Ressource verwendet wurde. Daher wird nur der erste Satz von Eigenschaften in die generierte Vorlage aufgenommen. Die Eigenschaften Code/ImageUri und Code/ZipFile werden weggelassen.
Außerdem gibt der IaC-Generator die folgenden Warnungen aus:
-
MUTUALLY_EXCLUSIVE_PROPERTIES- warnt davor, dassCode/S3BucketundCode/S3Keyals sich gegenseitig ausschließende Eigenschaften identifiziert werden. -
UNSUPPORTED_PROPERTIES- Warnt, dass die EigenschaftCode/S3ObjectVersionnicht unterstützt wird.
Um AWS::Lambda::Function-Ressourcen in eine generierte Vorlage aufzunehmen, müssen Sie die Vorlage herunterladen und mit den richtigen Code-Eigenschaften aktualisieren.
Auflösung
Wenn Sie Ihren Lambda-Code in einem Amazon S3-Bucket speichern und die S3ObjectVersion Eigenschaftnicht verwenden, können Sie die generierte Vorlage ohne Änderungen importieren. Der IaC-Generator wird Sie während des Importvorgangs nach dem Amazon S3-Bucket und dem Schlüssel als Vorlagenparameter fragen.
Wenn Sie Ihren Lambda-Code in einem Amazon ECR-Repository speichern, können Sie Ihre Vorlage anhand der folgenden Anweisungen aktualisieren:
-
Laden Sie die generierte Vorlage herunter.
-
Entfernen Sie die Eigenschaften und die entsprechenden Parameter für die Eigenschaften
Code/S3BucketundCode/S3Keyaus der generierten Vorlage. -
Ersetzen Sie die entfernten Eigenschaften in der generierten Vorlage durch die Eigenschaft
Code/ImageUri, die die URL für das Amazon ECR-Repository angibt. -
Öffnen Sie die generierte Vorlage in der IaC-Generator-Konsole und wählen Sie die Schaltfläche Bearbeitete Vorlage importieren .
Wenn Sie Ihren Lambda-Code in einer Zip-Datei speichern, können Sie Ihre Vorlage anhand der folgenden Anweisungen aktualisieren:
-
Laden Sie die generierte Vorlage herunter.
-
Entfernen Sie die Eigenschaften und die entsprechenden Parameter für die Eigenschaften
Code/S3BucketundCode/S3Keyaus der generierten Vorlage. -
Ersetzen Sie die entfernten Eigenschaften in der generierten Vorlage durch die Eigenschaft
Code/ZipFile. -
Öffnen Sie die generierte Vorlage in der IaC-Generator-Konsole und wählen Sie die Schaltfläche Bearbeitete Vorlage importieren .
Wenn Sie keine Kopie Ihres Lambda-Codes haben, können Sie Ihre Vorlage anhand der folgenden Anweisungen aktualisieren:
-
Verwenden Sie die API-Aktion AWS Lambda
GetFunction(beispielsweise mit dem Befehlaws lambda get-functionAWS CLI . -
In der Antwort lautet der Parameter
RepositoryTypeS3, wenn sich der Code in einem Amazon S3-Bucket befindet, oderECR, wenn sich der Code in einem Amazon ECR-Repository befindet. -
In der Antwort enthält der Parameter
Locationeine vorsignierte URL, mit der Sie das Bereitstellungspaket für 10 Minuten herunterladen können. Laden Sie den Code herunter. -
Laden Sie den Code in einen Amazon S3-Bucket hoch.
-
Führen Sie einen Importvorgang mit der generierten Vorlage aus und geben Sie den Bucketnamen und den Schlüssel als Parameterwerte an.