k8s-高级调度-CronJob 计划任务

在 k8s 中周期性运行计划任务,与 linux 中的 crontab 相同
注意点:CronJob 执行的时间是 controller-manager 的时间,所以一定要确保 controller-manager 时间是准确的

一、cron 表达式

# ┌───────────── 分钟 (0 - 59)
# │ ┌───────────── 小时 (0 - 23)
# │ │ ┌───────────── 月的某天 (1 - 31)
# │ │ │ ┌───────────── 月份 (1 - 12)
# │ │ │ │ ┌───────────── 周的某天 (0 - 6)(周日到周一;在某些系统上,7 也是星期日)
# │ │ │ │ │                          或者是 sun,mon,tue,web,thu,fri,sat
# │ │ │ │ │
# │ │ │ │ │
# * * * * *

二、使用 Kubernetes 的 CronJob 定时任务

1.创建 CronJob

首先,创建一个名为 cron-job.yaml 的 YAML 文件,定义您的 CronJob:

[root@k8s-master jobs]# vi cron-job.yaml
apiVersion: batch/v1
kind: CronJob #定时任务
metadata:
  name: cron-job-test #定时任务名字
spec:
  concurrencyPolicy: Allow # 并发调度策略:Allow 允许并发调度,Forbid:不允许并发执行,Replace:如果之前的任务还没执行完,就直接执行新的,放弃上一个任务
  failedJobsHistoryLimit: 1 # 保留多少个失败的任务
  successfulJobsHistoryLimit: 3 # 保留多少个成功的任务
  suspend: false # 是否挂起任务,若为 true 则该任务不会执行
#  startingDeadlineSeconds: 30 # 间隔多长时间检测失败的任务并重新执行,时间不能小于 10
  schedule: "* * * * *" # 调度策略 每分钟执行一次
  jobTemplate:
    spec:
      template:
        spec:
          containers:
          - name: busybox
            image: busybox:1.28
            imagePullPolicy: IfNotPresent
            command:
            - /bin/sh
            - -c
            - date; echo Hello from the Kubernetes cluster
          restartPolicy: OnFailure


应用该配置文件:

#创建CronJob
[root@k8s-master jobs]# kubectl apply -f  cron-job.yaml
cronjob.batch/cron-job-test created

2.查看任务列表

查看创建的 CronJob 和相关的任务:

#获取任务列表
[root@k8s-master jobs]#  kubectl get cronjob
NAME            SCHEDULE    SUSPEND   ACTIVE   LAST SCHEDULE   AGE
cron-job-test   * * * * *   False     0        17s             52s

[root@k8s-master jobs]# kubectl get po
NAME                           READY   STATUS      RESTARTS       AGE
cron-job-test-28421783-w4qms   0/1     Completed   0              54s

3.查看任务日志

[root@k8s-master jobs]# kubectl logs -f cron-job-test-28421783-w4qms
Mon Jan 15 08:23:00 UTC 2024
Hello from the Kubernetes cluster

4.删除 CronJob

当任务完成后,您可以删除 CronJob:


[root@k8s-master jobs]# kubectl delete cronjob cron-job-test
cronjob.batch "cron-job-test" deleted


你可能感兴趣的:(k8s,kubernetes,容器,云原生)