前言

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
Logo

K8S/Kubernetes社区为您提供最前沿的新闻资讯和知识内容

更多推荐