首页 > 运维 > linux运维 > 正文

【赵渝强老师】Job控制器多工作队列的并行方式

雪夜
发布: 2025-06-26 09:22:12
原创
521人浏览过

kubernetes job控制器用于管理一次性任务。它确保pod中的容器执行完任务后不会重新启动,并将容器状态设为“completed”。如果容器意外终止,job控制器会根据重启策略重新启动pod。遇到node节点故障时,job控制器会通过调度器将pod重新调度到其他节点。job控制器有两种运行模式:单工作队列的串行方式和多工作队列的并行方式。

视频讲解如下:

接下来通过一个具体示例展示如何使用Job控制器的多工作队列并行方式。在创建多工作队列的Job并行方式时,需要指定两个关键参数:

  • .spec.parallelism:并行执行的Pod数量,即队列数量。
  • .spec.completions:需要完成的总任务数量。

在下面的例子中,总任务数量为5个,创建了3个队列,即并行度为3。整个任务执行需要2分钟。

(1)创建名为“job-demo2.yaml”的文件,并输入以下内容:

apiVersion: batch/v1
kind: Job
metadata:
  name: job-demo2
spec:
  completions: 5
  parallelism: 3
  template:
    spec:
      containers:
      - name: job-demo2
        image: nginx
        imagePullPolicy: IfNotPresent
        # 模拟任务执行60秒
        command: ["/bin/bash","-c","sleep 60"]
      # 重启策略,不进行重启
      restartPolicy: Never
登录后复制

(2)执行以下命令创建Job:

kubectl apply -f job-demo2.yaml
登录后复制

(3)查看Job和Pod信息,如下图所示:

kubectl get job,pod
# 注意:由于总任务数量为5个,但并行执行的队列数量为3,因此这里只看到Job控制器启动了3个Pod。
登录后复制

【赵渝强老师】Job控制器多工作队列的并行方式

(4)等待60秒后,再次查看Job和Pod信息,如下图所示:

kubectl get job,pod
# 注意:60秒后,第一批3个任务已完成,Job控制器又启动了2个队列来执行剩余的两个任务。
登录后复制

【赵渝强老师】Job控制器多工作队列的并行方式

(5)再等待60秒后,再次查看Job和Pod信息,如下图所示:

kubectl get job,pod
# 注意:经过120秒后,5个任务全部成功执行完成。
登录后复制

【赵渝强老师】Job控制器多工作队列的并行方式

【赵渝强老师】Job控制器多工作队列的并行方式

以上就是【赵渝强老师】Job控制器多工作队列的并行方式的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
相关标签:
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号