K8S中Pod控制器之CronJob(CJ)控制器

embedded/2025/1/22 12:02:03/

CronJob 控制器是 Kubernetes 中用于周期性执行任务的一种控制器,它基于 Job 控制器来创建和管理作业。以下是 CronJob 的一些关键特点:

  • 周期性调度CronJob 允许您定义一个基于时间的调度,类似于 Linux 的 cron 工具,来周期性地执行任务。

  • 时间点触发CronJob 根据指定的时间表(cron 表达式)触发,可以精确到分钟。

  • 一次性或重复执行:尽管 CronJob 主要用于重复性任务,但它也可以配置为仅执行一次。

  • 立即执行:如果需要,可以在创建 CronJob 之后立即启动第一个作业。

  • 并行性控制:可以设置 CronJob 的并行性策略,决定是否允许多个 Job 实例并行运行,或者在新实例启动前完成上一个实例。

  • 成功和失败处理CronJob 可以配置成功和失败的工作节(job history limit)限制,以控制保留成功和失败的 Job 记录的数量。

  • 暂停和恢复CronJob 支持暂停和恢复功能,允许您临时停止或恢复周期性任务的执行。

  • 时区处理CronJob 允许您指定时区,以确保任务在特定地理区域的特定时间执行。

  • 灵活的 cron 表达式:支持复杂的 cron 表达式,以满足不同的时间调度需求。

CronJob的资源清单

---
apiVersion: batch/v1beta1 # 版本号
kind: CronJob # 类型
metadata: # 元数据name: # rs名称namespace: # 所属命名空间labels: # 标签controller: cronjob
spec: # 详情描述schedule: # cron格式的作业调度运行时间点,用于控制任务在什么时间执行concurrencyPolicy: # 并发执行策略,用于定义前一次作业运行尚未完成时是否以及如何运行后一次的作业failedJobHistoryLimit: # 为失败的任务执行保留的历史记录数,默认为1successfulJobHistoryLimit: # 为成功的任务执行保留的历史记录数,默认为3startingDeadlineSeconds: # 启动作业错误的超时时长jobTemplate: # job控制器模板,用于为cronjob控制器生成job对象;下面其实就是job的定义spec:completions: 1parallelism: 1activeDeadlineSeconds: 30backoffLimit: 6manualSelector: truetemplate:metadata:labels:app: counter-podspec:restartPolicy: Nevercontainers:- name: counterimage: busybox:1.30command: ["bin/sh", "-c", "for i in 9 8 7 6 5 4 3 2 1; do echo $i; sleep 20; done"]

schedule

schedule 是一个 cron 表达式,用于定义 CronJob 的执行计划。cron 表达式由五个字段组成,分别表示分钟、小时、日期(一个月中的哪一天)、月份和星期几。每个字段可以包含以下几种类型的值:

  • 具体值:例如 115

  • 逗号分隔的多个值:例如 1,15 表示第 1 分钟和第 15 分钟。

  • 范围:使用连字符 - 表示,例如 1-3 表示从第 1 分钟到第 3 分钟。

  • 通配符:使用星号 * 表示匹配任意值。

  • 步长:使用斜杠 / 表示,例如 */15 表示从 0 开始每 15 分钟。

cron 表达式的字段含义如下:

  • 分钟:0 到 59

  • 小时:0 到 23

  • 日期:1 到 31

  • 月份:1 到 12 或 JAN 到 DEC

  • 星期:0 到 6(0 表示星期天)或 SUN 到 SAT

 测试:

---
apiVersion: batch/v1
kind: CronJob
metadata:name: pc-cronjobnamespace: test
spec:schedule: "*/1 * * * *"jobTemplate:spec:template:spec:restartPolicy: Nevercontainers:- name: counterimage: busybox:1.30command: ["bin/sh", "-c", "for i in 9 8 7 6 5 4 3 2 1; do echo $i; sleep 3; done"]
  • 查看cronjob:

cronjob每分钟执行一次,当job执行时会启动一个pod,pod启动完成job结束当前任务

[root@k8s-master ~]# kubectl get cronjob -n test -w 
NAME         SCHEDULE      SUSPEND   ACTIVE   LAST SCHEDULE   AGE
pc-cronjob   */1 * * * *   False     0        <none>          0s
pc-cronjob   */1 * * * *   False     1        0s              38s
kubectl get job -n test -w
pc-cronjob   */1 * * * *   False     0        30s             68s
pc-cronjob   */1 * * * *   False     1        0s              98s
pc-cronjob   */1 * * * *   False     0        30s             2m8s
  • 查看job:
[root@k8s-master ~]# kubectl get job -n test -wNAME                  COMPLETIONS   DURATION   AGE
pc-cronjob-28956119   0/1           20s        20s
pc-cronjob-28956119   1/1           30s        30s
pc-cronjob-28956120   0/1                      0s
pc-cronjob-28956120   0/1           0s         0s
pc-cronjob-28956120   1/1           30s        30s
  • 查看pod:

可以看的pod创建之后,会结束当前任务,等待一分钟之后再次启动pod

^C[root@k8s-master ~]# kubectl get pods -n test -w
NAME                 READY   STATUS    RESTARTS   AGE
pc-daemonset-9vwvd   1/1     Running   0          52m
pc-daemonset-drdt5   1/1     Running   0          52m
pc-cronjob-28956119-n7cxf   0/1     Pending   0          0s
pc-cronjob-28956119-n7cxf   0/1     Pending   0          0s
pc-cronjob-28956119-n7cxf   0/1     ContainerCreating   0          0s
pc-cronjob-28956119-n7cxf   0/1     ContainerCreating   0          2s
pc-cronjob-28956119-n7cxf   1/1     Running             0          2s
pc-cronjob-28956119-n7cxf   0/1     Completed           0          30s
pc-cronjob-28956119-n7cxf   0/1     Completed           0          30s
pc-cronjob-28956120-4q5sv   0/1     Pending             0          0s
pc-cronjob-28956120-4q5sv   0/1     Pending             0          0s
pc-cronjob-28956120-4q5sv   0/1     ContainerCreating   0          0s
pc-cronjob-28956120-4q5sv   0/1     ContainerCreating   0          1s
pc-cronjob-28956120-4q5sv   1/1     Running             0          2s
pc-cronjob-28956120-4q5sv   0/1     Completed           0          30s
pc-cronjob-28956120-4q5sv   0/1     Completed           0          30s


http://www.ppmy.cn/embedded/156045.html

相关文章

人工智能在数字化转型中的角色:从数据分析到智能决策

引言 在数字化转型浪潮中&#xff0c;人工智能&#xff08;AI&#xff09;正迅速崛起&#xff0c;成为推动企业创新和变革的关键力量。面对日益复杂的市场环境和激烈的行业竞争&#xff0c;企业亟需借助技术手段提高运营效率、优化决策过程&#xff0c;并增强市场竞争力。而AI…

代码随想录_字符串

字符串 344.反转字符串 344. 反转字符串 编写一个函数&#xff0c;其作用是将输入的字符串反转过来。输入字符串以字符数组 s 的形式给出。 不要给另外的数组分配额外的空间&#xff0c;你必须**原地修改输入数组**、使用 O(1) 的额外空间解决这一问题。 思路: 双指针 代…

分布式系统通信解决方案:Netty 与 Protobuf 高效应用

分布式系统通信解决方案&#xff1a;Netty 与 Protobuf 高效应用 一、引言 在现代网络编程中&#xff0c;数据的编解码是系统设计的一个核心问题&#xff0c;特别是在高并发和低延迟的应用场景中&#xff0c;如何高效地序列化和传输数据对于系统的性能至关重要。随着分布式系…

玉米植物结构受乙烯生物合成基因 ZmACS7 的调控

摘要&#xff1a; 植物高度和叶片角度是玉米&#xff08;Zea mays&#xff09;植物结构的两个关键决定因素&#xff0c;与高种植密度下的抗倒伏性和冠层光合作用密切相关。这两个性状主要由几种植物激素调节。然而&#xff0c;乙烯在调节玉米植物结构中的机制&#xff0c;特别…

excel实用工具

持续更新… 文章目录 1. 快捷键1.1 求和 2. 命令2.1 查找 vloopup 1. 快捷键 1.1 求和 windows: alt mac : command shift T 2. 命令 2.1 查找 vloopup vlookup 四个入参数 要查找的内容 &#xff08;A2 6xx1&#xff09;查找的备选集 &#xff08;C2:C19&#xff09;…

【K8S系列】在 K8S 中使用 Values 文件定制不同环境下的应用配置

写在前面 因为有小伙伴问这个问题&#xff0c;因此用这篇文章详细讲解一下&#xff1a;在k8s中怎么实现通过使用Values文件&#xff0c;定制不同环境&#xff08;开发、测试、预发、生产&#xff09;下的应用配置的问题。 希望对你有所帮助~ 一、基础介绍 &#xff08;一&…

VSCode+EIDE 环境搭建

一、安装插件 请在魔法的情况下&#xff0c;去下载安装该插件。 二、配置 导入一个例程。 编译器选择 AC5或者AC6&#xff0c;当然AC5需要你自己去整&#xff0c;具体可以参照这篇文章Keil5 MDK安装Compiler Version5&#xff08;即ARM Compiler 5&#xff0c;简称AC5&#x…

【科研建模】Pycaret自动机器学习框架使用流程及多分类项目实战案例详解

Pycaret自动机器学习框架使用流程及项目实战案例详解 1 Pycaret介绍2 安装及版本需求3 Pycaret自动机器学习框架使用流程3.1 Setup3.2 Compare Models3.3 Analyze Model3.4 Prediction3.5 Save Model4 多分类项目实战案例详解4.1 ✅ Setup4.2 ✅ Compare Models4.3 ✅ Experime…