本文介绍: 在 k8s 中周期性运行计划任务,与 linux 中的 crontab 相同注意点:CronJob 执行的时间是 controller-manager 的时间,所以一定要确保 controller-manager 时间是准确的。
在 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
原文地址:https://blog.csdn.net/weixin_45213266/article/details/135693012
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.7code.cn/show_58220.html
如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。