CronJob

    CronJob 创建基于时隔重复调度的 Jobs

    一个 CronJob 对象就像 crontab (cron table) 文件中的一行。 它用 格式进行编写, 并周期性地在给定的调度时间执行 Job。

    Caution:

    所有 CronJobschedule: 时间都是基于 kube-controller-manager. 的时区。

    如果你的控制平面在 Pod 或是裸容器中运行了 kube-controller-manager, 那么为该容器所设置的时区将会决定 Cron Job 的控制器所使用的时区。

    Caution:

    如 所述,官方并不支持设置时区。

    Kubernetes 项目官方并不支持设置如 CRON_TZ 或者 TZ 等变量。 CRON_TZ 或者 TZ 是用于解析和计算下一个 Job 创建时间所使用的内部库中一个实现细节。 不建议在生产集群中使用它。

    CronJob 用于执行周期性的动作,例如备份、报告生成等。 这些任务中的每一个都应该配置为周期性重复的(例如:每天/每周/每月一次); 你可以定义任务开始执行的时间间隔。

    下面的 CronJob 示例清单会在每分钟打印出当前时间和问候消息:

    application/job/cronjob.yaml

    一文会为你详细讲解此例。

    Cron 时间表语法

    例如,下面这行指出必须在每个星期五的午夜以及每个月 13 号的午夜开始任务:

    0 0 13 * 5

    要生成 CronJob 时间表表达式,你还可以使用 之类的 Web 工具。

    CronJob 根据其计划编排,在每次该执行任务的时候大约会创建一个 Job。 我们之所以说 “大约”,是因为在某些情况下,可能会创建两个 Job,或者不会创建任何 Job。 我们试图使这些情况尽量少发生,但不能完全杜绝。因此,Job 应该是 幂等的

    Caution:

    如果 的设置值低于 10 秒钟,CronJob 可能无法被调度。 这是因为 CronJob 控制器每 10 秒钟执行一次检查。

    对于每个 CronJob,CronJob 控制器(Controller) 检查从上一次调度的时间点到现在所错过了调度次数。如果错过的调度次数超过 100 次, 那么它就不会启动这个任务,并记录这个错误:

    需要注意的是,如果 startingDeadlineSeconds 字段非空,则控制器会统计从 startingDeadlineSeconds 设置的值到现在而不是从上一个计划时间到现在错过了多少次 Job。 例如,如果 startingDeadlineSeconds200,则控制器会统计在过去 200 秒中错过了多少次 Job。

    如果未能在调度时间内创建 CronJob,则计为错过。 例如,如果 concurrencyPolicy 被设置为 Forbid,并且当前有一个调度仍在运行的情况下, 试图调度的 CronJob 将被计算为错过。

    例如,假设一个 CronJob 被设置为从 08:30:00 开始每隔一分钟创建一个新的 Job, 并且它的 startingDeadlineSeconds 字段未被设置。如果 CronJob 控制器从 08:29:00 到 终止运行,则该 Job 将不会启动,因为其错过的调度 次数超过了 100。

    为了进一步阐述这个概念,假设将 CronJob 设置为从 08:30:00 开始每隔一分钟创建一个新的 Job, 并将其 startingDeadlineSeconds 字段设置为 200 秒。 如果 CronJob 控制器恰好在与上一个示例相同的时间段(08:29:0010:21:00)终止运行, 则 Job 仍将从 10:22:00 开始。 造成这种情况的原因是控制器现在检查在最近 200 秒(即 3 个错过的调度)中发生了多少次错过的 Job 调度,而不是从现在为止的最后一个调度时间开始。

    CronJob 仅负责创建与其调度时间相匹配的 Job,而 Job 又负责管理其代表的 Pod。

    • 了解 CronJob 所依赖的 与 Job 的概念。
    • 有关创建和使用 CronJob 的说明及示例规约文件,请参见 。
    • 有关自动清理失败或完成作业的说明,请参阅自动清理作业
    • CronJob 是 Kubernetes REST API 的一部分, 阅读 对象定义以了解关于该资源的 API。

    最后修改 March 23, 2022 at 6:15 PM PST: [zh] Update cron-jobs and delete repeat context (bd6b45c44)