Voraussetzungen
Um Aufträge in deinen Workflows zu implementieren, musst du verstehen, worum es sich bei Aufträgen handelt. Weitere Informationen findest du unter Understanding GitHub Actions.
Festlegen einer ID für einen Auftrag
Verwende jobs.<job_id>
, um deinem Auftrag einen eindeutigen Bezeichner zu geben. Der Schlüssel job_id
ist ein String und der Wert umfasst eine Zuordnung der Konfigurationsdaten für den Auftrag. Du musst <job_id>
mit einer Zeichenfolge ersetzen, die für das jobs
-Objekt eindeutig ist. <job_id>
muss mit einem Buchstaben oder _
beginnen und darf nur alphanumerische Zeichen, -
oder _
enthalten.
Beispiel: Erstellen von Aufträgen
In diesem Beispiel wurden zwei Aufträge erstellt und ihre job_id
-Werte sind my_first_job
und my_second_job
.
jobs:
my_first_job:
name: My first job
my_second_job:
name: My second job
Festlegen eines Namens für einen Auftrag
Mit jobs.<job_id>.name
legst du einen Namen für den Auftrag fest, der auf der Benutzeroberfläche von GitHub angezeigt wird.
Definieren von erforderlichen Aufträgen
Verwende jobs.<job_id>.needs
, um alle Aufträge zu identifizieren, die erfolgreich abgeschlossen sein müssen, bevor dieser Auftrag ausgeführt wird. Hier ist ein String oder ein Array mit Strings zulässig. Wenn ein Auftrag fehlschlägt oder übersprungen wird, werden alle Aufträge übersprungen, die diesen Auftrag benötigen, außer die Aufträge umfassen einen bedingte Ausdruck, mit dem der Auftrag dennoch fortgesetzt wird. Wenn eine Ausführung eine Reihe von Aufträgen enthält, die voneinander abhängig sind, wird ein Fehler oder eine Auslassung auf alle Aufträge in der Abhängigkeitskette ab dem Fehler- oder Auslassungspunkt angewendet. Wenn ein Auftrag auch dann ausgeführt werden soll, wenn ein Auftrag, von dem er abhängig ist, nicht erfolgreich war, verwenden Sie den bedingten always()
-Ausdruck in jobs.<job_id>.if
.
Beispiel: Erfordern erfolgreicher abhängiger Aufträge
jobs:
job1:
job2:
needs: job1
job3:
needs: [job1, job2]
In diesem Beispiel muss job1
erfolgreich abgeschlossen sein, bevor job2
beginnt, und job3
wartet darauf, dass job1
und job2
angeschlossen werden.
Die Aufträge in diesem Beispiel werden sequenziell ausgeführt:
job1
job2
job3
Beispiel: Nicht Erfordern erfolgreicher abhängiger Aufträge
jobs:
job1:
job2:
needs: job1
job3:
if: ${{ always() }}
needs: [job1, job2]
In diesem Beispiel verwendet job3
den bedingten Ausdruck always()
, sodass er immer nach Abschluss von job1
und job2
ausgeführt wird, unabhängig davon, ob sie erfolgreich waren. Weitere Informationen finden Sie unter Auswerten von Ausdrücken in Workflows und Aktionen.
Verwenden einer Matrix zum Ausführen von Aufträgen mit unterschiedlichen Variablen
Definiere eine matrix
-Strategie in deinem Workflow, um einen Auftrag automatisch mit unterschiedlichen Kombinationen von Variablen wie Betriebssystemen oder Sprachversionen auszuführen.
Weitere Informationen finden Sie unter Ausführen von Variationen von Aufträgen in einem Workflow.