Übersicht
GitHub Actions ist eine Plattform für Continuous Integration und Continuous Delivery (CI/CD), mit der du deine Build-, Test- und Bereitstellungspipeline automatisieren kannst. Du kannst Workflows erstellen, mit denen du alle Pull Requests für dein Repository erstellen und testen sowie gemergte Pull Requests für die Produktion bereitstellen kannst.
GitHub Actions ist nicht auf DevOps beschränkt und kann auch für andere Ereignisse in deinem Repository Workflows ausführen. So kannst du z. B. einen Workflow für das automatische Hinzufügen geeigneter Bezeichnungen ausführen, sobald in deinem Repository ein neues Issue erstellt wird.
GitHub stellt virtuelle Linux-, Windows- und macOS-Computer für die Ausführung deiner Workflows bereit. Alternativ dazu kannst du eigene selbstgehostete Runner in deinem Rechenzentrum oder deiner Cloudinfrastruktur hosten.
Die Komponenten von GitHub Actions
Du kannst konfigurieren, dass bei einem Ereignis in deinem Repository ein GitHub Actions-Workflow ausgelöst wird. Dabei kann es sich etwa um das Öffnen eines Pull Requests oder das Erstellen eines Issues handeln. Der Workflow enthält einen oder mehrere Aufträge, die nacheinander oder gleichzeitig ausgeführt werden können. Jeder Auftrag wird innerhalb eines eigenen Runners der VM oder in einem Container ausgeführt und verfügt über einen oder mehrere Schritte. Diese führen entweder ein von Ihnen definiertes Skript oder eine Aktion aus. Dabei handelt es sich um eine wiederverwendbare Erweiterung zur Vereinfachung des Workflows.
Workflows
Ein Workflow ist ein konfigurierbarer automatisierter Prozess zur Ausführung eines oder mehrerer Aufträge. Workflows werden durch eine im Repository eingecheckte YAML-Datei definiert. Die Auslösung ihrer Ausführung erfolgt durch ein Ereignis in deinem Repository, manuell oder nach einem definierten Zeitplan.
Workflows werden im .github/workflows
-Verzeichnis in einem Repository definiert. Ein Repository kann mehrere Workflows enthalten, die jeweils unterschiedliche Aufgaben ausführen können, wie:
- Erstellen und Testen von Pull Requests
- Bereitstellen deiner Anwendung bei jeder Erstellung eines Release
- Hinzufügen einer Bezeichnung, wenn ein neues Issue geöffnet wird
Du kannst innerhalb eines anderen Workflows auf einen Workflow verweisen. Weitere Informationen finden Sie unter Wiederverwenden von Workflows.
Weitere Informationen finden Sie unter Schreiben von Workflows.
Ereignisse
Bei einem Ereignis handelt es sich um eine bestimmte Aktivität in einem Repository, die die Ausführung eines Workflows auslöst. Eine Aktivität kann beispielsweise von GitHub stammen, wenn ein Pull Request erstellt, ein Issue geöffnet oder ein Commit per Push in ein Repository übertragen wird. Die Ausführung eines Workflows kann auch nach einem Zeitplan, durch Posten in einer REST-API oder manuell ausgelöst werden.
Eine vollständige Liste der Ereignisse zum Auslösen von Workflows findest du unter Ereignisse, die Workflows auslösen.
Aufträge
Ein Auftrag umfasst mehrere Schritte in einem Workflow, die in demselben Runner ausgeführt werden. Jeder Schritt besteht entweder aus einem Shellskript oder aus einer Aktion, die ausgeführt werden. Die Schritte werden nacheinander ausgeführt und sind voneinander abhängig. Da alle Schritte im gleichen Runner ausgeführt werden, kannst du Daten eines Schritts für andere Schritte freigeben. So kann z. B. in einem Schritt eine Anwendung erstellt und im nächsten Schritt die erstellte Anwendung getestet werden.
Ein Auftrag so konfiguriert werden, dass er Abhängigkeiten zu anderen Aufträgen enthält. Standardmäßig verfügen Aufträge nicht über Abhängigkeiten und werden parallel ausgeführt. Wenn ein Auftrag von einem anderen Auftrag abhängt, wartet er auf den Abschluss des abhängigen Auftrags, bevor er ausgeführt wird.
Sie könnten zum Beispiel mehrere Build-Aufträge für verschiedene Architekturen ohne Auftragsabhängigkeiten konfigurieren und einen Auftrag zur Paketerstellung, der von diesen Aufträgen abhängig ist. Dadurch werden die Buildaufträge parallel ausgeführt, und der Auftrag zur Paketerstellung wird ausgeführt, wenn sie erfolgreich abgeschlossen sind.
Weitere Informationen finden Sie unter Auswählen, was in dem Workflow passiert.
Aktionen
Bei einer Aktion handelt es sich um eine benutzerdefinierte Anwendung für die GitHub Actions-Plattform zur Ausführung einer komplexen und häufig ausgeführten Aufgabe. Mit einer Aktion können Sie die Menge des Codes in Ihren Workflow-Dateien reduzieren. Mit einer Aktion können Sie Ihr Git-Repository aus GitHub abrufen, die korrekte Toolkette für Ihre Buildumgebung einrichten oder die Authentifizierung bei Ihrem Cloudanbieter einrichten.
Du kannst eigene Aktionen schreiben oder im GitHub Marketplace nach Aktionen für deine Workflows suchen.
Weitere Informationen zu Aktionen findest du unter Freigeben von Automatisierungen.
Runner
Ein Runner ist ein Server, auf dem die Workflows ausgeführt werden, wenn sie ausgelöst werden. Jeder Runner kann jeweils nur einen Auftrag ausführen. GitHub stellt Runner für Ubuntu Linux, Microsoft Windows und macOS zum Ausführen von Workflows bereit. Jede Workflowausführung erfolgt in einer neu bereitgestellten VM.
GitHub bietet zudem größerer Runner, die in größeren Konfigurationen verfügbar sind. Weitere Informationen finden Sie unter Verwenden größerer Runner.
Wenn Sie ein anderes Betriebssystem benötigen oder eine bestimmte Hardwarekonfiguration wünschen, können Sie Ihre eigenen Runner hosten.
Weitere Informationen zu selbstgehosteten Runnern findest du unter Deinen eigenen Runner hosten.
Nächste Schritte
GitHub Actions kann dir dabei helfen, nahezu alle Aspekte deines Anwendungsentwicklungsprozesses zu automatisieren. Willst du loslegen? Hier findest du einige hilfreiche Ressourcen für deine nächsten Schritte mit GitHub Actions:
- Informationen zum Erstellen eines GitHub Actions-Workflows sind unter Verwenden von Workflowvorlagen zu finden.
- Informationen zu CI-Workflows (Continuous Integration) sind unter Erstellen und Testen zu finden.
- Informationen zum Erstellen und Veröffentlichen von Paketen findest du unter Veröffentlichen von Paketen.
- Informationen zum Bereitstellen von Projekten findest du unter Anwendungsfälle und Beispiele.
- Informationen zum Automatisieren von Aufgaben und Prozessen auf GitHub findest du unter Projekte verwalten.
- Beispiele, die komplexere Features von GitHub Actions veranschaulichen, sind unter Anwendungsfälle und Beispiele zu finden. Diese detaillierten Beispiele erläutern, wie man Code auf einem Runner testen, auf die GitHub-CLI zugreifen und erweiterte Funktionen wie Parallelität und Testmatrizen verwenden kann.
- Zum Nachweis der Kenntnisse in der Automatisierung von Arbeitsabläufen und der Beschleunigung der Entwicklung mit GitHub Actions kann ein GitHub Actions-Zertifikat mit GitHub Certifications erworben werden. Weitere Informationen findest du unter Informationen zu GitHub Certifications.