Kubernetes 的 CronJob 是一种用于定期执行任务的控制器,类似于 Linux 系统中的 cron 定时任务。它可以在指定的时间点自动创建 Job 资源,从而运行一次性 Pod 来完成诸如备份、清理、数据同步等周期性操作。
如何使用 CronJob 调度定期任务
CronJob 通过 cron 表达式定义调度时间,格式为:分钟 小时 日 月 星期。例如 0 2 * * * 表示每天凌晨 2 点执行一次。
要创建一个定期任务,需编写一个 YAML 配置文件定义 CronJob。以下是一个每天执行一次备份任务的例子:
apiVersion: batch/v1
kind: CronJob
metadata:
name: daily-backup
spec:
schedule: "0 2 * * *" # 每天 2:00 执行
jobTemplate:
spec:
template:
spec:
containers:
- name: backup-tool
image: alpine:latest
command:
- /bin/sh
- -c
- echo "Running backup at $(date)"; sync-data-to-storage
restartPolicy: OnFailure
关键配置说明
schedule:必填字段,遵循标准 cron 格式,支持 *、/、- 等符号 jobTemplate:定义每次触发时要运行的 Job 和 Pod 模板 startingDeadlineSeconds:可选,设置任务最多允许延迟多少秒才被视为失败 concurrencyPolicy:控制并发行为,可设为 Allow(允许并发)、Forbid(禁止并发)或 Replace(替换前一个) successfulJobsHistoryLimit 和 failedJobsHistoryLimit:控制保留多少个成功和失败的历史记录常见使用场景
每日数据库备份 定时日志清理 周期性健康检查或报告生成 定时拉取外部数据同步到集群可以通过 kubectl apply -f cronjob.yaml 创建任务,用 kubectl get cronjobs 查看状态,所有由 CronJob 创建的 Job 和 Pod 都会自动带上相关标签,便于追踪。
基本上就这些。只要写对 cron 表达式并定义好容器行为,CronJob 就能可靠地运行你的周期性任务。注意避免高频率调度(如每分钟多次),以免产生大量 Job 影响控制平面性能。
