Heim >Backend-Entwicklung >Python-Tutorial >Automatisieren Sie DevOps-Workflows mit GitHub-Aktionen

Automatisieren Sie DevOps-Workflows mit GitHub-Aktionen

Susan Sarandon
Susan SarandonOriginal
2024-11-11 03:37:02783Durchsuche

Automate DevOps Workflows with GitHub Actions

Autor: Trix Cyrus

Waymap-Pentesting-Tool: Klicken Sie hier
TrixSec Github: Klicken Sie hier


Was sind GitHub-Aktionen?

GitHub Actions ist ein in GitHub integriertes Automatisierungstool, das die Möglichkeit bietet, Arbeitsabläufe, CI/CD-Pipelines, Tests, Codequalitätsprüfungen und sogar Bereitstellungen direkt in Ihrem Repository zu automatisieren. Sie können damit Workflows mithilfe von YAML-Dateien definieren und haben so die volle Kontrolle über Auslöser, Umgebungen und Aufgaben.


Warum GitHub-Aktionen für DevOps verwenden?

  1. In GitHub integriert: Nahtlose Integration in GitHub-Repos, Issues und Pull Requests.
  2. Skalierbare CI/CD-Pipelines: Führen Sie Builds, Tests und Bereitstellungen auf verschiedenen Plattformen aus.
  3. Anpassbare Arbeitsabläufe: Definieren Sie Arbeitsabläufe, die genau Ihren Anforderungen entsprechen, von einfachen Aufgaben bis hin zu komplexen mehrstufigen Prozessen.
  4. Wiederverwendbare Arbeitsabläufe: Teilen Sie wiederverwendbare Arbeitsabläufe und benutzerdefinierte Aktionen über mehrere Projekte hinweg.

Schlüsselkomponenten von GitHub-Aktionen

  1. Workflows: Automatisierte Prozesse, die in YAML-Dateien definiert sind, die im Verzeichnis .github/workflows gespeichert sind.
  2. Jobs: Jeder Workflow besteht aus Jobs, die gleichzeitig oder nacheinander ausgeführt werden können.
  3. Schritte: Jeder Job besteht aus einer Reihe von Schritten, die das Ausführen von Befehlen, Skripts oder wiederverwendbaren Aktionen umfassen können.
  4. Auslöser: Definieren Sie Ereignisse, die einen Workflow auslösen, z. B. Push, Pull_Request, Zeitplan usw.

Einrichten Ihres ersten DevOps-Workflows

Lassen Sie uns durch die Erstellung eines grundlegenden CI-Workflows gehen, um Ihren Code zu testen und zu erstellen, wann immer ein neuer Commit gepusht wird.

  1. Erstellen Sie die Workflow-Datei

    Navigieren Sie zu .github/workflows in Ihrem Repository und erstellen Sie eine Datei mit dem Namen ci.yml.

  2. Definieren Sie die Workflow-Struktur

   name: CI Workflow

   on:
     push:
       branches:
         - main
     pull_request:
       branches:
         - main

   jobs:
     build:
       runs-on: ubuntu-latest

       steps:
         - name: Checkout code
           uses: actions/checkout@v3

         - name: Set up Node.js
           uses: actions/setup-node@v3
           with:
             node-version: '16'

         - name: Install dependencies
           run: npm install

         - name: Run tests
           run: npm test

         - name: Build project
           run: npm run build
  1. Erklärung des Arbeitsablaufs
  • Trigger (ein): Der Workflow wird bei Push- oder Pull_request-Ereignissen ausgelöst, die auf den Hauptzweig abzielen.
  • Jobs: Wir haben einen einzelnen Build-Job, der Abhängigkeiten installiert, Tests ausführt und das Projekt erstellt.
  • Schritte: Jeder Schritt verwendet Aktionen oder Befehle (z. B. „actions/checkout“ zum Auschecken des Codes, „actions/setup-node“ zum Einrichten von Node.js und verschiedene npm-Befehle).

Linting und Code-Qualitätsprüfungen hinzufügen

Um die Codequalität sicherzustellen, können Sie Ihrem Workflow einen Linting-Schritt hinzufügen.

- name: Lint code
  run: npm run lint

Das Hinzufügen dieses Schritts nach der Installation von Abhängigkeiten hilft dabei, Probleme mit der Codequalität frühzeitig in der Pipeline zu erkennen.


Automatisieren von Bereitstellungen mit GitHub-Aktionen

