【GitHub Workflows 基礎(二)】深入理解 on、jobs、steps 的核心語法與執行邏輯

📘 GitHub Workflows 基礎(二):深入理解 onjobssteps 的核心語法與執行邏輯

繼第一篇講完 .github/workflows/ 中多個工作流的結構后,本篇將深入 GitHub Actions 的核心三要素:on(觸發器)、jobs(任務)、steps(步驟),帶你徹底搞懂它的執行流程、語法規則與靈活寫法。


🧩 一、Workflow 的結構復習

每一個 .yml 文件都是一個完整的工作流(workflow),它的基本結構如下:

name: 工作流名稱on:  # 👈 觸發條件push:branches: [main]jobs:  # 👇 工作流任務build:runs-on: ubuntu-lateststeps:- uses: actions/checkout@v4- run: echo "Hello World"

? 二、on:定義何時觸發

on: 是 GitHub Actions 的“啟動器”——定義這個 workflow 應該在什么事件發生時啟動

? 常見寫法

on: push             # 推送時觸發
on: pull_request     # PR 時觸發
on: workflow_dispatch # 手動觸發(按鈕)

? 進階配置

指定分支:
on:push:branches: [main, dev]
指定文件變化:
on:push:paths:- 'src/**'- '!docs/**'
多種觸發器:
on:push:pull_request:

📌 你可以組合不同觸發器,一個 workflow 可以監聽多個事件。


🧱 三、jobs:任務組,真正的工作發生地

每個 jobs 就是一個“任務集合”,可以有多個 job 并行或順序執行。

基本結構

jobs:build:runs-on: ubuntu-lateststeps:...
  • build 是這個 job 的 ID
  • runs-on 是運行環境(如 ubuntu、windows、macOS)
  • 一個 job 包含多個 step,每個 step 是一個命令或 action

🧩 四、steps:構成 job 的每一個步驟

每個 job 的步驟通過 steps: 列出,按順序執行,就像命令行里一行一行敲的命令。

兩種類型的步驟:

1. 使用已有 action:
- uses: actions/checkout@v4  # 拉取代碼
- uses: actions/setup-node@v4with:node-version: 18
2. 自定義 shell 命令:
- run: echo "開始構建項目"
- run: npm install && npm run build

📌 run: 相當于寫一條 shell 命令。你可以寫一行,也可以像腳本一樣多行:

- name: 安裝并構建run: |npm cinpm run build

🔁 五、多個 Job 的依賴與串聯

默認情況下,多個 job 是并行執行的,但你可以使用 needs: 實現前后順序。

示例:先 build 再 deploy

jobs:build:runs-on: ubuntu-lateststeps:- run: echo "構建中..."deploy:needs: build  # ? 表示必須等 build 執行完runs-on: ubuntu-lateststeps:- run: echo "部署中..."

這樣可以避免部署提前觸發,確保順序正確。


🔐 六、使用 Secrets 和變量

GitHub Actions 支持讀取環境變量和倉庫的 Secret 值。

? 使用 Secrets

- run: echo "${{ secrets.MY_SECRET_KEY }}"

Secrets 可以在倉庫 → Settings → Secrets 中配置,用于保存:

  • API Key
  • token
  • 密碼等敏感信息

? 自定義環境變量

env:NODE_ENV: production

也可以在 jobssteps 中設置。


🧪 七、實踐示例:構建并部署網站

name: Build and Deployon:push:branches: [main]jobs:build:runs-on: ubuntu-lateststeps:- uses: actions/checkout@v4- uses: actions/setup-node@v4with:node-version: 18- run: npm install- run: npm run build- uses: actions/upload-pages-artifact@v2with:path: distdeploy:needs: buildruns-on: ubuntu-lateststeps:- uses: actions/deploy-pages@v3

📌 總結思維圖

workflow
├── name: 工作流名稱
├── on: 觸發器
└── jobs:├── job1:│   ├── runs-on│   └── steps: [uses, run]└── job2:├── needs: job1└── steps

🏁 總結一句話

on 決定何時觸發,jobs 定義做哪些事,steps 寫出每個動作。GitHub Actions 就是一個小型 CI 系統,讓你用 YAML 編排自動化流程。


