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.
So lösen Sie Probleme mit schreibgeschützten Eigenschaften in Ressourcen AWS::Lambda::Function
In diesem Thema wird erklärt, wie Sie Probleme mit schreibgeschützten Eigenschaften in AWS::Lambda::FunctionRessourcen beheben können, wenn Sie den IaC-Generator verwenden.
Problem
Die AWS::Lambda::Function Ressource hat drei sich gegenseitig ausschließende Eigenschaftssätze zur Angabe des Lambda-Codes:
-
Code/S3BucketundCode/S3KeyEigenschaften und optional dieCode/S3ObjectVersionEigenschaft -
Code/ImageUriEigenschaft -
Code/ZipFileEigenschaft
Nur einer dieser Sätze kann für eine bestimmte AWS::Lambda::Function Ressource verwendet werden.
Der IaC-Generator kann nicht ermitteln, welcher Satz exklusiver schreibgeschützter Eigenschaften zum Erstellen oder Aktualisieren der Ressource verwendet wurde. Daher enthält er nur den ersten Satz von Eigenschaften in der generierten Vorlage. Die Code/ZipFile Eigenschaften Code/ImageUri und werden weggelassen.
Darüber hinaus gibt der IaC-Generator die folgenden Warnungen aus:
-
MUTUALLY_EXCLUSIVE_PROPERTIES— Warnt davorCode/S3BucketundCode/S3Keywerden als sich gegenseitig ausschließende Eigenschaften identifiziert. -
UNSUPPORTED_PROPERTIES— Warnt davor, dass dieCode/S3ObjectVersionEigenschaft nicht unterstützt wird.
Um AWS::Lambda::Function Ressourcen in eine generierte Vorlage aufzunehmen, müssen Sie die Vorlage herunterladen und mit den richtigen Codeeigenschaften aktualisieren.
Auflösung
Wenn Sie Ihren Lambda-Code in einem Amazon S3 S3-Bucket speichern und die S3ObjectVersion Eigenschaft nicht verwenden, können Sie die generierte Vorlage ohne Änderungen importieren. Der IaC-Generator fragt Sie während des Importvorgangs nach dem Amazon S3 S3-Bucket und dem Schlüssel als Vorlagenparameter.
Wenn Sie Ihren Lambda-Code als Amazon ECR-Repository speichern, können Sie Ihre Vorlage mithilfe der folgenden Anweisungen aktualisieren:
-
Laden Sie die generierte Vorlage herunter.
-
Entfernen Sie die Eigenschaften und die entsprechenden Parameter für die
Code/S3KeyEigenschaftenCode/S3Bucketund aus der generierten Vorlage. -
Ersetzen Sie die entfernten Eigenschaften in der generierten Vorlage durch die
Code/ImageUriEigenschaft und geben Sie dabei die URL für das Amazon ECR-Repository an. -
Öffnen Sie die generierte Vorlage in der IaC-Generatorkonsole und wählen Sie die Schaltfläche Bearbeitete Vorlage importieren.
Wenn Sie Ihren Lambda-Code wie in einer Zip-Datei speichern, können Sie Ihre Vorlage mithilfe der folgenden Anweisungen aktualisieren:
-
Laden Sie die generierte Vorlage herunter.
-
Entfernen Sie die Eigenschaften und die entsprechenden Parameter für die
Code/S3KeyEigenschaftenCode/S3Bucketund aus der generierten Vorlage. -
Ersetzen Sie die entfernten Eigenschaften in der generierten Vorlage durch die
Code/ZipFileEigenschaft. -
Öffnen Sie die generierte Vorlage in der IaC-Generatorkonsole und wählen Sie die Schaltfläche Bearbeitete Vorlage importieren.
Wenn Sie keine Kopie Ihres Lambda-Codes haben, können Sie Ihre Vorlage mithilfe der folgenden Anweisungen aktualisieren:
-
Verwenden Sie die AWS Lambda
GetFunctionAPI-Aktion (z. B. mithilfe desaws lambda get-functionAWS CLI Befehls). -
In der Antwort gibt der
RepositoryTypeParameter an,S3ob sich der Code in einem Amazon S3 S3-Bucket befindet oderECRob sich der Code in einem Amazon ECR-Repository befindet. -
In der Antwort enthält der
LocationParameter eine 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 S3-Bucket hoch.
-
Führen Sie einen Importvorgang mit der generierten Vorlage aus und geben Sie den Bucket-Namen und den Schlüssel als Parameterwerte an.