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.
Verwenden Sie dynamische Variablen in Ihrem Workflow-Dokument
Sie können dynamische Variablen in Ihren Workflow-Dokumenten verwenden, um Werte darzustellen, die zur Laufzeit Ihres Image-Erstellungsprozesses variieren. Die Zeichenketteninterpolation für dynamische Variablen ermöglicht es Ihnen, JSONPath Ausdrücke in strukturierte Inhalte wie JSON-Zeichenketten einzubetten. Dies ist besonders nützlich, wenn Sie Laufzeitwerte innerhalb komplexer Nutzlasten an Schrittaktionen wie oder übergeben müssen. ExecuteStateMachine WaitForAction
Um die Zeichenketteninterpolation für dynamische Variablen zu verwenden, setzen Sie JSONPath Ausdrücke innerhalb Ihres Zeichenketteninhalts in doppelte geschweifte Klammern. "{{...}}" Nur JSONPath Ausdrücke, die in doppelte geschweifte Klammern eingeschlossen sind, werden als Variablen verarbeitet. Alle JSONPath Ausdrücke, die nicht in doppelte geschweifte Klammern eingeschlossen sind, werden als wörtliche Zeichenketteninhalte behandelt.
JSONPath dynamische Workflow-Variablensyntax
$.<document structure>.[<step name>.]<variable name>
Dynamische Variablenwerte werden als JSONPath Selektoren mit Strukturknoten dargestellt, die die Zielvariable eindeutig identifizieren. Der erste Knoten nach dem Stamm ($) bezieht sich auf die Workflow-Dokumentstruktur, z. B. oderstepOutputs, im Fall von Image Builder Builder-Systemvariablen,imageBuilder. Die folgende Liste enthält unterstützte Strukturknoten für JSONPath Workflow-Dokumente.
Knoten für die Dokumentstruktur
-
Parameter — Die Workflow-Parameter
-
StepOutputs — Ausgaben aus einem Schritt im selben Workflow-Dokument
-
WorkflowOutputs — Ausgaben aus einem Workflow-Dokument, das bereits ausgeführt wurde
-
imagebuilder - Image Builder Builder-Systemvariablen
Die Knoten parameters und die stepOutputs Dokumentstruktur enthalten einen optionalen Knoten für den Schrittnamen. Dadurch wird sichergestellt, dass in allen Schritten eindeutige Variablennamen verwendet werden.
Der letzte Knoten in der JSONPath ist der Name der Zielvariablen, z. instanceId B.
Jeder Schritt kann sich auf die Ausgabe aller Aktionen eines vorherigen Schritts mit diesen JSONPath dynamischen Variablen beziehen. Dies wird auch als Verkettung oder Referenzierung bezeichnet. Um auf die Ausgabe einer Aktion aus einem vorherigen Schritt zu verweisen, können Sie die folgende dynamische Variable verwenden.
$.stepOutputs.step-name.output-name
Wichtig
Wenn sich ein Eingabeparameter auf eine dynamische Variable bezieht, muss der Verkettungsindikator (.$) an das Ende des Parameternamens angehängt werden.
Beispiel 1: Indikator für die Verkettung von Eingabeparametern
Das folgende Beispiel zeigt einen Eingabeparameter, der Zeichenketteninterpolation verwendet, um zur Laufzeit eine dynamische Variable im Parameterwert aufzulösen.
- name: ApplyTestComponents action: ExecuteComponents onFailure: Abort inputs: instanceId.$: "$.stepOutputs.LaunchTestInstance.instanceId"
Beispiel 2: Zeichenketteninterpolation in dynamischen Variablen
Das folgende Beispiel zeigt, wie dynamische Variablen Zeichenketteninterpolation verwenden, um Werte zur Laufzeit zu bestimmen.
- name: ValidateImageConfiguration action: ExecuteStateMachine inputs: stateMachineArn: arn:aws:states:us-east-1:111122223333:stateMachine:ImageValidation input: | { "imageId": "{{ $.stepOutputs.CreateImageFromInstance.imageId }}", "region": "us-east-1", "buildDate": "{{ $.imagebuilder.dateTime }}", "instanceType": "{{ $.stepOutputs.LaunchStep.instanceType }}" }
In diesem Beispiel werden die JSONPath Ausdrücke, die in doppelte geschweifte Klammern eingeschlossen sind, zur Laufzeit aufgelöst:
-
{{ $.stepOutputs.CreateImageFromInstance.imageId }}- Löst die tatsächliche Bild-ID aus dem Schritt auf CreateImageFromInstance -
{{ $.imagebuilder.dateTime }}- Löst den aktuellen Build-Zeitstempel auf. Eine Liste der Image Builder Builder-Systemvariablen, die Sie verwenden können, finden Verwenden Sie Image Builder Builder-Systemvariablen Sie unter. -
{{ $.stepOutputs.LaunchStep.instanceType }}- Löst den Instanztyp auf, der in der LaunchStep
Die literalen Zeichenketten wie "region": "us-east-1" bleiben unverändert.
Anmerkung
Die Zeichenketteninterpolation funktioniert mit jedem Zeichenketteninhalt in Ihrem Workflow-Dokument, einschließlich mehrzeiliger Zeichenketten, die den YAML-Operator pipe () verwenden. | Die Anforderung geschweifter Klammern dient als Escape-Mechanismus, um klar zwischen JSONPath Variablen und wörtlichem Textinhalt zu unterscheiden.
Verwenden Sie Image Builder Builder-Systemvariablen
Image Builder stellt die folgenden Systemvariablen bereit, die Sie in Ihrem Workflow-Dokument verwenden können:
|
Variablenname |
Description |
Typ |
Beispielwert |
|---|---|---|---|
|
cloudWatchLogGruppe |
Der Name der CloudWatch Protokollgruppe für Ausgabeprotokolle. Format: |
String |
|
|
cloudWatchLogStreamen |
Der Name des CloudWatch Logs-Streams für Ausgabeprotokolle. |
String |
|
|
collectImageMetadata |
Die Einstellung, die Image Builder anweist, ob Instanzmetadaten erfasst werden sollen. |
Boolesch |
|
|
collectImageScanErgebnisse |
Der aktuelle Wert der Einstellung, die es Image Builder ermöglicht, Bildscanergebnisse zu sammeln. |
Boolesch |
|
|
imageBuildNumber |
Die Build-Versionsnummer des Images. |
Ganzzahl |
|
|
imageId |
Die AMI-ID des Basis-Images. |
String |
|
|
Name des Bilds |
Der Name des Image. |
String |
|
|
ImageType |
Der Bildausgabetyp. |
String |
|
|
imageVersionNumber |
Die Versionsnummer des Bildes. |
String |
|
|
instanceProfileName |
Der Name der Instanzprofilrolle, die Image Builder zum Starten von Build- und Testinstanzen verwendet. |
String |
|
|
platform |
Die Betriebssystemplattform des erstellten Images. |
String |
|
|
S3-Protokolle |
Ein JSON-Objekt, das die Konfiguration für die S3-Protokolle enthält, die Image Builder schreibt. |
JSON-Objekt |
{'s3Logs': {'s3 BucketName ':' ', 's3 |
|
securityGroups |
Die Sicherheitsgruppe IDs , die für Build- und Test-Instances gilt. |
Liste [Zeichenfolge] |
|
|
Quelle ImageARN |
Der Amazon-Ressourcenname (ARN) der Image Builder Builder-Image-Ressource, die der Workflow für Build- und Testphasen verwendet. |
String |
arn:aws:imagebuilder: ::image// |
|
subnetId |
Die ID des Subnetzes, in dem die Build- und Test-Instances gestartet werden sollen. |
String |
|
|
terminateInstanceOnFehlschlag |
Der aktuelle Wert der Einstellung, die Image Builder anweist, die Instanz bei einem Fehler zu beenden oder sie zur Fehlerbehebung beizubehalten. |
Boolesch |
|
|
WorkflowPhase |
Die aktuelle Phase, in der die Workflow-Ausführung ausgeführt wird. |
String |
|
|
workingDirectory |
Der Pfad zum Arbeitsverzeichnis. |
String |
|