返回顶部
首页 > 资讯 > 精选 >k8s中job与cronjob如何使用
  • 318
分享到

k8s中job与cronjob如何使用

2023-07-05 08:07:31 318人浏览 泡泡鱼
摘要

本篇内容介绍了“k8s中job与cronjob如何使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、前言job,顾名思义就是任务,job

本篇内容介绍了“k8s中job与cronjob如何使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

一、前言

job,顾名思义就是任务,job的概念在很多框架中都有,而且实际业务场景中也使用非常广泛,比如大家熟悉的hadoop,客户端可以向集群提交一个job,然后集群根据一定的调度策略来处理这个job;

k8s中的job,主要用于批量处理的业务场景,比如像那种短暂的一次性任务(每个任务仅运行一次就结束);

二、k8s中job特点

  • 当Job创建的pod执行成功结束时,Job将记录成功结束的pod数量;

  • 当成功结束的pod达到指定的数量时,Job将完成执行;

job与pod的关系如下图

k8s中job与cronjob如何使用

三、Job模板配置文件核心配置参数

如下为job的一个模板配置yaml文件中的部分核心配置参数

apiVersion: batch/v1 # 版本号kind: Job # 类型       metadata: # 元数据  name: # rs名称   namespace: # 命名空间   labels:     controller: jobspec:   completions: 6 # 指定job需要成功运行Pods的次数。默认值: 1  parallelism: 3 # 指定job在任一时刻应该并发运行Pods的数量。默认值: 1  ttlSecondsAfterFinished: 5  activeDeadlineSeconds: 30 # 指定job可运行的时间期限,超过时间还未结束,系统将会尝试进行终止。  backoffLimit: 5 # 指定job失败后进行重试的次数。默认是6  manualSelector: true # 是否可以使用selector选择器选择pod,默认是false  selector: # 选择器,通过它指定该控制器管理哪些pod    matchLabels:      # Labels匹配规则      app: counter-pod    matchExpressions: # Expressions匹配规则      - {key: app, operator: In, values: [counter-pod]}  template: # 模板,当副本数量不足时,会根据下面的模板创建pod副本    metadata:      labels:        app: counter-pod    spec:      restartPolicy: Never # 重启策略只能设置为Never或者OnFailure      containers:      - name: counter        image: busybox:1.30        command: ["bin/sh","-c","for i in 9 8 7 6 5 4 3 2 1; do echo $i;sleep 2;done"]

可以参照各个参数的备注加以理解,下面对其中部分参数做补充说明;

3.1 ttlSecondsAfterFinished

  • 当设置了ttlSecondsAfterFinished参数,job完成或者失败后都会在ttlSecondsAfterFinished所设置的时间后被清理;

  • 假设ttlSecondsAfterFinished 设置成30。在job完成或者失败后30s,job就会被自动清除,包括job和job所管理的pod都会被清除;

  • 假设没有设置,job和job所管理的pod会一直存在,不管是失败还是成功,不过好像有些k8s的版本ttlSecondsAfterFinished是不生效的,建议使用1.20以上的版本;

3.2 activeDeadlineSeconds

  • Job的超时时间,一旦一个Job运行的时间超出该限制,则Job失败,所有运行中的Pod会被结束并删除;

  • 该配置指定的值必须是个正整数,不指定则不会超时;

  • 但是经过实验,job pod并不会自动删除,所以如果希望超时后pod会自动删除还是设置一下ttlSecondsAfterFinished;

3.3 backoffLimit

  • 允许执行失败的次数,默认值是6,0表示不允许执行失败;

  • 如果Pod是restartPolicy为Nerver,则失败后会创建新的Pod,如果是OnFailed,则会重启Pod,不管是哪种情况,只要Pod失败一次就计算一次,而不是等整个Pod失败后再计算一个;

  • 当失败的次数达到该限制时,整个Job随即结束,所有正在运行中的Pod都会被删除;

  • 但是经过实验,jobpod并不会自动删除,所以如果希望超时后pod会自动删除还是设置一下ttlSecondsAfterFinished;

