首页 > Web开发 > 详细

Kubernetes的Job对象

时间:2019-10-14 12:59:29      阅读:102      评论:0      收藏:0      [点我收藏+]

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

参数解释:

  • restartPolicy:为Never,因为我们的Pod永远不应该被重启.restartPolicy在Job对象里只允许被指定为Never和OnFailure,而在Deployment对象里,restartPolicy只允许被设置为Alway
  • backoffLimit: 作业失败后Job重新创建Pod的次数(如果restartPolicy指定为OnFailure,作业失败,不会尝试创建新的Pod)
  • activeDeadlineSeconds:最长运行的时间
  • parallelism: 同一时间最多可以启动Pod数量
  • completions: 至少要完成的Pod数量
    简单的说,可以通过设置parallelism控制并发数,通过completions控制任务执行的次数,通过activeDeadlineSeconds设置一个任务的最长运行时间

执行创建

kubectl apply -f job.yaml

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

Kubernetes的Job对象

原文:https://www.cnblogs.com/chenqionghe/p/11670224.html

(1)
(1)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!