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配置指南」「自动化工作流」,建议在相关技术社区和博客平台发布时保留标题结构。

相关推荐
绝无仅有14 小时前
远景集团面试后端Java岗位问答与总结汇总
后端·面试·github
爱吃烤鸡翅的酸菜鱼14 小时前
深度掌握 Git 分支体系:从基础操作到高级策略与实践案例
分布式·git·后端·gitee·github
CoderJia程序员甲1 天前
GitHub 热榜项目 - 日榜(2025-10-07)
ai·github·开源项目·github热榜
CoderJia程序员甲1 天前
GitHub 热榜项目 - 日榜(2025-10-04)
ai·开源·大模型·github·ai教程
小黄酥1 天前
Sourcetree克隆/获取gitee工程,Git获取SSH密钥
git·gitee·github
wdfk_prog1 天前
构建基于Hexo、Butterfly、GitHub与Cloudflare的高性能个人博客
笔记·学习·github·hexo·blog
JinSo1 天前
alien-signals 系列 —— 认识下一代响应式框架
前端·javascript·github
freedom_1024_1 天前
解决GitHub大文件推送错误:彻底清理PDB文件并配置.gitignore
git·github
是垚不是土2 天前
Prometheus接入“飞书“实现自动化告警
运维·安全·自动化·github·飞书·prometheus
绝无仅有2 天前
消息队列mq面试经典问题与解答总结
后端·面试·github