搜尋
首頁後端開發Python教學使用 GitHub Actions 自動化 DevOps 工作流程

Automate DevOps Workflows with GitHub Actions

作者:Trix Cyrus

Waymap滲透測試工具:點這裡
TrixSec Github:點這裡


什麼是 GitHub 操作?

GitHub Actions 是整合到 GitHub 的自動化工具,提供自動化工作流程、CI/CD 管道、測試、程式碼品質檢查,甚至直接在儲存庫中部署的功能。它使您能夠使用 YAML 檔案定義工作流程,從而完全控制觸發器、環境和任務。


為什麼要使用 GitHub Actions 進行 DevOps?

  1. 與 GitHub 整合:與 GitHub 儲存庫、問題和拉取請求無縫整合。
  2. 可擴展的 CI/CD 管道:在各種平台上運行建置、測試和部署。
  3. 可自訂的工作流程:定義符合您確切需求的工作流程,從簡單的任務到複雜的多步驟流程。
  4. 可重複使用工作流程:跨多個專案共用可重複使用工作流程和自訂操作。

GitHub Actions 的關鍵元件

  1. 工作流程:儲存在 .github/workflows 目錄中的 YAML 檔案中定義的自動化流程。
  2. 作業:每個工作流程都由可以同時或順序運作的作業組成。
  3. 步驟:每個作業都有一系列步驟,其中可能包括執行命令、腳本或可重複使用的操作。
  4. 觸發器:定義觸發工作流程的事件,例如push、pull_request、schedule等

設定您的第一個 DevOps 工作流程

讓我們逐步建立一個基本的 CI 工作流程,以便在推送新提交時測試和建置程式碼。

  1. 建立工作流程檔案

    導航到儲存庫中的 .github/workflows 並建立一個名為 ci.yml 的檔案。

  2. 定義工作流程架構

   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. 工作流程說明
  • 觸發器(開啟):工作流程在針對主分支的 Push 或 Pull_request 事件上觸發。
  • 作業:我們有一個建置作業,用於安裝依賴項、執行測試和建置專案。
  • 步驟:每個步驟都使用操作或命令(例如,用於檢查程式碼的 actions/checkout、用於設定 Node.js 的 actions/setup-node 以及各種 npm 命令)。

添加 Linting 和程式碼品質檢查

為了確保程式碼質量,您可以在工作流程中新增 linting 步驟。

- name: Lint code
  run: npm run lint

在安裝依賴項之後新增此步驟有助於在管道早期識別程式碼品質問題。


使用 GitHub Actions 自動化部署

現在,讓我們為雲端服務新增自動部署步驟,例如 AWS 或 Firebase。

範例:部署到 Firebase

  1. 設定 Firebase CLI

    首先,在本機上安裝並設定 Firebase CLI。使用 firebase login:ci 產生令牌並將其儲存為 GitHub 機密 (FIREBASE_TOKEN)。

  2. 新增部署步驟

   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

這裡,我們指定needs: build,表示此部署作業僅在建置作業成功完成後執行。


高級 GitHub 操作提示

  1. 使用快取:透過快取相依性來加快工作流程。
- name: Lint code
  run: npm run lint
  1. 矩陣建置:使用矩陣策略跨多個版本或平台進行測試。
   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. Secrets 和環境變數:將敏感資訊儲存在 GitHub Secrets 中並使用 ${{ Secrets.SECRET_NAME }} 存取它們。

監控和調試工作流程

  • 查看日誌:GitHub Actions 中的每個步驟都會產生可透過「Actions」標籤存取的日誌。
  • 偵錯模式:在機密中新增 ACTIONS_STEP_DEBUG,值為 true 以進行詳細日誌記錄。
  • 錯誤通知:設定通知(例如 Slack 或電子郵件)以接收有關工作流程失敗的警報。

可重複使用的工作流程

隨著專案的成長,請考慮透過在 YAML 檔案中定義工作流程_call 並在多個儲存庫中重複使用來建立可重複使用的工作流程,特別是對於程式碼格式化或安全掃描等任務。


總結

