第五章 Kubernetes Pod控制器-Cronjob

一、CronJob特性

CronJob是基于时间的Job控制器,简单理解就是CronJob控制器会依赖Job控制器,基于Job控制器之上增加了时间方面的约束。所以CronJob是周期性的执行Job控制器,Job控制器跑Pod的方式来完成周期性任务的。

CronJob有些特性如下:

以上特性,对其中某些做些说明:

1、spec.schedule:这个跟linux里面的corntab类似,采用 [* * * * * job命令] 方式。5个*分别代表了分时日月周。

2、spce.concurrencyPolicy:并发策略。并发策略需要根据你实际业务情况进行设定。其中:

  • Allow(默认):允许并发允许Job,比如当你的任务在周期时刻被调度的时候,上一次跑的任务都还没有结束,那么Allow就是允许本次被调度运行,与前一次的任务可以并行的。
  • Forbid:禁止并发运行。如果前一次调度的任务还没有完成,本次调度的任务就会跳过,不会执行本次调度任务。
  • Replace:在本次调度时刻,如果上次调度的任务还在运行中,那么就会取消正在运行的Job,用一个新的Job来替换。

3、spec.suspend:挂起。将后续所有任务都挂起,对已经开始执行的Job不起作用。比如临时业务情况有变化,比如周期性备份数据库任务需要暂停,这时候可以设置suspend为ture。

4、spec.successfulJobsHistoryLimit和spec.failedJobsHistoryLimit:成功的job和失败的job的历史记录限制条数。假如我们有一个是每分钟要执行的任务,那么一个月一年下来,我们创建的Job控制器的记录都会保留在etcd中,记录太多了,没必要记录这么多,因为对于我们使用者来说关注的是当前最新几个pod的情况是否正常,所以系统默认分别设置了'3'和'1'。

二、CronJob实操

1、创建CronJob控制器

vim 12.cronjob.yaml

复制代码
apiVersion: batch/v1
kind: CronJob
metadata:
  name: cronjob-demo
spec:
  schedule: "*/1 * * * *"
  jobTemplate:
    spec:
      completions: 3
      template:
        spec:
          containers:
          - name: cronjob-demo-container
            image: nginx:v1
            args:
            - /bin/sh
            - -c
            - date; echo Hello from the Kubernetes cluster
          restartPolicy: OnFailure

root@k8s-master01 5\]# kubectl apply -f 12.cronjob.yaml cronjob.batch/cronjob-demo created \[root@k8s-master01 5\]# kubectl get cronjob NAME SCHEDULE SUSPEND ACTIVE LAST SCHEDULE AGE cronjob-demo \*/1 \* \* \* \* False 0 \ 24s * SCHEDULE:调度周期。这里是1分钟调度一次。 * SUSPEND:是否为挂起 * ACTIVE:激活数量 * LAST SCHEDULE:最后一次调度距离现在的时长 * AGE:Cronjob资源对象创建的时长 注意:cronjob资源对象创建之后,第一次调度运行任务,并不会是严格在1分钟后执行,可能是1分钟前也可能是1分钟后,这个时间不定。如果你对于这个第一次调度的时间有一个很明确的要求,那么就需要在pod内部进行判断,在cronjob这个级别是做不到这个控制的。 ### 2、查看Job/Pod资源对象情况 \[root@k8s-master01 5\]# kubectl get job NAME COMPLETIONS DURATION AGE cronjob-demo-28971561 3/3 10s 2m50s cronjob-demo-28971562 3/3 9s 110s cronjob-demo-28971563 3/3 9s 50s 验证结果:发现已经有3个Job创建并已经完成了。根据上章节Job控制器讲的,每个Job控制器中,COMPLETIONS是3/3,说明我们要求3个pod成功完成,目前已经有3个pod完成了。 \[root@k8s-master01 5\]# kubectl get pod NAME READY STATUS RESTARTS AGE cronjob-demo-28971561-26l5q 0/1 Completed 0 2m14s cronjob-demo-28971561-965tb 0/1 Completed 0 2m11s cronjob-demo-28971561-ppspp 0/1 Completed 0 2m7s cronjob-demo-28971562-2km7d 0/1 Completed 0 74s cronjob-demo-28971562-kwzm4 0/1 Completed 0 68s cronjob-demo-28971562-pvk8w 0/1 Completed 0 71s cronjob-demo-28971563-h4zvb 0/1 Completed 0 8s cronjob-demo-28971563-jqkxg 0/1 Completed 0 14s cronjob-demo-28971563-xdxtk 0/1 Completed 0 11s 验证结果:通过pod可以看到,每个Job下产生了3个pod,比如cronjob-demo-28971561这个job产生了cronjob-demo-28971561-26l5q、cronjob-demo-28971561-965tb、cronjob-demo-28971561-ppspp三个pod,并且STATUS都是Completed,表示成功执行完成。

相关推荐
项目題供诗3 小时前
黑马k8s(九)
云原生·容器·kubernetes
wjy6_8 小时前
Rocky Linux 9.5 基于kubeadm部署k8s
linux·运维·kubernetes
oceanweave16 小时前
【K8S学习之生命周期钩子】详细了解 postStart 和 preStop 生命周期钩子
学习·kubernetes
gnufre1 天前
Kubernetes 1.28 无 Docker 运行时环境下的容器化构建实践:Kaniko + Jenkins 全链路详解
kubernetes·jenkins·kaniko
川石教育1 天前
测试工程师如何学会Kubernetes(k8s)容器知识
云原生·容器·kubernetes·kubernetes容器·kubernetes教程
iRayCheung1 天前
Kind方式部署k8s单节点集群并创建nginx服务对外访问
nginx·kubernetes·kind
小黑_深呼吸1 天前
Prometheus实战教程:k8s平台-Mysql监控案例
运维·学习·kubernetes·prometheus
富士康质检员张全蛋1 天前
云原生|kubernetes|kubernetes的etcd集群备份策略
云原生·kubernetes·etcd
慧一居士1 天前
Kubernetes 中kind类型和各类型详细配置完整示例介绍
云原生·kubernetes·yaml配置
水淹萌龙2 天前
k8s 中使用 Service 访问时NetworkPolicy不生效问题排查
云原生·容器·kubernetes