Kubernetes 1.21如何引入Indexed Jobs特性

发布时间:2021-12-24 13:46:45 作者:小新
来源:亿速云 阅读:160

这篇文章主要为大家展示了“Kubernetes 1.21如何引入Indexed Jobs特性”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Kubernetes 1.21如何引入Indexed Jobs特性”这篇文章吧。

一旦你将一个非并行作业(Job)容器化,就很容易在 Kubernetes 上启动并运行它,而无需修改二进制文件。在大多数情况下,当运行并行分布式作业时,你必须设置一个单独的系统来在工作资源之间划分工作。例如,你可以设置一个任务队列,将一个工作项分配给每个 Pod[2],或将多个项分配给每个 Pod,直到队列清空为止[3]

Kubernetes 1.21 版本引入了一个新的字段来控制作业完成模式,这是一个配置选项,允许你控制 Pod 完成如何影响作业的总体进度,有两个可能的选项(目前):

你可以开始使用带有索引完成模式的作业,简称为索引作业(Indexed Jobs),来轻松启动并行作业。然后,每个 worker Pod 可以根据索引有一个静态分配的数据分区。这使你不必设置排队系统,甚至不必修改二进制文件!

 

创建索引作业

要创建一个索引作业,你只需添加 completionMode: Indexed 到作业规范中,并使用 JOB_COMPLETION_INDEX 环境变量。

apiVersion: batch/v1
kind: Job
metadata:
  name: 'sample-job'
spec:
  completions: 3
  parallelism: 3
  completionMode: Indexed
  template:
    spec:
      restartPolicy: Never
      containers:
      - command:
        - 'bash'
        - '-c'
        - 'echo "My partition: ${JOB_COMPLETION_INDEX}"'
        image: 'docker.io/library/bash'
        name: 'sample-load'
 

注意,完成模式是 1.21 版本中的一个 alpha 特性。为了能够在集群中使用它,请确保在 API 服务器和控制器管理器上启用了 IndexedJob 特性门。

当你运行该示例时,你将看到三个创建的 Pods 中的每一个都获得了不同的完成索引。为了方便用户,控制平面设置 JOB_COMPLETION_INDEX 环境变量,但是你可以选择设置自己的或将索引暴露为文件。

计划

SIG Apps 设想可能有更多的完成模式,为 Job API 启用更多的用例。我们欢迎你在kubernetes/kubernetes[5]中提出你的建议。

特别是,我们正在考虑一种 IndexedAndUnique 模式,其中索引不仅作为注释可用,而且是 Pod 名称的一部分,类似于 StatefulSet。这应该有助于紧密耦合的 Pod 之间的通信。你可以参加这个公开问题[6]的讨论。

总结

索引作业(Indexed Jobs)允许你在并行作业的作业之间静态地划分作业。SIG Apps 希望这个特性能够促进更多的批量工作负载迁移到 Kubernetes。

以上是“Kubernetes 1.21如何引入Indexed Jobs特性”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!

推荐阅读:
  1. Kubernetes 再升级,安全和稳定性是1.12版最大亮点
  2. Kubernetes1.4版本的新功能是什么

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

kubernetes

上一篇:Kubernetes的探针有什么用

下一篇:linux中如何删除用户组

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》