🔮 下一篇預告

👉 《GitHub Workflows 基礎(三):深入理解 artifact、緩存、并發與條件執行》

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/93716.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/93716.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/93716.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

React Filber及核心原理

1. React Fiber 的核心目標??增量渲染?:將大型更新拆解為可中斷的小任務(時間切片),避免阻塞主線程?優先級調度?:動態管理任務執行順序(如用戶交互 > 動畫 > 數據加載)。與瀏覽器協作…

Shader開發(五)什么是渲染管線

在計算機圖形學中,渲染管線(Rendering Pipeline) 是圖形處理器(GPU)將3D網格數據轉化為屏幕圖像的核心流程。無論是炫酷的游戲畫面還是逼真的動畫場景,這一切都離不開渲染管線的默默工作。對于想要學習著色…

CentOS7 使用Docker安裝MinIO完整教程

目錄 1. MinIO簡介 什么是MinIO? 為什么選擇Docker安裝? 2. 環境準備 檢查Docker狀態 檢查防火墻設置 創建存儲目錄 3. 快速啟動MinIO 基礎啟動命令 驗證啟動狀態 4. 配置持久化存儲 停止并刪除臨時容器 使用數據卷啟動MinIO 驗證數據持久化 5. 訪問MinIO控制臺…

【數據庫】時序數據庫選型指南:從大數據視角看IoTDB的核心優勢

文章目錄前言-官網鏈接一、時序數據管理的時代挑戰二、時序數據庫選型的六大核心維度1. 數據模型設計2. 寫入與查詢性能3. 存儲效率4. 系統擴展性5. 生態兼容性6. 運維復雜度三、IoTDB的技術架構解析1. 存儲引擎創新2. 計算引擎優勢3. 分布式架構設計四、行業解決方案對比1. 能…

【25-cv-08364】Keith攜Hello Angel版權圖發案

Hello Angel版權圖案件號:25-cv-08364起訴時間:2025/7/22原告:Angelea Clark Van Dam原告律所:Keith受理法院:伊利諾伊州北區地方法院原告介紹原告是是一位來自澳大利亞的藝術家,筆名為Hello Angel&#xf…

SkSurface---像素的容器:表面

如果說 SkCanvas 是畫布,是所有繪圖操作的提供者的話,那么 SkSurface 就是畫布的容器,我們稱之為表面,它負責管理畫布對應的像素數據。這些像素數據可以是在內存中創建的,也可以是在 GPU 顯存中創建的。創建一個空白表…

26.(vue3.x+vite)以pinia為中心的開發模板

效果截圖 代碼實現 HelloWorld.vue <template><div style="padding: 20px;">介紹:<br>1:使用class 來減少pinia(store)的代碼量<br>

華為AI Agent智能園藝助手開發案例

一、引言與行業背景 在數字化與智能化日益滲透我們生活的今天&#xff0c;園藝這一傳統而充滿生機的領域&#xff0c;也迎來了智能化的革新。華為AI Agent智能園藝助手通過融合人工智能與園藝專業知識&#xff0c;為用戶提供一站式、個性化的園藝養護解決方案&#xff0c;徹底改…

Linux Flathub軟件管理方法 使用指南

Flathub 使用指南&#xff1a;軟件安裝、管理及常用軟件推薦 一. 什么是 Flathub&#xff1f; Flathub 是 Flatpak 應用程序的主要分發中心&#xff0c;類似于 Linux 上的"應用商店"。它提供了一種跨發行版的軟件打包和分發方式&#xff0c;讓用戶可以在任何 Linux 發…

GitLab 18.2 發布幾十項與 DevSecOps 有關的功能,可升級體驗【二】

沿襲我們的月度發布傳統&#xff0c;極狐GitLab 發布了 18.2 版本&#xff0c;該版本帶來了議題和任務的自定義工作流狀態、新的合并請求主頁、新的群組概覽合規儀表盤、下載安全報告的 PDF 導出文件、中心化的安全策略管理&#xff08;Beta&#xff09;等幾十個重點功能的改進…

??免費語音轉換服務(TTS)全面指南

????1. TTS技術概述?? TTS&#xff08;Text-to-Speech&#xff09;通過AI將文字轉化為自然語音&#xff0c;核心技術包括??深度神經網絡&#xff08;DNN&#xff09;??、??語音韻律建模??和??聲學合成??。其核心優勢在于&#xff1a; ??多語言支持??&a…

正則化都是放在模型的哪個位置呢?

? 什么是“正則化”&#xff1f;在神經網絡中&#xff0c;正則化&#xff08;Regularization&#xff09; 抑制過擬合的技巧 目的是讓模型在訓練集和測試集上都表現得好&#xff08;泛化能力強&#xff09;。&#x1f9e0; 常見的正則化手段包括&#xff1a;方法類型通常放在哪…

Python畢業設計 | 基于協同過濾的智能商品推薦與數據大屏系統(Vue+Flask+Scikit-learn,附源碼+文檔)

個人介紹&#x1f3af; 畢業設計私人教練 專注計算機畢設輔導第 6 年&#xff0c;累計 1v1 帶飛 800 同學順利通關。從選題、開題、代碼、論文到答辯&#xff0c;一條龍陪跑&#xff1b;擅長把導師的 “模糊要求” 變成能落地的技術方案。白天寫方案&#xff0c;晚上改論文&…

基于千問2.5-VL-7B訓練識別人的表情

一、安裝LLaMA-Factory 我們使用LLaMA-Factory來進行微調&#xff0c;安裝LLaMA-Factory來參考文章&#xff1a; 大模型微調工具LLaMA-Factory的安裝流程-CSDN博客 二、下載千問2.5-VL-7B模型 我們使用千問2.5-VL-7B多模態模型來進行微調 通義千問2.5-VL-7B-Instruct 下載…

Android屏幕適配:從dp到px的轉換與今日頭條適配方案詳解

前言 在Android開發中&#xff0c;屏幕適配一直是一個重要且復雜的話題。不同設備有著不同的屏幕尺寸、分辨率和像素密度&#xff0c;如何讓應用在各種設備上都能良好顯示&#xff0c;是每個開發者都需要面對的問題。本文將深入探討Android系統中dp到px的轉換原理&#xff0c;并…

nvim 縮進4空格

要把 Neovim 配置為縮進 4 空格&#xff0c;并適用于所有語言&#xff08;或某些語言如 C/C&#xff09;&#xff0c;你只需要設置這三個核心選項即可&#xff1a;? 通用方式&#xff1a;在 init.lua 或 options.lua 中添加 vim.opt.tabstop 4 -- 一個 <Tab> 等…

pdw估計edw怎么估計

問題一、pdw估計edw怎么估計PDW&#xff08;Pulse Descriptor Word&#xff09;數據是雷達接收到的每一個脈沖的瞬時特征數據&#xff0c;EDW&#xff08;Emitter Descriptor Word&#xff09;是對某一輻射源&#xff08;發射機&#xff09;整體特性的估計。PDW 是每一個脈沖的…

TS語法最佳實踐

switch 的 case不能使用條件表達式JavaScript 允許在 switch 的 case 中使用條件表達式&#xff0c;但這種用法實際上是無效的&#xff0c;因為 case 的值會被隱式地轉換為布爾值。TypeScript 明確禁止這種用法&#xff0c;以避免隱式類型轉換導致的邏輯錯誤。建議使用 if-else…

行業熱點丨仿真歷史數據難以使用?如何利用幾何深度學習破局,加速汽車工程創新

01、AI 驅動研發升級&#xff1a;幾何深度學習創造行業新價值人工智能正加速推動各行業研發能力升級。麥肯錫最新報告顯示&#xff0c;該技術在制藥、化工和航空航天等領域的應用&#xff0c;有望為相關企業創造高達5600億美元的經濟價值。 AI 技術應用的先行者&#xff0c;全球…

JSBridge原理與實現全解析

JSBridge 是用于連接 JavaScript&#xff08;H5&#xff09; 和原生應用&#xff08;iOS/Android&#xff09;的橋梁&#xff0c;允許它們之間相互調用方法。 &#x1f309; 一、JSBridge 雙向通信流程圖 #mermaid-svg-AoDVdJL2VJBnTJ2Q {font-family:"trebuchet ms"…