跳转至

任务参数说明

根据 .spec.completions.spec.Parallelism 的设置,可以将任务(Job)划分为以下几种类型:

Job 类型 说明
非并行 Job 创建一个 Pod 直至其 Job 成功结束
具有确定完成计数的并行 Job 当成功的 Pod 个数达到 .spec.completions 时,Job 被视为完成
并行 Job 创建一个或多个 Pod 直至有一个成功结束

参数说明

RestartPolicy 创建一个 Pod 直至其成功结束
.spec.completions 表示 Job 结束需要成功运行的 Pod 个数,默认为 1
.spec.parallelism 表示并行运行的 Pod 的个数,默认为 1
spec.backoffLimit 表示失败 Pod 的重试最大次数,超过这个次数不会继续重试。
.spec.activeDeadlineSeconds 表示 Pod 运行时间,一旦达到这个时间,Job 即其所有的 Pod 都会停止。且 activeDeadlineSeconds 优先级高于 backoffLimit,即到达 activeDeadlineSeconds 的 Job 会忽略backoffLimit 的设置。

以下是一个 Job 配置示例,保存在 myjob.yaml 中,其计算 π 到 2000 位并打印输出。

apiVersion: batch/v1
kind: Job            #当前资源的类型
metadata:
  name: myjob
spec:
  completions: 50        # Job结束需要运行50个Pod,这个示例中就是打印π 50次
  parallelism: 5        # 并行5个Pod
  backoffLimit: 5        # 最多重试5次
  template:
    spec:
      containers:
      - name: pi
        image: perl
        command: ["perl",  "-Mbignum=bpi", "-wle", "print bpi(2000)"]
      restartPolicy: Never #重启策略

相关命令

kubectl apply -f myjob.yaml  #启动 job
kubectl get job #查看这个job
kubectl logs myjob-1122dswzs 查看Job Pod 的日志