3.4 parallelism

并行运行的Pod的个数,默认值为1,假如设置为3,就会同时开启3个pod去执行任务

3.5 completions

  • 完成该Job需要执行成功的Pod数;

  • 指定需要完成的数量,默认值为1,假设设置为3,需要有三个pod成功完成任务,这个job才算是完成;

四、job案例操作演示

在当前目录下创建一个jod-pod.yaml文件,配置如下内容

apiVersion: batch/v1kind: Job      metadata:  name: test-job  namespace: defaultspec:  manualSelector: true  selector:    matchLabels:      app: counter-pod  template:    metadata:      labels:        app: counter-pod    spec:      restartPolicy: Never      containers:      - name: counter        image: busybox:1.30        command: ["bin/sh","-c","for i in 9 8 7 6 5 4 3 2 1; do echo $i;sleep 3;done"]

使用apply创建pod

k8s中job与cronjob如何使用

在另外的两个窗口,我们提前打开监控pod和job的执行情况,可以看到下面的完整执行过程;

从job的执行过程来看,经历了从无到有以及到最终的STATUS状态为Completed的过程,这个也和上文提到的job的生命周期描述吻合;

k8s中job与cronjob如何使用

k8s中job与cronjob如何使用

对于Pod的执行过程来看,从下面这张图可以清晰看到STATUS的各个阶段变化的完整过程;

k8s中job与cronjob如何使用

其他的模板中的参数可以直接往里面添加即可在job运行过程中看到效果,比如我们在该模板文件中补充两个参数;

k8s中job与cronjob如何使用

再次运行这个job,通过job和pod的监控信息,看到如下的效果;

k8s中job与cronjob如何使用

k8s中job与cronjob如何使用

五、cronjob 理论

CronJob其实就是在Job的基础上加上了时间调度,我们可以:在给定的时间点运行一个任务,也可以周期性地在给定时间点运行。这个实际上和我们linux中的crontab就非常类似了。

CronJob控制器以 Job控制器资源为其管控对象,并借助它管理pod资源对象,Job控制器定义的作业任务在其控制器资源创建之后便会立即执行,但CronJob可以以类似于Linux操作系统的周期性任务作业计划的方式控制其运行时间点重复运行的方式。也就是说,CronJob可以在特定的时间点(反复的)去运行job任务

cronjob 运行原理图

k8s中job与cronjob如何使用

六、cronjob 模板配置文件核心配置参数

如下为cronjob模板配置文件中核心参数;

apiVersion: batch/v1beta1 # 版本号kind: CronJob # 类型       metadata: # 元数据  name: # rs名称   namespace: # 命名空间   labels: #标签    controller: cronjobspec: # 详情描述  schedule: # cron格式的作业调度运行时间点,用于控制任务在什么时间执行  concurrencyPolicy: # 并发执行策略,用于定义前一次作业运行尚未完成时是否以及如何运行后一次的作业  failedJobHistoryLimit: # 为失败的任务执行保留的历史记录数,默认为1  successfulJobHistoryLimit: # 为成功的任务执行保留的历史记录数,默认为3  startingDeadlineSeconds: # 启动作业错误的超时时长  jobTemplate: # job控制器模板,用于为cronjob控制器生成job对象;下面其实就是job的定义    metadata:    spec:      completions: 1      parallelism: 1      activeDeadlineSeconds: 30      backoffLimit: 6      manualSelector: true      selector:        matchLabels:          app: counter-pod        matchExpressions: 规则          - {key: app, operator: In, values: [counter-pod]}      template:        metadata:          labels:            app: counter-pod        spec:          restartPolicy: Never           containers:          - name: counter            image: busybox:1.30            command: ["bin/sh","-c","for i in 9 8 7 6 5 4 3 2 1; do echo $i;sleep 20;done"]

