当前位置: 首页 > backend >正文

github actions入门指南

GitHub Actions 是 GitHub 提供的持续集成和持续交付(CI/CD)平台,允许开发者自动化软件工作流程(如构建、测试、部署)。以下是详细介绍:


一、核心概念

  1. Workflow(工作流程)
    持续集成的一次完整运行过程,由 YAML 文件定义,存储在仓库的 .github/workflows 目录中。每个文件对应一个独立的工作流。

  2. Job(任务)
    一个 Workflow 包含多个 Job,每个 Job 在独立的运行器(虚拟机/容器)中执行。Job 默认并行执行,但可通过 needs 定义依赖顺序。

  3. Step(步骤)
    每个 Job 由多个 Step 组成,按顺序执行。每个 Step 可以是 Shell 命令或预定义的 Action

  4. Action(动作)
    可复用的脚本单元,可直接引用他人共享的 Action(如 actions/checkout@v3)。GitHub 官方维护了丰富的 Action 库 GitHub Marketplace。


二、配置文件结构

name: CI Workflow  # 工作流名称
on: [push]         # 触发事件(如 push、pull_request、定时任务 schedule)
jobs:build:runs-on: ubuntu-latest  # 运行环境(Ubuntu、Windows、macOS)steps:- name: Checkout codeuses: actions/checkout@v4  # 使用预定义 Action 拉取代码- name: Install dependenciesrun: npm install           # 执行 Shell 命令- name: Run testsrun: npm test

三、核心功能

  1. 事件触发

    • 代码推送(push)、拉取请求(pull_request)、定时任务(schedule)等均可触发工作流。
    • 示例:每天 8 点自动运行
      on:schedule:- cron: '0 0 * * *'  # UTC 时间,对应北京时间 8 点
      
  2. 多环境支持
    支持运行在 GitHub 托管的虚拟机(如 ubuntu-latest)或自托管运行器,并可指定容器环境 。

  3. 密钥管理与安全
    使用 secrets 存储敏感信息(如 API Key),避免硬编码在配置文件中。例如部署时引用密钥:

    env:API_KEY: ${{ secrets.DEPLOY_KEY }}
    
  4. 自动化部署
    常见场景:自动构建静态站点并发布到 GitHub Pages ,或部署到云服务(AWS、Azure)。


四、典型使用场景

  1. 持续集成(CI)
    自动运行测试、代码风格检查,确保代码质量。

  2. 持续部署(CD)
    代码合并到主分支后,自动部署到生产环境。

  3. 定时任务
    如每日数据备份、爬虫任务 。

  4. 跨平台构建
    同时编译 Windows、Linux、macOS 版本的程序。


五、优势

  • 高度集成:与 GitHub 仓库无缝协作,无需额外配置。
  • 灵活复用:通过共享 Action 减少重复代码 。
  • 低成本:公开仓库免费使用 GitHub 托管的运行器 。

六、快速入门示例

  1. 在仓库中创建 .github/workflows/demo.yml
  2. 写入以下内容(当代码推送到 main 分支时输出 “Hello World”):
name: Demo
on:push:branches: [main]
jobs:greet:runs-on: ubuntu-lateststeps:- run: echo "Hello GitHub Actions!"

参考资料

  • GitHub Actions 入门教程(阮一峰)
  • 使用 GitHub Actions 自动部署 Hugo
  • GitHub 官方快速入门指南
  • 部署到云服务案例
http://www.xdnf.cn/news/9545.html

相关文章:

  • .NET 9正式发布,亮点是.NET Aspire和AI
  • Linux `vi/vim` 编辑器深度解析与高阶应用指南
  • Golang | 搜索哨兵-对接分布式gRPC服务
  • vue修改配置文件.env.development不生效
  • 2025-05-28 学习记录--Python-文件
  • 对象检测新纪元:D-FINE 模型超越 YOLO,带来更精准的实时检测!
  • 6.2 Q1|哈尔滨医科大学GBD发文 | 1990 年至 2019 年颗粒物污染导致的中风全球趋势和负担
  • Python后端开发实战:从0到1搭建高可用API服务
  • 医疗器械企业批记录数字化转型实操指南
  • LeetCode hot100-6
  • C# 基于 Windows 系统与 Visual Studio 2017 的 Messenger 消息传递机制详解:发布-订阅模式实现
  • Python 包管理工具 uv的一些常用指令
  • AWS 创建VPC 并且添加权限控制
  • CloudCompare——点云统计滤波
  • element ui 表格 勾选复选框后点击分页不保存之前的数据问题
  • Service Worker介绍及应用(实现Web Push机制)
  • 【AI学习笔记】Coze平台实现生成小红书热门多图笔记
  • Metasploit工具使用详解(上)丨小白WEB安全入门笔记
  • 电子电路:什么是C类放大器?
  • ⚡️ Linux 系统安装与配置 Git
  • Windows SMB压缩在低速或者高延迟环境可以帮助提供性能增益
  • Linux驱动学习笔记(十)
  • vue-04(深入了解 props:验证、类型和默认值)
  • Django实现文件上传
  • Docker-compose 编排lnmp(dockerfile) 完成Wordpress
  • [ERR] switch_core_session.c:2697 Invalid Application callcenter
  • 基于 HTTP 的邮件认证深入解读 ngx_mail_auth_http_module
  • bug: uniCloud 查询数组字段失败
  • # 使用 Selenium 爬取苏宁易购优质评价
  • 针对C语言的开发工具推荐及分析(涵盖编辑器、集成开发环境(IDE)、编译器、调试工具及辅助工具)