【云原生】Job一次性任务详解

Job一次性任务

文章目录

一、Job介绍

  • Job会创建一个或者多个Pod,并将继续重试Pod的执行,直到指定数量的Pod成功终止。随着Pod成功借宿,Job跟踪记录成功完成的Pod个数。当数量达到指定的成功个数阈值时,任务(即Job)结束。删除Job的操作会清除所有创建的全部Pod。挂起Job的操作会删除Job的所有活跃的Pod,直到Job被再次恢复执行。

  • 一种简单的使用场景下,你会创建一个Job对象以便以以一种可靠的方式运行某Pod直到完成。当第一个Pod失败或者被删除(比如因为节点硬件失效或者重启)时,Job对象对启动一个新的Pod。

  • 当然你也可以使用Job以并行的方式运行多个Pod。

二、运行示例Job

  • 下面是一个Job配置示例。并将运行结果打印出来,此计算大约需要10秒钟完成。
bash 复制代码
# 注意:Job的重启策略只有两种分别是Never和OnFailure,不支持Always,我们执行Job就相当于执行一个批处理任务,执行完成就结束了,如果支持Always的话就会陷入死循环
[root@master ~]# vim job.yaml
apiVersion: "batch/v1"
kind: Job
metadata:
  name: job
spec:
  template:
    spec:
      containers:
      - name: job
        image: busybox:latest
        imagePullPolicy: IfNotPresent
        # 容器内部运行的命令
        command: ["bin/sh","-c","for i in 9 8 7 6 5 4 3 2 1; do echo $i;sleep 1;done"]
      restartPolicy: Never
  # 设置重试次数,如果Job运行失败,就会尝试重启4次
  backoffLimit: 4
bash 复制代码
# 应用资源清单
[root@master ~]# kubectl apply -f job.yaml
  • 查看Job运行状态过程
bash 复制代码
# 你可以提前执行该命令
# 可以看出Job根据我们规定的执行命令,运行10秒自动退出
# Completed表示完成的意思
[root@master ~]# kubectl get pod --watch
NAME        READY   STATUS    RESTARTS   AGE
job-jw22g   0/1     Pending   0          0s
job-jw22g   0/1     Pending   0          0s
job-jw22g   0/1     ContainerCreating   0          0s
job-jw22g   1/1     Running             0          1s
job-jw22g   0/1     Completed           0          11s
  • 查看Job容器内部运行情况
bash 复制代码
[root@master ~]# kubectl logs job-jw22g 
9
8
7
6
5
4
3
2
1
相关推荐
周杰伦_Jay2 小时前
详细介绍:云原生技术细节(关键组成部分、优势和挑战、常用云原生工具)
java·云原生·容器·架构·kubernetes·jenkins·devops
元气满满的热码式2 小时前
K8S中Pod控制器之DaemonSet(DS)控制器
云原生·容器·kubernetes
昵称难产中2 小时前
浅谈云计算21 | Docker容器技术
docker·容器·云计算
夏子曦2 小时前
k8s 蓝绿发布、滚动发布、灰度发布
云原生·容器·kubernetes
ShareBeHappy_Qin3 小时前
ZooKeeper 中的 ZAB 一致性协议与 Zookeeper 设计目的、使用场景、相关概念(数据模型、myid、事务 ID、版本、监听器、ACL、角色)
分布式·zookeeper·云原生
颜淡慕潇7 小时前
【K8S系列】在 K8S 中使用 Values 文件定制不同环境下的应用配置
云原生·容器·kubernetes·环境配置
来恩100314 小时前
Kubernetes学习指南与资料分享
云原生·容器·kubernetes
weixin_3875456417 小时前
探索云原生可观测性:技术与团队协作的深度结合
云原生
sci_ei12319 小时前
高水平EI会议-第四届机器学习、云计算与智能挖掘国际会议
数据结构·人工智能·算法·机器学习·数据挖掘·机器人·云计算
向阳121820 小时前
doris:阿里云 OSS 导入数据
数据库·阿里云·云计算·doris