📘 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"…