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.
Erstellen Sie ein YAML Workflow-Dokument
Das Dokument mit der YAML Formatdefinition konfiguriert Eingabe-, Ausgabe- und Workflow-Schritte für die Erstellungs- und Testphasen des Image-Erstellungsprozesses. Sie können mit Vorlagen beginnen, die standardisierte Schritte enthalten, oder Sie können ganz von vorne beginnen, um Ihren eigenen Workflow zu definieren. Unabhängig davon, ob Sie eine Vorlage verwenden oder ganz von vorne beginnen, können Sie den Workflow an Ihre Bedürfnisse anpassen.
Struktur eines YAML Workflow-Dokuments
Das YAML Workflow-Dokument, das Image Builder zum Ausführen von Image-Erstellungs- und Testaktionen verwendet, ist wie folgt strukturiert.
Identifizierung von Workflow-Dokumenten
Identifiziert den Workflow eindeutig. Dieser Abschnitt kann die folgenden Attribute enthalten.
Feld |
Beschreibung |
Typ |
Erforderlich |
---|---|---|---|
Name |
Der Name des Workflow-Dokuments. |
String |
Nein |
description |
Die Beschreibung des Dokuments. |
String |
Nein |
schemaVersion |
Die Version des Dokumentschemas, derzeit 1.0. |
String |
Ja |
Beispiel
--- name: sample-test-image description: Workflow for a sample image, with extra configuration options exposed through workflow parameters. schemaVersion: 1.0
Eingabeparameter für Workflow-Dokumente
In diesem Teil des Workflow-Dokuments werden Eingabeparameter definiert, die der Aufrufer angeben kann. Wenn Sie keine Parameter haben, können Sie diesen Abschnitt weglassen. Wenn Sie Parameter angeben, kann jeder Parameter die folgenden Attribute enthalten.
Feld |
Beschreibung |
Typ |
Erforderlich |
Beschränkungen |
---|---|---|---|---|
Name |
Der Name des Parameters. |
String |
Ja |
|
description |
Die Beschreibung des Parameters. |
String |
Nein |
|
default |
Der Standardwert des Parameters, wenn kein Wert angegeben wird. Wenn Sie keinen Standardwert in die Parameterdefinition aufnehmen, ist der Parameterwert zur Laufzeit erforderlich. |
Entspricht dem Parameter-Datentyp. |
Nein |
|
Typ |
Der Datentyp des Parameters. Wenn Sie den Datentyp nicht in die Parameterdefinition aufnehmen, verwendet der Parametertyp standardmäßig einen zur Laufzeit erforderlichen Zeichenkettenwert. |
String |
Ja |
Der Datentyp des Parameters muss einer der folgenden sein:
|
Beispiel
Geben Sie den Parameter im Workflow-Dokument an.
parameters: - name: waitForActionAtEnd type: boolean default: true description: "Wait for an external action at the end of the workflow"
Verwenden Sie den Parameterwert im Workflow-Dokument.
$.parameters.waitForActionAtEnd
Schritte des Workflow-Dokuments
Gibt bis zu 15 Schrittaktionen für den Workflow an. Die Schritte werden in der Reihenfolge ausgeführt, in der sie im Workflow-Dokument definiert sind. Im Falle eines Fehlers wird ein Rollback in umgekehrter Reihenfolge ausgeführt, wobei mit dem fehlgeschlagenen Schritt begonnen und die vorherigen Schritte rückwärts durchgearbeitet werden.
Jeder Schritt kann sich auf die Ausgabe aller Aktionen eines vorherigen Schritts beziehen. Dies wird als Verkettung oder Referenzierung bezeichnet. Um auf die Ausgabe einer Aktion aus einem vorherigen Schritt zu verweisen, können Sie einen JSONPath Selektor verwenden. Beispielsweise:
$.stepOutputs.
step-name
.output-name
Weitere Informationen finden Sie unter Verwenden Sie dynamische Variablen in Ihrem Workflow-Dokument.
Anmerkung
Auch wenn der Schritt selbst kein Ausgabeattribut hat, ist jede Ausgabe einer Schrittaktion in stepOutput
für den Schritt enthalten.
Jeder Schritt kann die folgenden Attribute enthalten.
Feld |
Beschreibung |
Typ |
Erforderlich |
Standardwert |
Beschränkungen |
---|---|---|---|---|---|
action |
Die Workflow-Aktion, die durch diesen Schritt ausgeführt wird. |
String |
Ja |
Muss eine unterstützte Schrittaktion für Image Builder Builder-Workflow-Dokumente sein. |
|
|
Bedingte Anweisungen erweitern den Hauptteil Ihrer Workflow-Schritte um Entscheidungspunkte für den Kontrollfluss. |
Diktieren |
Nein |
Image Builder unterstützt die folgenden bedingten Anweisungen als Modifikatoren für den
|
|
description |
Die Beschreibung des Schritts. |
String |
Nein |
Leere Zeichenketten sind nicht zulässig. Falls angegeben, muss die Länge zwischen 1 und 1024 Zeichen liegen. |
|
inputs |
Enthält Parameter, die die Schrittaktion zur Ausführung benötigt. Sie können Schlüsselwerte als statische Werte oder mit einer JSONPath Variablen angeben, die in den richtigen Datentyp aufgelöst wird. |
Diktieren |
Ja |
||
Name |
Der Name des Schritts. Dieser Name muss innerhalb des Workflow-Dokuments eindeutig sein. |
String |
Ja |
Die Länge muss zwischen 3 und 128 Zeichen liegen. Kann alphanumerische Zeichen und enthalten. |
|
onFailure |
Konfiguriert die Aktion, die ausgeführt werden soll, wenn der Schritt fehlschlägt, wie folgt. Behavior
|
String |
Nein |
|
|
rollbackEnabled |
Konfiguriert, ob der Schritt zurückgesetzt wird, falls ein Fehler auftritt. Sie können einen statischen booleschen Wert oder eine dynamische JSONPath Variable verwenden, die in einen booleschen Wert aufgelöst wird. |
Boolesch |
Nein |
|
|
timeoutSeconds |
Die maximale Zeit in Sekunden, für die der Schritt ausgeführt wird, bevor er fehlschlägt und erneut versucht wird, falls Wiederholungen erforderlich sind. |
Ganzzahl |
Nein |
Hängt gegebenenfalls von der Standardeinstellung ab, die für die Schrittaktion definiert wurde. |
Zwischen 1 und 86400 Sekunden (maximal 24 Stunden) |
Beispiel
steps: - name: LaunchTestInstance action: LaunchInstance onFailure: Abort inputs: waitFor: "ssmAgent" - name: ApplyTestComponents action: ExecuteComponents onFailure: Abort inputs: instanceId.$: "$.stepOutputs.LaunchTestInstance.instanceId" - name: TerminateTestInstance action: TerminateInstance onFailure: Continue inputs: instanceId.$: "$.stepOutputs.LaunchTestInstance.instanceId" - name: WaitForActionAtEnd action: WaitForAction if: booleanEquals: true value: "$.parameters.waitForActionAtEnd"
Ausgaben von Workflow-Dokumenten
Definiert Ausgaben für den Workflow. Jede Ausgabe ist ein Schlüssel-Wert-Paar, das den Namen der Ausgabe und den Wert angibt. Sie können Ausgaben verwenden, um zur Laufzeit Daten zu exportieren, die nachfolgende Workflows verwenden können. Dieser Abschnitt ist optional.
Jede Ausgabe, die Sie definieren, enthält die folgenden Attribute.
Feld |
Beschreibung |
Typ |
Erforderlich |
---|---|---|---|
Name |
Der Name der Ausgabe. Der Name muss für alle Workflows, die Sie in Ihre Pipeline aufnehmen, eindeutig sein. |
String |
Ja |
Wert |
Der Wert für die Ausgabe. Der Wert der Zeichenfolge kann eine dynamische Variable sein, z. B. eine Ausgabedatei aus einer Schrittaktion. Weitere Informationen finden Sie unter Verwenden Sie dynamische Variablen in Ihrem Workflow-Dokument. |
String |
Ja |
Beispiel
Erstellen Sie eine Ausgabebild-ID für das Workflow-Dokument mit der Schrittausgabe aus dem createProdImage
Schritt.
outputs: - name: 'outputImageId' value: '$.stepOutputs.createProdImage.imageId'
Sehen Sie sich die Workflow-Ausgabe im nächsten Workflow an.
$.workflowOutputs.outputImageId