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

相关推荐
岚天start21 分钟前
在K8S环境中,telnet nodePort端口是通的,但是 ss 获取不到端口号原因解析
iptables·kubernetes·k8s·telnet·ss
hzulwy3 小时前
docker与k8s的容器数据卷
docker·eureka·kubernetes
java叶新东老师3 小时前
k8s pod生命周期、初始化容器、钩子函数、容器探测、重启策略
云原生·容器·kubernetes
Lyndon11075 小时前
K8S 九 安全认证 TLS
安全·容器·kubernetes
东风微鸣6 小时前
提升效率:AI 知识库在软件开发中的应用
docker·云原生·kubernetes·可观察性
Lyndon11076 小时前
K8S 八 数据存储-高级存储PV PVC 生命周期;配置存储ConfigMap Secret
云原生·容器·kubernetes
虚伪的空想家7 小时前
记录es收集日志报错问题as the final mapping would have more than 1 type[XXX,doc]
大数据·elasticsearch·搜索引擎·容器·kubernetes·log-pilot
终端行者1 天前
k8s之Ingress服务接入控制器
云原生·容器·kubernetes
学Linux的语莫1 天前
k8s的nodeport和ingress
网络·rpc·kubernetes
aashuii1 天前
k8s通过NUMA亲和分配GPU和VF接口
云原生·容器·kubernetes