其他分享
首页 > 其他分享> > Kubenetes的Job对象

Kubenetes的Job对象

作者:互联网

Deployment、StatefulSet及DaemonSet三个主要用来进行长时间业务,不会退出。
而有一些离线业务,或者叫Batch Job(计算业务),计算完成后就直接退出 了,如果用Deployment来管理这种业务,Pod会在计算结束后退出,然后被Deployment Controller不断地重启,
而我们的任务不需要一直被执行,Job对象主要就是针对这种离线跑任务场景

示例

apiVersion: batch/v1
kind: Job
metadata:
  name: pi
spec:
  parallelism: 2
  completions: 4
  template:
    spec:
      containers:
      - name: pi
        image: resouer/ubuntu-bc 
        command: ["sh", "-c", "echo 'scale=10000; 4*a(1)' | bc -l "]
      restartPolicy: Never
      activeDeadlineSeconds: 100
  backoffLimit: 4

参数解释:

执行创建

kubectl apply -f job.yaml

创建后会看到po状态,由ContainerCreating->Running->Completed,如果有失败情况还会出现DeadlineExceeded状态

标签:completions,对象,restartPolicy,activeDeadlineSeconds,Job,Kubenetes,Deployment,Pod
来源: https://www.cnblogs.com/chenqionghe/p/11670224.html