Fügen wir nun einen automatisierten Bereitstellungsschritt zu einem Cloud-Dienst wie AWS oder Firebase hinzu.

Beispiel: Bereitstellung auf Firebase

  1. Firebase-CLI einrichten

    Installieren und konfigurieren Sie zunächst die Firebase-CLI auf Ihrem lokalen Computer. Generieren Sie ein Token mit Firebase login:ci und speichern Sie es als GitHub-Geheimnis (FIREBASE_TOKEN).

  2. Bereitstellungsschritt hinzufügen

   name: CI Workflow

   on:
     push:
       branches:
         - main
     pull_request:
       branches:
         - main

   jobs:
     build:
       runs-on: ubuntu-latest

       steps:
         - name: Checkout code
           uses: actions/checkout@v3

         - name: Set up Node.js
           uses: actions/setup-node@v3
           with:
             node-version: '16'

         - name: Install dependencies
           run: npm install

         - name: Run tests
           run: npm test

         - name: Build project
           run: npm run build

Hier geben wir „Bedarf: Build“ an, was bedeutet, dass dieser Bereitstellungsjob erst ausgeführt wird, nachdem der Build-Job erfolgreich abgeschlossen wurde.


Erweiterte GitHub-Aktionstipps

  1. Caching verwenden: Beschleunigen Sie Arbeitsabläufe durch Caching von Abhängigkeiten.
- name: Lint code
  run: npm run lint
  1. Matrix-Builds: Testen Sie mehrere Versionen oder Plattformen mithilfe von Matrixstrategien.
   deploy:
     needs: build
     runs-on: ubuntu-latest

     steps:
       - name: Checkout code
         uses: actions/checkout@v3

       - name: Set up Node.js
         uses: actions/setup-node@v3
         with:
           node-version: '16'

       - name: Install dependencies
         run: npm install

       - name: Build project
         run: npm run build

       - name: Deploy to Firebase
         env:
           FIREBASE_TOKEN: ${{ secrets.FIREBASE_TOKEN }}
         run: |
           npm install -g firebase-tools
           firebase deploy
  1. Geheimnisse und Umgebungsvariablen: Speichern Sie vertrauliche Informationen in GitHub Secrets und greifen Sie mit ${{ Secrets.SECRET_NAME }} darauf zu.

Überwachungs- und Debugging-Workflows

  • Protokolle anzeigen: Jeder Schritt in GitHub-Aktionen generiert Protokolle, auf die über die Registerkarte „Aktionen“ zugegriffen werden kann.
  • Debug-Modus: Fügen Sie ACTIONS_STEP_DEBUG in Secrets mit dem Wert „true“ für ausführliche Protokollierung hinzu.
  • Fehlerbenachrichtigungen: Richten Sie Benachrichtigungen ein (z. B. Slack oder E-Mail), um Benachrichtigungen über Workflow-Fehler zu erhalten.

Wiederverwendbare Arbeitsabläufe

Wenn Ihre Projekte wachsen, sollten Sie erwägen, wiederverwendbare Workflows zu erstellen, indem Sie Workflow_call in Ihrer YAML-Datei definieren und in mehreren Repositorys wiederverwenden, insbesondere für Aufgaben wie Codeformatierung oder Sicherheitsscans.


Zusammenfassung

Die Automatisierung von DevOps-Workflows mit GitHub Actions steigert die Produktivität, reduziert menschliche Fehler und schafft eine robustere CI/CD-Pipeline. Da Arbeitsabläufe nahtlos im Hintergrund laufen, können sich Entwickler mehr auf das Schreiben von Code und weniger auf Bereitstellungsaufgaben konzentrieren. Beginnen Sie klein mit dem Testen und weiten Sie es schrittweise auf die Bereitstellung und Überwachung aus, um das Potenzial von GitHub Actions auf Ihrer DevOps-Reise zu maximieren.


Dieser Leitfaden bietet eine Grundlage für das Erstellen, Testen und Bereitstellen Ihrer Projekte mit GitHub Actions. Sobald Sie sich wohl fühlen, können Sie mit benutzerdefinierten Aktionen, Integrationen und erweiterter Automatisierung für eine vollständig optimierte DevOps-Pipeline weiter expandieren.

~TrixSec

Das obige ist der detaillierte Inhalt vonAutomatisieren Sie DevOps-Workflows mit GitHub-Aktionen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn