Wiederverwendbare Workflows
Referenzinformationen für wiederverwendbare Workflows
Zugriff auf wiederverwendbare Workflows
Ein wiederverwendbarer Workflow kann von einem anderen Workflow verwendet werden, wenn einer der folgenden Punkte zutrifft:
- Beide Workflows befinden sich im selben Repository.
- Der aufgerufene Workflow wird in einem öffentlichen Repositoryund In Ihrer Unternehmensorganisation können Sie öffentliche wiederverwendbare Workflows verwenden.
- Der aufgerufene Workflow befindet sich in einem internen Repository, und die Einstellungen für dieses Repository ermöglichen den Zugriff darauf. Weitere Informationen finden Sie unter Freigeben von Aktionen und Workflows in deinem Unternehmen.
- Der aufgerufene Workflow befindet sich in einem privaten Repository, und die Einstellungen für dieses Repository ermöglichen den Zugriff darauf. Weitere Informationen finden Sie unter Freigeben von Aktionen und Workflows in deinem Unternehmen.
Die folgende Tabelle zeigt die Zugänglichkeit wiederverwendbarer Workflows für einen Aufrufer-Workflow, abhängig von der Sichtbarkeit des Host-Repositorys.
| Anrufer-Repository | Repositorys für zugängliche Workflows |
|---|---|
private |
`private`
, `internal`und`public` |
| |
| internal |
internal und public |
| |
| public | public |
Die Actions Berechtigungen auf der Seite „Actions-Einstellungen“ des Aufrufer-Repositorys müssen so konfiguriert werden, dass die Nutzung von Aktionen und wiederverwendbaren Workflows ermöglicht wird. Weitere Informationen findest du unter Einstellung der GitHub Actions für ein Repository verwalten.
Für interne oder private Repositorys muss die Access-Richtlinie auf der Seite "Aktionen"-Einstellungen des repositorys des aufgerufenen Workflows explizit konfiguriert werden, um den Zugriff von Repositorys zuzulassen, die Aufruferworkflows enthalten - siehe Einstellung der GitHub Actions für ein Repository verwalten.
Hinweis
Um die Sicherheit zu erhöhen, unterstützt GitHub Actions keine Umleitungen für Aktionen oder wiederverwendbare Workflows. Dies bedeutet, dass bei einer Änderung des Besitzers bzw. der Besitzerin, des Namens des Repositorys einer Aktion oder des Namens einer Aktion alle Workflows, die diese Aktion mit dem vorherigen Namen verwenden, fehlschlagen.
Einschränkungen von wiederverwendbaren Workflows
-
Sie können bis zu zehn Ebenen von Workflows verbinden. Weitere Informationen findest du unter Verschachteln wiederverwendbarer Workflows.
-
Sie können maximal 50 eindeutige wiederverwendbare Workflows aus einer einzigen Workflowdatei aufrufen. Dieser Grenzwert gilt für alle Strukturen von geschachtelten wiederverwendbaren Workflows, die ab der Workflowdatei der aufrufenden Funktion der obersten Ebene aufgerufen werden können.
Beispielsweise zählt top-level-caller-workflow.yml → called-workflow-1.yml → called-workflow-2.yml als zwei wiederverwendbare Workflows.
-
Alle Umgebungsvariablen, die in einem
env-Kontext festgelegt werden, der im aufrufenden Workflow auf Workflowebene definiert ist, werden nicht an den aufgerufenen Workflow übergeben. Weitere Informationen findest du unter Speichern von Informationen in Variablen und Kontextreferenz. -
Auf ähnliche Weise sind im
env-Kontext festgelegte Umgebungsvariablen, die im aufgerufenen Workflow definiert sind, imenv-Kontext des Aufruferworkflows nicht zugänglich. Stattdessen musst du Ausgaben des wiederverwendbaren Workflows verwenden. Weitere Informationen findest du unter Verwenden von Ausgaben eines wiederverwendbaren Workflows. -
Um Variablen in mehreren Workflows wiederzuverwenden, lege sie auf Organisations-, Repository- oder Umgebungsebene fest, und verweise mithilfe des Kontexts
varsdarauf. Weitere Informationen findest du unter Speichern von Informationen in Variablen und Kontextreferenz. -
Wiederverwendbare Workflows werden direkt in einem Auftrag aufgerufen und nicht innerhalb eines Arbeitsschritts. Du kannst daher
GITHUB_ENVverwenden, um Werte an die Auftragsschritte im Aufruferworkflow zu übergeben.
Unterstützte Schlüsselwörter für Aufträge, in denen ein wiederverwendbarer Workflow aufgerufen wird
Beim Aufrufen eines wiederverwendbaren Workflows kannst du in dem Auftrag, der den Aufruf enthält, nur die folgenden Schlüsselwörter verwenden:
-
Hinweis
- Wenn im aufrufenden Auftrag
jobs.<job_id>.permissionsnicht angegeben ist, verfügt der aufgerufene Workflow über die Standardberechtigungen fürGITHUB_TOKEN. Weitere Informationen finden Sie unter Workflowsyntax für GitHub Actions. - Die vom aufrufenden Workflow übergebene
GITHUB_TOKEN-Berechtigungen können vom aufgerufenen Workflow nur herabgestuft (nicht erweitert) werden. - Wenn Sie
jobs.<job_id>.concurrency.cancel-in-progress: trueverwenden, dürfen Sie fürjobs.<job_id>.concurrency.groupin den aufgerufenen und aufrufenden Workflows nicht gen gleichen Wert verwenden, da sonst der bereits ausgeführte Workflow abgebrochen wird. Ein aufgerufener Workflow verwendet den Namen des Aufrufer-Workflows in ${{ github.workflow }}, also wird, wenn Sie diesen Kontext als Wert injobs.<job_id>.concurrency.groupsowohl im aufrufenden als auch im aufgerufenen Workflow verwenden, der Aufrufer-Workflow abgebrochen, wenn der aufgerufene Workflow ausgeführt wird.
- Wenn im aufrufenden Auftrag
Wie wiederverwendbare Workflows Runner nutzen
GitHub-gehostete Läufer
Die Zuweisung von GitHubgehosteten Läufern wird immer nur mit dem Kontext des Anrufers ausgewertet. Die Abrechnung für GitHub-gehostete Runner ist immer mit dem Aufrufer verknüpft. Der Aufruferworkflow kann keine GitHub-gehosteten Runner vom aufgerufenen Repository verwenden. Weitere Informationen finden Sie unter Von GitHub gehostete Runner.
Selbstgehosteten Runnern
Als Workflows bezeichnet, die demselben Benutzer, derselben Organisation oder demselben Unternehmen gehören wie der aufrufende Workflow, können über den Kontext des Anrufers auf selbst gehostete Runner zugreifen. Dies bedeutet, dass ein aufgerufener Workflow auf selbstgehostete Runner zugreifen kann, auf die Folgendes zutrifft:
- Du befindest dich im Repository des aufrufenden Workflows.
- In der Organisation oder dem Unternehmen des aufrufenden Repositorys, sofern der Runner dem aufrufenden Repository zur Verfügung gestellt wurde
Zugriff und Berechtigungen für geschachtelte Workflows
Ein Workflow, der geschachtelte wiederverwendbare Workflows enthält, schlägt fehl, wenn einer der geschachtelten Workflows für den anfänglichen aufrufenden Workflow nicht zugänglich ist. Weitere Informationen findest du unter Zugriff auf wiederverwendbare Workflows.
`GITHUB_TOKEN`-Berechtigungen müssen in geschachtelten Workflows identisch oder restriktiver sein. In der Workflowkette A > B > C gilt beispielsweise Folgendes: Wenn Workflow A über die Tokenberechtigung `package: read` verfügt, können B und C nicht die Berechtigung `package: write` aufweisen. Weitere Informationen finden Sie unter [AUTOTITLE](/actions/security-guides/automatic-token-authentication).
Informationen dazu, wie du mithilfe der API ermitteln kannst, welche Workflowdateien an einer bestimmten Workflowausführung beteiligt waren, findest du unter Wiederverwenden von Workflows.
Verhalten von wiederverwendbaren Workflows beim erneuten Ausführen von Aufträgen
Auf wiederverwendbare Workflows aus öffentlichen Repositorys kann mithilfe eines SHA, eines Releasetags oder eines Branchnamens verwiesen werden. Weitere Informationen finden Sie unter Wiederverwenden von Workflows.
Wenn du einen Workflow, der einen wiederverwendbaren Workflow verwendet, erneut ausführst, und der Verweis kein SHA-Verweis ist, sind einige Verhaltensweisen zu beachten:
- Bei erneuter Ausführung aller Aufträge in einem Workflow wird der wiederverwendbare Workflow aus dem angegebenen Verweis verwendet. Weitere Informationen zum erneuten Ausführen aller Aufträge in einem Workflow findest du unter Erneutes Ausführen von Workflows und Jobs.
- Beim erneuten Ausführen fehlerhafter Aufträge oder eines bestimmten Auftrags in einem Workflow wird der wiederverwendbare Workflow aus dem Commit-SHA des ersten Versuches verwendet. Weitere Informationen zum erneuten Ausführen fehlerhafter Aufträge in einem Workflow findest du unter Erneutes Ausführen von Workflows und Jobs. Weitere Informationen zum erneuten Ausführen eines bestimmten Auftrags in einem Workflow findest du unter Erneutes Ausführen von Workflows und Jobs.
Kontext github
Wenn ein wiederverwendbarer Workflow durch einen aufrufenden Workflow ausgelöst wird, wird der Kontext github immer dem aufrufenden Workflow zugeordnet. Dem aufgerufenen Workflow wird automatisch Zugriff auf github.token und secrets.GITHUB_TOKEN gewährt. Weitere Informationen zum github-Kontext findest du unter Kontextreferenz.
Workflowvorlagen
Referenzinformationen, die beim Erstellen von Workflowvorlagen für deine Organisation verwendet werden sollen
Verfügbarkeit von Workflowvorlagen
Du kannst Vorlagen in Repositorys verwenden, die mit dem Vorlagenrepository übereinstimmen oder eine eingeschränktere Sichtbarkeit als das Vorlagenrepository aufweisen.
- Workflowvorlagen in einem öffentlichen
.github-Repository sind für alle Repositorytypen verfügbar. - Workflowvorlagen in einem internen
.github-Repository sind lediglich für interne und private Repositorys verfügbar. - Workflowvorlagen in einem privaten
.github-Repository sind ausschließlich für private Repositorys verfügbar.
Da öffentliche Workflowvorlagen ein öffentliches .github Repository erfordern, sind sie für Enterprise Managed Users nicht verfügbar.
Gewähren des Zugriffs für private oder interne Repositorys
Wenn du ein privates oder internes .github-Repository verwendest, musst du Benutzern oder Teams Lesezugriff gewähren, die die Vorlagen verwenden können sollten.
Platzhalter $default-branch
Wenn du auf den Standardbranch eines Repositorys verweisen musst, kannst du in deiner Workflowvorlage den Platzhalter $default-branch verwenden. Wenn ein Workflow erstellt wird, wird der Platzhalter automatisch durch den Namen des Standardzweigs des Repositorys ersetzt.
Beispieldatei für eine Workflowvorlage
Die Datei octo-organization-ci.yml veranschaulicht einen einfachen Workflow.
name: Octo Organization CI
on:
push:
branches: [ $default-branch ]
pull_request:
branches: [ $default-branch ]
jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v5
- name: Run a one-line script
run: echo Hello from Octo Organization
name: Octo Organization CI
on:
push:
branches: [ $default-branch ]
pull_request:
branches: [ $default-branch ]
jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v5
- name: Run a one-line script
run: echo Hello from Octo Organization
Anforderungen an Metadatendateien
Die Metadatendatei muss denselben Namen wie die Workflowdatei tragen, aber statt der .yml-Erweiterung muss .properties.json angefügt sein. Beispielsweise enthält die Datei octo-organization-ci.properties.json die Metadatei für den Workflow octo-organization-ci.yml:
{
"name": "Octo Organization Workflow",
"description": "Octo Organization CI workflow template.",
"iconName": "example-icon",
"categories": [
"Go"
],
"filePatterns": [
"package.json$",
"^Dockerfile",
".*\\.md$"
]
}
{
"name": "Octo Organization Workflow",
"description": "Octo Organization CI workflow template.",
"iconName": "example-icon",
"categories": [
"Go"
],
"filePatterns": [
"package.json$",
"^Dockerfile",
".*\\.md$"
]
}
-
`name` - **Muss angegeben werden.** Der Name des Workflows. Dieser wird in der Liste der verfügbaren Workflows angezeigt. -
`description` - **Muss angegeben werden.** Die Beschreibung des Workflows. Dieser wird in der Liste der verfügbaren Workflows angezeigt. -
`iconName` - **Optional:** Legt ein Symbol für den Workflow fest, das in der Liste der Workflows angezeigt wird. `iconName` kann eine der folgenden Typen sein:- Eine SVG-Datei, die im Verzeichnis
workflow-templatesgespeichert ist. Um auf eine Datei zu verweisen, muss der Wert dem Dateinamen ohne Dateierweiterung entsprechen. Beispielsweise wird auf eine SVG-Datei mit dem Namenexample-icon.svgalsexample-iconverwiesen. - Ein Symbol aus der Octicon-Gruppe von GitHub. Um auf ein Octicon zu verweisen, muss der Wert
octicon <icon name>lauten. Beispiel:octicon smiley.
- Eine SVG-Datei, die im Verzeichnis
-
`categories` - **Optional:** Definiert die Kategorien, unter denen der Workflow angezeigt wird. Du kannst Kategorienamen aus den folgenden Listen verwenden:- Allgemeine Kategorienamen aus dem Repository starter-workflows.
- Linguist-Sprachen aus der Liste im Repository linguist.
- Unterstützte Technologiestapel aus der Liste im Repository starter-workflows.
-
`filePatterns` - **Optional:** Dies ermöglicht die Verwendung des Workflows, wenn sich im Repository des Benutzers bzw. der Benutzerin eine Datei im Stammverzeichnis befindet, die einem definierten regulären Ausdruck entspricht.
YAML-Anker und -Aliase
Du kannst YAML-Anker und Aliase verwenden, um Wiederholungen in deinen Workflows zu reduzieren. Ein Anker (durch & gekennzeichnet) identifiziert einen Inhalt, den du wiederverwenden möchtest, wohingegen ein Alias (durch *gekennzeichnet) diesen Inhalt an einer anderen Stelle wiederholt.
Ausführliche Informationen zu Ankern und Aliasen findest du unter Knotenanker und -aliase in der YAML-Spezifikation.
Im folgenden Beispiel werden YAML-Anker und -Aliase mit Umgebungsvariablen verwendet:
jobs:
job1:
env: &env_vars # Define the anchor on first use
NODE_ENV: production
DATABASE_URL: ${{ secrets.DATABASE_URL }}
steps:
- run: echo "Using production settings"
job2:
env: *env_vars # Reuse the environment variables
steps:
- run: echo "Same environment variables here"
Das entspricht dem Schreiben des folgenden YAML-Codes ohne Anker und Aliase:
jobs:
job1:
env:
NODE_ENV: production
DATABASE_URL: ${{ secrets.DATABASE_URL }}
steps:
- run: echo "Using production settings"
job2:
env:
NODE_ENV: production
DATABASE_URL: ${{ secrets.DATABASE_URL }}
steps:
- run: echo "Same environment variables here"
Du kannst Anker außerdem für komplexere Konfigurationen wie die Wiederverwendung einer gesamten Auftragskonfiguration verwenden:
jobs:
test: &base_job # Define the anchor on first use
runs-on: ubuntu-latest
timeout-minutes: 30
env:
NODE_VERSION: '18'
steps:
- uses: actions/checkout@v5
- name: Set up Node.js
uses: actions/setup-node@v4
with:
node-version: ${{ env.NODE_VERSION }}
- run: npm test
alt-test: *base_job # Reuse the entire job configuration