在 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