Hinweis: GitHub-gehostete Runner werden auf GitHub Enterprise Server derzeit nicht unterstützt. Weitere Informationen zur geplanten zukünftigen Unterstützung findest Du in der GitHub public roadmap.
Einführung
Sowohl GitLab CI/CD als auch GitHub Actions erlauben es Ihnen, Workflows zu erstellen, mit denen Code automatisch erstellt, getestet, veröffentlicht, freigegeben und bereitgestellt wird. GitLab CI/CD und GitHub Actions haben einige Ähnlichkeiten in der Workflow-Konfiguration:
- Workflow-Konfigurationsdateien werden in YAML geschrieben und im Code-Repository gespeichert.
- Workflows umfassen einen oder mehrere Jobs.
- Jobs beinhalten einen oder mehrere Schritte oder einzelne Befehle.
- Aufträge können entweder auf verwalteten oder auf selbstgehosteten Computern ausgeführt werden.
Es gibt einige Unterschiede, und in diesem Leitfaden kannst du dich mit den wichtigsten Unterschieden vertraut machen, damit du deinen Workflow zu GitHub Actions migrieren kannst.
Aufträge
Aufträge in GitLab CI/CD sind Aufträgen in GitHub Actions sehr ähnlich. In beiden Systemen haben Jobs folgende Merkmale:
- Aufträge enthalten eine Reihe von Schritten oder Skripts, die sequenziell ausgeführt werden.
- Aufträge können auf separaten Computern oder in separaten Containern ausgeführt werden.
- Jobs werden standardmäßig parallel ausgeführt, können aber so konfiguriert werden, dass sie sequentiell laufen.
Du kannst ein Skript oder einen Shellbefehl in einem Auftrag ausführen. In GitLab CI/CD werden Skriptschritte mithilfe des Schlüssels script
angegeben. In GitHub Actions sind alle Skripts mit dem Schlüssel run
spezifiziert.
Nachfolgend ein Beispiel für die Syntax in jedem System:
GitLab CI/CD | GitHub Actions |
---|---|
|
|
Runner
Runner sind Computer, auf denen die Aufträge ausgeführt werden. Sowohl GitLab CI/CD als auch GitHub Actions bieten verwaltete und selbstgehostete Varianten von Runnern an. In GitLab CI/CD werden tags
dazu verwendet, Aufträge auf verschiedenen Plattformen auszuführen, während sie in GitHub Actions mit dem Schlüssel runs-on
ausgeführt werden.
Nachfolgend ein Beispiel für die Syntax in jedem System:
GitLab CI/CD | GitHub Actions |
---|---|
|
|
Weitere Informationen findest du unter Workflowsyntax für GitHub Actions.
Docker-Images
Sowohl GitLab CI/CD als auch GitHub Actions unterstützen die Ausführung von Aufträgen in einem Docker-Image. In GitLab CI/CD werden Docker-Images mit einem image
-Schlüssel definiert, während sie in GitHub Actions mit dem Schlüssel container
definiert werden.
Nachfolgend ein Beispiel für die Syntax in jedem System:
GitLab CI/CD | GitHub Actions |
---|---|
|
|
Weitere Informationen findest du unter Workflowsyntax für GitHub Actions.
Bedingungs- und Ausdruckssyntax
In GitLab CI/CD wird anhand von rules
festgestellt, ob ein Auftrag für eine bestimmte Bedingung ausgeführt wird. Von GitHub Actions wird mithilfe des Schlüsselworts if
sichergestellt, dass ein Auftrag nur dann ausgeführt wird, wenn eine Bedingung erfüllt wird.
Nachfolgend ein Beispiel für die Syntax in jedem System:
GitLab CI/CD | GitHub Actions |
---|---|
|
|
Weitere Informationen findest du unter Ausdrücke.
Abhängigkeiten zwischen Jobs
Sowohl mit GitLab CI/CD als auch mit GitHub Actions kannst du Abhängigkeiten für einen Job festlegen. In beiden Systemen werden Aufträge standardmäßig parallel ausgeführt, aber Auftragsabhängigkeiten in GitHub Actions können explizit mit dem Schlüssel needs
angegeben werden. In GitLab CI/CD existiert auch ein Konzept von stages
. Hier werden Aufträge in einer Phase gleichzeitig ausgeführt, aber die nächste Phase beginnt erst dann, wenn alle Aufträge aus der vorherigen Phase abgeschlossen sind. Dieses Szenario kannst du in GitHub Actions mit dem Schlüssel needs
nachbilden.
Nachfolgend ein Beispiel für die Syntax in jedem System. Die Workflows beginnen mit zwei Aufträgen namens build_a
und build_b
, die parallel ausgeführt werden. Nach Abschluss dieser Aufträge wird ein weiterer Auftrag ausgeführt, der mit der Bezeichnung test_ab
benannt ist. Schließlich wird, nach Abschluss von test_ab
, der Auftrag deploy_ab
ausgeführt.
GitLab CI/CD | GitHub Actions |
---|---|
|
|
Weitere Informationen findest du unter Workflowsyntax für GitHub Actions.
Planen von Workflows
Sowohl GitLab CI/CD als auch GitHub Actions ermöglichen es Ihnen, Workflows in einem bestimmten Intervall auszuführen. In GitLab CI/CD werden Pipelinepläne mit der Benutzeroberfläche konfiguriert, während du in GitHub Actions einen Workflow in einem geplanten Intervall mit dem Schlüssel „on“ auslösen kannst.
Weitere Informationen findest du unter Ereignisse zum Auslösen von Workflows.
Variablen und Geheimnisse
GitLab CI/CD und GitHub Actions unterstützen das Festlegen von Variablen in der Pipeline- oder Workflowkonfigurationsdatei und das Erstellen von Geheimnissen mithilfe der Benutzeroberfläche von GitLab oder GitHub Enterprise Server.
Weitere Informationen findest du unter Variablen und unter Verschlüsselte Geheimnisse.
Caching
GitLab CI/CD und GitHub Actions stellen in der Konfigurationsdatei eine Methode zum manuellen Zwischenspeichern von Workflowdateien bereit.
Die Zwischenspeicherung mit GitHub Actions ist nur für Repositorys verfügbar, die in GitHub.com oder GitHub Enterprise Server 3.5 und höher gehostet werden. Weitere Informationen findest du unter Zwischenspeichern von Abhängigkeiten zum Beschleunigen von Workflows.
Artifacts
Sowohl von GitLab CI/CD als auch von GitHub Actions können Dateien und Verzeichnisse hochgeladen werden, die von einem Auftrag als Artefakte erstellt wurden. In GitHub Actions können Artefakte dazu verwendet werden, Daten über mehrere Aufträge hinweg beizubehalten.
Nachfolgend ein Beispiel für die Syntax in jedem System:
GitLab CI/CD | GitHub Actions |
---|---|
|
|
Weitere Informationen findest du unter Speichern von Workflowdaten als Artefakte.
Datenbanken und Dienstcontainer
Mit beiden Systemen kannst du zusätzliche Container für Datenbanken, Zwischenspeicherung im Cache oder andere Abhängigkeiten einbinden.
In GitLab CI/CD wird ein Container für den Auftrag mit dem Schlüssel image
angegeben, während von GitHub Actions der Schlüssel container
verwendet wird. In beiden Systemen werden zusätzliche Dienstcontainer mit dem Schlüssel services
angegeben.
Nachfolgend ein Beispiel für die Syntax in jedem System:
GitLab CI/CD | GitHub Actions |
---|---|
|
|
Weitere Informationen finden Sie unter Informationen zu Service-Containern.