关于配置文件中的补充参数说明

concurrencyPolicy

concurrencyPolicy 配置策略

  • Allow: 允许Jobs并发运行(默认);

  • Forbid: 禁止并发运行,如果上一次运行尚未完成,则跳过下一次运行;

  • Replace: 替换,取消当前正在运行的作业并用新作业替它;

Cron调度语法

注意K8S的定时任务仅支持5位,从minute开始


# ┌───────────── minute (0 - 59)
# │ ┌───────────── hour (0 - 23)
# │ │ ┌───────────── day of the month (1 - 31)
# │ │ │ ┌───────────── month (1 - 12)
# │ │ │ │ ┌───────────── day of the week (0 - 6) (Sunday to Saturday;
# │ │ │ │ │ 7 is also Sunday on some systems)
# │ │ │ │ │
# │ │ │ │ │
#* * * * *

七、cronjob 案例操作演示

在当前目录创建一个cron-job.yaml的配置文件,配置内容如下:

apiVersion: batch/v1beta1kind: CronJobmetadata:  name: test-cronjob  namespace: default  labels:    controller: cronjobspec:  schedule: "*/1 * * * *"  jobTemplate:    metadata:    spec:      template:        spec:          restartPolicy: Never          containers:          - name: counter            image: busybox:1.30            command: ["bin/sh","-c","for i in 9 8 7 6 5 4 3 2 1; do echo $i;sleep 3;done"]

使用apply(或create命令)创建cronjob

k8s中job与cronjob如何使用

通过开启其他客户端窗口,可以监控cronjob,job以及pod的运行过程中的状态;

cronjob的运行状态

上面的配置策略是每分钟执行,从下图的运行效果中也可以看出来;

k8s中job与cronjob如何使用

job的运行状态

k8s中job与cronjob如何使用

pod的运行状态

k8s中job与cronjob如何使用

cronjob使用场景

Cron 作业对于创建周期性和重复性任务很有用,例如运行备份或发送电子邮件。Cron 作业还可以将单个任务安排在特定时间,例如,你想将作业安排在业务低峰期执行。

“k8s中job与cronjob如何使用”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

--结束END--

本文标题: k8s中job与cronjob如何使用

