k8s学习(十三)创建CronJob
目录前言一、CronJob二、使用步骤1.引入库2.读入数据总结前言。一、CronJob二、使用步骤1.引入库代码如下(示例):import numpy as npimport pandas as pdimport matplotlib.pyplot as pltimport seaborn as snsimport warningswarnings.filterwarnings('ignore'
前言
CronJob是k8s里的定时任务,可以周期性执行 Job。
所有 CronJob 的 schedule 时间都是基于 kube-controller-manager 的时区。
一、CronJob
1、Cron 表达式语法
┌───────────── 分钟 (0 - 59)
│ ┌───────────── 小时 (0 - 23)
│ │ ┌───────────── 月的某天 (1 - 31)
│ │ │ ┌───────────── 月份 (1 - 12)
│ │ │ │ ┌───────────── 周的某天 (0 - 6) (周日到周一;在某些系统上,7 也是星期日)
│ │ │ │ │
│ │ │ │ │
│ │ │ │ │
2、CronJob Spec:
.spec.schedule指定任务运行周期,格式同Cron
.spec.jobTemplate指定需要运行的任务,格式同Job
.spec.startingDeadlineSeconds指定任务开始的截止期限
.spec.concurrencyPolicy指定任务的并发策略,支持Allow、Forbid和Replace三个选项
二、创建CronJob
1、cronjob.yaml
[root@k8s-master k8s]# cat cronjob.yaml
apiVersion: batch/v1beta1
kind: CronJob
metadata:
name: cronjob-test
spec:
schedule: "*/1 * * * *"
jobTemplate:
spec:
template:
spec:
containers:
- name: busybox-container
image: busybox
args:
- /bin/sh
- -c
- date; echo "hello cron-job"
restartPolicy: onFailure
2、创建
[root@k8s-master k8s]# kubectl create -f cronjob.yaml
cronjob.batch/cronjob-test created
3、查看cronjob
[root@k8s-master k8s]# kubectl get cronjob
NAME SCHEDULE SUSPEND ACTIVE LAST SCHEDULE AGE
cronjob-test */1 * * * * False 0 <none> 25s
4、查看pod
[root@k8s-master k8s]# kubectl get pods | grep cronjob
cronjob-test-1640615340-f4gff 0/1 Completed 0 2m57s
cronjob-test-1640615400-6h5gz 0/1 Completed 0 116s
cronjob-test-1640615460-xdslh 0/1 Completed 0 56s
cronjob-test-1640615520-dqnxg 0/1 ContainerCreating 0 5s
5、查看pod日志
[root@k8s-master k8s]# kubectl logs cronjob-test-1640615160-s77l2
Mon Dec 27 14:26:13 UTC 2021
hello cron-job
6、删除cronjob
[root@k8s-master k8s]# kubectl delete cronjob cronjob-test
cronjob.batch "cronjob-test" deleted
更多推荐
所有评论(0)