Heim >Backend-Entwicklung >Python-Tutorial >Automatisieren Sie DevOps-Workflows mit GitHub-Aktionen
Autor: Trix Cyrus
Waymap-Pentesting-Tool: Klicken Sie hier
TrixSec Github: Klicken Sie hier
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.
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.
Erstellen Sie die Workflow-Datei
Navigieren Sie zu .github/workflows in Ihrem Repository und erstellen Sie eine Datei mit dem Namen ci.yml.
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
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.
Fügen wir nun einen automatisierten Bereitstellungsschritt zu einem Cloud-Dienst wie AWS oder Firebase hinzu.
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).
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.
- name: Lint code run: npm run lint
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
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.
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!