本文链接: https://lsjlt.com/news/350765.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • k8s中job与cronjob如何使用
    本篇内容介绍了“k8s中job与cronjob如何使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、前言job,顾名思义就是任务,job...
    99+
    2023-07-05
  • k8s中job与cronjob使用实例详解
    目录一、前言二、k8s中job特点三、Job模板配置文件核心配置参数3.1 ttlSecondsAfterFinished3.2 activeDeadlineSeconds3.3 b...
    99+
    2023-03-06
    k8s job与cronjob使用 k8s job与cronjob
  • k8s Ingress如何使用
    本篇内容主要讲解“k8s Ingress如何使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“k8s Ingress如何使用”吧!一、什么是Ingress在上一篇关于k8s之...
    99+
    2023-07-05
  • Kubernetes中如何使用Rancher部署K8S集群
    本篇文章给大家分享的是有关Kubernetes中如何使用Rancher部署K8S集群,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。1.安装Rancher这里使用三台机器来搭建K...
    99+
    2023-06-19
  • k8s的imagePullSecrets如何生成及使用
    公司的docker仓库(harbor),是私有的,需要用户认证之后,才能拉取镜像。 登录docker登录到k8s master节点,先登录dockerroot@k8s-master:~# docker logi...
    99+
    2023-01-31
    k8s imagePullSecrets
  • Docker与K8s关系介绍不会Docker也可以使用K8s
    目录K8s和Docker 的关系容器用Docker,需要学到什么程度总结K8s和Docker 的关系 Docker 和 K8s 这两个经常一起出现,两者的Logo 看着也有一定联系一...
    99+
    2024-04-02
  • k8s数据存储之Volume如何使用
    这篇文章主要讲解了“k8s数据存储之Volume如何使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“k8s数据存储之Volume如何使用”吧!一、什么是Volume通过之前学习了解到,k8...
    99+
    2023-07-05
  • Docker中如何部署k8s
    这篇文章主要介绍Docker中如何部署k8s,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!拓扑结构1master + 2minionk8s-master 192.168.0.201 masterk8s-node1 1...
    99+
    2023-06-07
  • k8s Job执行一次性及批处理任务使用的场景是什么
    这篇文章主要介绍“k8s Job执行一次性及批处理任务使用的场景是什么”,在日常操作中,相信很多人在k8s Job执行一次性及批处理任务使用的场景是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对...
    99+
    2023-07-05
  • k8s中的secret怎么使用
    这篇文章主要讲解了“k8s中的secret怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“k8s中的secret怎么使用”吧!secret可以加密用户名和密码文件,将其打包成一个sec...
    99+
    2023-07-06
  • k8s与docker空间使用分析与清理方法
    目录1. 前言2. 常见问题场景3. docker 磁盘空间使用分析及处理3.1 image镜像占用分析及解决3.2 json.log占用分析及解决3.3 Local Volumne...
    99+
    2022-12-29
    k8s 与docker空间使用 k8s 与docker空间使用 k8s docker空间
  • k8s如何查看pod资源使用情况
    要查看Kubernetes中Pod的资源使用情况,可以使用以下几种方法: kubectl top pod: 使用kubectl t...
    99+
    2024-04-02
  • k8s中kubeconfig怎么配置使用
    这篇文章主要讲解了“k8s中kubeconfig怎么配置使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“k8s中kubeconfig怎么配置使用”吧!1、概述kubeconfig文件保存了...
    99+
    2023-06-26
  • 如何利用K8S技术进行K8S资源控制
    如何利用K8S技术进行K8S资源控制,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。私有云K8S资源控制原理基于前面系列文章的详细阐述,我们已经可以手工去K8S集群的命令行下将C...
    99+
    2023-06-19
  • 如何利用k8s与gitlab来实现自动化部署
    随着互联网行业的日益发展,软件开发变得越来越复杂。如何快速、高效、可靠地完成软件部署成为了开发者们需要解决的重要问题。而自动化部署正是这样一种解决方案,对于加快软件上线速度、提高部署质量有着不可替代的作用。本文将介绍如何利用k8s与gitl...
    99+
    2023-10-22
  • k8s如何使用emptyDir,hostPath,nfs,pv,pvc做存储
    本篇文章为大家展示了k8s如何使用emptyDir,hostPath,nfs,pv,pvc做存储,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。存储卷三种方式:emptyDir,gitRepo,hos...
    99+
    2023-06-04
  • k8s中如何部署springboot项目
    在k8s中部署Spring Boot项目通常可以通过以下几个步骤完成: 创建Docker镜像:首先,将你的Spring Boot...
    99+
    2024-04-02
  • k8s中如何部署redis集群
    在Kubernetes中部署Redis集群通常可以通过以下步骤进行: 创建Redis的ConfigMap:在Kubernetes中...
    99+
    2024-04-09
    redis
  • k8s中如何部署mysql集群
    在Kubernetes中部署MySQL集群可以使用StatefulSet和PersistentVolume。以下是一个简单的步骤: ...
    99+
    2024-04-02
  • k8s资源管理命令与Namespace使用详解
    目录 一、前言 二、k8s概述 三、k8s常用操作管理命令 3.1 kubectl 命令用法 3.2 常用控制台管理命来源地址:https://blog.csdn.net/zhangcongyi420/article/details/128...
    99+
    2023-09-10
    k8s 操作命令使用 k8s 资源管理命令总结 k8s namespace使用 k8s namespace k8s资源命令总结
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作