在 k8s 中周期性运行计划任务,与 linux 中的 crontab 相同
注意点:CronJob 执行的时间是 controller-manager 的时间,所以一定要确保 controller-manager 时间是准确的
# ┌───────────── 分钟 (0 - 59)
# │ ┌───────────── 小时 (0 - 23)
# │ │ ┌───────────── 月的某天 (1 - 31)
# │ │ │ ┌───────────── 月份 (1 - 12)
# │ │ │ │ ┌───────────── 周的某天 (0 - 6)(周日到周一;在某些系统上,7 也是星期日)
# │ │ │ │ │ 或者是 sun,mon,tue,web,thu,fri,sat
# │ │ │ │ │
# │ │ │ │ │
# * * * * *
首先,创建一个名为 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
查看创建的 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
[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
当任务完成后,您可以删除 CronJob:
[root@k8s-master jobs]# kubectl delete cronjob cron-job-test
cronjob.batch "cron-job-test" deleted