使用 GitHub Actions 自動化 DevOps 工作流程可提高工作效率、減少人為錯誤並建立更強大的 CI/CD 管道。透過在後台無縫運行的工作流程,開發人員可以更專注於編寫程式碼,而不是部署任務。從測試開始,逐漸擴展到部署和監控,以最大限度地發揮 GitHub Actions 在 DevOps 之旅中的潛力。


本指南為使用 GitHub Actions 建置、測試和部署專案提供了基礎。一旦您熟悉了,您就可以透過自訂操作、整合和高級自動化進一步擴展,以實現完全優化的 DevOps 管道。

~TrixSec

以上是使用 GitHub Actions 自動化 DevOps 工作流程的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
Python和時間:充分利用您的學習時間Python和時間:充分利用您的學習時間Apr 14, 2025 am 12:02 AM

要在有限的時間內最大化學習Python的效率,可以使用Python的datetime、time和schedule模塊。 1.datetime模塊用於記錄和規劃學習時間。 2.time模塊幫助設置學習和休息時間。 3.schedule模塊自動化安排每週學習任務。

Python:遊戲,Guis等Python:遊戲,Guis等Apr 13, 2025 am 12:14 AM

Python在遊戲和GUI開發中表現出色。 1)遊戲開發使用Pygame,提供繪圖、音頻等功能,適合創建2D遊戲。 2)GUI開發可選擇Tkinter或PyQt,Tkinter簡單易用,PyQt功能豐富,適合專業開發。

Python vs.C:申請和用例Python vs.C:申請和用例Apr 12, 2025 am 12:01 AM

Python适合数据科学、Web开发和自动化任务,而C 适用于系统编程、游戏开发和嵌入式系统。Python以简洁和强大的生态系统著称,C 则以高性能和底层控制能力闻名。

2小時的Python計劃:一種現實的方法2小時的Python計劃:一種現實的方法Apr 11, 2025 am 12:04 AM

2小時內可以學會Python的基本編程概念和技能。 1.學習變量和數據類型,2.掌握控制流(條件語句和循環),3.理解函數的定義和使用,4.通過簡單示例和代碼片段快速上手Python編程。

Python:探索其主要應用程序Python:探索其主要應用程序Apr 10, 2025 am 09:41 AM

Python在web開發、數據科學、機器學習、自動化和腳本編寫等領域有廣泛應用。 1)在web開發中,Django和Flask框架簡化了開發過程。 2)數據科學和機器學習領域,NumPy、Pandas、Scikit-learn和TensorFlow庫提供了強大支持。 3)自動化和腳本編寫方面,Python適用於自動化測試和系統管理等任務。

您可以在2小時內學到多少python?您可以在2小時內學到多少python?Apr 09, 2025 pm 04:33 PM

兩小時內可以學到Python的基礎知識。 1.學習變量和數據類型,2.掌握控制結構如if語句和循環,3.了解函數的定義和使用。這些將幫助你開始編寫簡單的Python程序。

如何在10小時內通過項目和問題驅動的方式教計算機小白編程基礎?如何在10小時內通過項目和問題驅動的方式教計算機小白編程基礎?Apr 02, 2025 am 07:18 AM

如何在10小時內教計算機小白編程基礎?如果你只有10個小時來教計算機小白一些編程知識,你會選擇教些什麼�...

如何在使用 Fiddler Everywhere 進行中間人讀取時避免被瀏覽器檢測到?如何在使用 Fiddler Everywhere 進行中間人讀取時避免被瀏覽器檢測到?Apr 02, 2025 am 07:15 AM

使用FiddlerEverywhere進行中間人讀取時如何避免被檢測到當你使用FiddlerEverywhere...

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
4 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
4 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
4 週前By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
1 個月前By尊渡假赌尊渡假赌尊渡假赌

熱工具

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

SecLists

SecLists

SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

Dreamweaver Mac版

Dreamweaver Mac版

視覺化網頁開發工具

PhpStorm Mac 版本

PhpStorm Mac 版本

最新(2018.2.1 )專業的PHP整合開發工具