k8s术语之CronJob

CronJob管理基于时间的Job,即:

        在给定时间点只运行一次

        周期性地在给定时间点运行

一个CronJob对象类似于crontab文件中的一行。它根据指定的预定计划周期地运行一个Job,格式可以参考Cron

前提条件

        当前使用地Kubernetes集群,版本>=1.8.对于先前版本地集群,版本<1.8,启动API Server(参考 为集群开启或关闭 API 版本 获取更多信息)时,通过传递选项 --runtime-config=batch/v2alpha1=true 可以开启 batch/v2alpha1 API。

        典型地用法如下所示:

                在给定的时间点调度Job运行

                创建周期性运行的Job,例如:数据库备份、发送邮件

CronJob Spec

        .spec.schedule:调度,必需字段,指定任务运行周期,格式同Cron

        .spec.jobTemplate:Job模板,必需字段,直到需要运行的任务,格式同Job

        .spec.startingDeadlineSeconds :启动 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。

                默认情况下,它们分别设置为 3 和 1。设置限制的值为 0,相关类型的 Job 完成后将不会被保留。

你可能感兴趣的:(kubernetes,容器,云原生)