第五章 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 <none> 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,表示成功执行完成。

相关推荐
jcrose25802 小时前
分析用户请求K8S里ingress-nginx提供的ingress流量路径
nginx·容器·kubernetes
alden_ygq3 小时前
K8S运行时切换-从Docker到Containerd的切换实战
docker·容器·kubernetes
Linux运维老纪14 小时前
K8s 分布式存储后端(K8s Distributed Storage Backend)
服务器·分布式·云原生·容器·kubernetes·云计算·运维开发
Dusk_橙子16 小时前
在K8S中,有哪几种控制器类型?
云原生·容器·kubernetes
a_j582 天前
Kubernetes常见问答(一)
云原生·容器·kubernetes
bjackal2 天前
K8S学习笔记-------1.安装部署K8S集群环境
笔记·学习·kubernetes
Dusk_橙子2 天前
在K8S中,如何把某个worker节点设置为不可调度?
云原生·容器·kubernetes
Linux运维老纪3 天前
K8s之Service详解(Detailed Explanation of K8s Service)
服务器·网络·云原生·容器·kubernetes·云计算·运维开发
A ?Charis3 天前
ExternalName Service 针对的是k8s集群外部有api服务的场景?
kubernetes