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

server/2025/1/23 0:22:38/

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/server/160598.html

相关文章

MindAgent:基于大型语言模型的多智能体协作基础设施

2023-09-18 &#xff0c;加州大学洛杉矶分校&#xff08;UCLA&#xff09;、微软研究院、斯坦福大学等机构共同创建的新型基础设施&#xff0c;目的在评估大型语言模型在游戏互动中的规划和协调能力。MindAgent通过CuisineWorld这一新的游戏场景和相关基准&#xff0c;调度多智…

在 vscode + cmake + GNU 工具链的基础上配置 JLINK

安装 JLINK JLINK 官网链接 下载安装后找到安装路径下的可执行文件 将此路径添加到环境变量的 Path 中。 创建 JFlash 项目 打开 JFlash&#xff0c;选择新建项目 选择单片机型号 在弹出的窗口中搜索单片机 其他参数根据实际情况填写 新建完成&#xff1a; 接下来设置…

STM32 FreeRTOS中断管理

目录 FreeRTOS的中断管理 1、STM32中断优先级管理 2、FreeRTOS任务优先级管理 3、寄存器和内存映射寄存器 4、BASEPRI寄存器 5、FreeRTOS与STM32中断管理结合使用 vPortRaiseBASEPRI vPortSetBASEPRI 6、FromISR后缀 7、在中断服务函数中调用FreeRTOS的API函数需注意 F…

电脑如何访问手机文件?

手机和电脑已经深深融入了我们的日常生活&#xff0c;无时无刻不在为我们提供服务。除了电脑远程操控电脑外&#xff0c;我们还可以在电脑上轻松地访问Android或iPhone手机上的文件。那么&#xff0c;如何使用电脑远程访问手机上的文件呢&#xff1f; 如何使用电脑访问手机文件…

Android 11适配全攻略:从理论到实践

随着Google正式发布Android 11&#xff0c;开发者们迎来了新的挑战和机遇。Android 11不仅带来了全新的用户体验和功能提升&#xff0c;还要求开发者们对应用进行相应的适配&#xff0c;以确保应用的兼容性和稳定性。本文将从理论到实践&#xff0c;全面解析Android 11的适配攻…

【Java】阿里云OSS上传、删除文件

阿里云OSS上传、删除文件 编写AliOssConfig&#xff1a; import lombok.Data;/*** <p>DESC: </p>* <p>VERSION:1.0.0</p>*/ Data public class AliOssConfig {private String endpoint;private String accessKey;private String accessSecret;private…

开发常用工具

在项目开发中&#xff0c;工具的使用起到了至关重要的作用&#xff0c;正所谓工欲善其事&#xff0c;必先利其器&#xff0c;掌握一些实用的开发工具能够使我们的开发效率事半功倍。 那么我们应该掌握哪些开发工具的使用方法呢&#xff1f;其实一路走来&#xff0c;我们已经介…

【Go】Go Gin框架初识(一)

1. 什么是Gin框架 Gin框架&#xff1a;是一个由 Golang 语言开发的 web 框架&#xff0c;能够极大提高开发 web 应用的效率&#xff01; 1.1 什么是web框架 web框架体系图&#xff08;前后端不分离&#xff09;如下图所示&#xff1a; 从上图中我们可以发现一个Web框架最重要…