GitHub Actions定时任务配置完全指南:从Cron语法到实战示例

你好,我是悦创。

博客网站:https://blog.bornforthis.cn/

本教程将详细讲解如何在GitHub Actions中配置定时任务(Scheduled Tasks),帮助你掌握 Cron 表达式的编写规则和实际应用场景。

一、定时任务基础配置

1.1 核心语法结构

yaml 复制代码
on:
  schedule:
    - cron: "分 时 日 月 周"

1.2 参数解析

组件 取值范围 说明
0-59 分钟
0-23 小时(UTC时间)
1-31 月份中的日期
1-12 或 JAN-DEC 月份
0-6 或 SUN-SAT 星期(0=周日)

二、Cron表达式详解

2.1 特殊字符说明

符号 示例 作用
* * * * * * 任意值
, 0,30 * * * * 多个值
- 0-5 * * * * 范围值
/ */15 * * * * 间隔值

2.2 常用配置模板

yaml 复制代码
on:
  schedule:
    # 每5分钟(GitHub最小间隔)
    - cron: "*/5 * * * *"
    
    # 每日UTC时间0点
    - cron: "0 0 * * *"
    
    # 每周一北京时间上午8点
    - cron: "0 0 * * 1"
      timezone: Asia/Shanghai
    
    # 每月1号正午执行
    - cron: "0 12 1 * *"

三、高级配置技巧

3.1 时区设置

yaml 复制代码
- cron: "0 8 * * *"
  timezone: Asia/Shanghai  # 支持IANA时区数据库格式

3.2 分支过滤

yaml 复制代码
on:
  schedule:
    - cron: "0 0 * * *"
  branches:  # 限定触发的分支
    - main
    - release/*

3.3 多任务配置

yaml 复制代码
on:
  schedule:
    - cron: "0 9 * * 1-5"   # 工作日早9点
    - cron: "0 18 * * 1-5"  # 工作日晚6点
    - cron: "0 12 * * 0"    # 周日中午12点

四、注意事项

  1. 执行延迟:GitHub Actions的定时任务可能有1-10分钟的延迟
  2. 频率限制
    • 公共仓库:每月2000分钟免费额度
    • 私有仓库:每月500分钟免费额度
  3. 日志查看 :执行记录可在仓库的 Actions 标签页查看
  4. 表达式验证 :推荐使用 crontab.guru 调试表达式

五、实战应用场景

5.1 自动化测试

yaml 复制代码
name: Daily Test
on:
  schedule:
    - cron: "0 0 * * *"
jobs:
  test:
    runs-on: ubuntu-latest
    steps:
      - run: npm test

5.2 数据备份

yaml 复制代码
name: Weekly Backup
on:
  schedule:
    - cron: "0 3 * * 6"  # 每周六凌晨3点
jobs:
  backup:
    runs-on: ubuntu-latest
    steps:
      - name: Backup database
        run: ./scripts/backup.sh

5.3 定时通知

yaml 复制代码
name: Morning Reminder
on:
  schedule:
    - cron: "0 9 * * 1-5"  # 工作日早9点
jobs:
  notify:
    runs-on: ubuntu-latest
    steps:
      - uses: actions-slack@v3
        with:
          payload: |
            {
              "text": "每日站会时间到!"
            }

SEO优化提示:本文包含高频搜索关键词「GitHub Actions定时任务」「Cron配置指南」「自动化工作流」,建议在相关技术社区和博客平台发布时保留标题结构。

相关推荐
我是一只代码狗7 小时前
idea中使用git
git·gitee·github
产品经理独孤虾9 小时前
GitHub Copilot:产品经理提升工作效率的AI助手
github·copilot·产品经理·原型设计·ai工具·效率提升·prd
杜莱10 小时前
IDEA 安装AI代码助手GitHub Copilot和简单使用体验
人工智能·github·intellij-idea
LogicFlow12 小时前
对单调的画布说拜拜👋🏻
前端框架·开源·github
強云14 小时前
使用 SSH 连接 GitHub
ssh·github
这里有鱼汤14 小时前
🚀逆天神器来了!MCP Chrome:超越Playwright,让AI接管你的浏览器,我当场震撼!
github·mcp
独立开阀者_FwtCoder14 小时前
前端开发的你,其实并没有真的掌握img标签!
前端·vue.js·github
草梅友仁1 天前
手机号注册登录功能开发 | 2025 年第 28 周草梅周报
开源·github·ai编程
Xi-Xu1 天前
隆重介绍 Xget for Chrome:您的终极下载加速器
前端·网络·chrome·经验分享·github