Cron Job管理基于时间的Job,即

    • 在给定时间只运行一次
    • 周期性的再给定时间运行

    在特定时间循环创建Job

    典型的用法如下:

    • 在给定时间点调度Job运行
    • 创建周期运行的Job,列如:数据库备份、发送邮件

    特殊说明:

    • spec.template格式同Pod
    • RestartPolicy仅支持Never或OnFailure
    • 单个Pod时,默认Pod成功运行后Job即结束
    • .spec.completions标志Job结束需要成功运行的Pod个数,默认为1
    • .spec.parallelism标志并行运行的Pod的个数,默认为1
    • .spec.activeDeadlineSeconds标志失败Pod的重试最大时间,超过这个时间不会继续重试

    CronJob Spec

    • .spec.schedule:调度,必需字段,指定任务运行周期,格式同Cron
    • .spec.jobTemplate : Job模板,必需字段,指定需要运行的任务,格式同Job
    • .spec.startingDeadlineSecomls︰启动Job的期限(秒级别),该字段是可选的。如果因为任何原因而错过了被调度的时间,那么错过执行时间的Job将被认为是失败的。如果没有指定,则没有期限
    • .spec.concurrencyPolicy:并发策略,该字段也是可选的。它指定了如何处理被cron Job创建的Job的并发执行。只允许指定下面策略中的一种:

      • Allow(默认):允许并发运行Job
      • Forbid:禁止并发运行,如果前一个还没有完成,则直接跳过下一个
      • Replace:取消当前正在运行的Job,用一个新的来替换

        注意,当前策略只能应用于同一个Cron Job创建的Job。如果存在多个Cron Job,它们创建的Job 之间总是允许并发运行。

    • .spec.suspend:挂起,该字段也是可选的。如果设置为true,后续所有执行都会被挂起。它对已经开始执行的Job不起作用。默认值为false

    • .spec.successfulJobsHistoryLimit.spec.failedJobsHistoryLimit:历史保留限制,是可选的字段。它们指定了可以保留多少完成和失败的Job。默认情况下,它们分别设置为31。设置限制的值为0,相关类型的Job完成后将不会被保留。

    CronJob的yaml例子:
    image.png

    CronJob创建Job应该是幂等的