k8s 实践经验(八)job && CronJob

文章目录


  • ​​Job​​
    • ​​Job的资源清单文件:​​
    • ​​创建pc-job.yaml,内容如下:​​
    • ​​CronJob(CJ)​​
    • ​​CronJob的资源清单文件:​​

    Job

    Job,主要用于负责**批量处理(一次要处理指定数量任务)短暂的一次性(每个任务仅运行一次就结束)**任重启之极海听雷务。Job特点如下:

    当Job创建的pod执行成功结束时,Job将记录成功结束的pod数量
    当成功结束的pod达到指定的数量时,Job将完成执行

    k8s 实践经验(八)job && CronJob

    Job的资源清单文件:

    apiVersion: batch/v1 # 版本号
    kind: Job # 类型
    metadata: # 元数据
    name: # rs名称
    namespace: # 所属命名空间
    labels: #标签
    controller: job
    spec: # 详情描述
    completions: 1 # 指定job需要成功运行Pods的次数。默认值: 1
    parallelism: 1 # 指定job在任一时刻应该并发运行Pods的数量。默认值: 1
    activeDeadlineSeconds: 30 # 指定job可运行的时间期限,超过时间还未结束,系统将会尝试进行终止。
    backoffLimit: 6 # 指定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"]
    • .spec.template.spec.restartPolicy属性拥有三个候选值:OnFkubernetes联邦集群ailure,Never和Always。默认值为云计算Always。它主要用于描述Pod内容器的重启策略。在Job中只能将此属性设置为OnFailure或Never。云计算定义如果.spec.template.spec.restarkubernetestPolicy = OnFailure,如果Pod内某个容器的exit code不为0,那么Pod就会在其内部重启这个容器。.spec.template.重启末世spec.restartPolicy = Never,那么Pod内某个容器exit code不为0时,就不会触发容器的重启
    • .spec.backof云计算导论fLimit用于设置Job的容错次数,默认值为6。当Job运行的Po云原生是什么意思d失败次数到达.spec.backoffLimit次时,Jo云原生技术b Controller不再新建Pod,直接停止运行这个Job,将其运行结果标记为Failure。另外,Pod运容器苗行失败后再次运行的时间间隔呈递增状态,例如10s,20s,40s。。。
    • .spec.act云原生是什么iveDea原力计划dlineSeconds属性用容器苗于设置Job运行的超时时间。如果Job运行的时间超过了设定的秒数,那么此Job就自动停止运行所有的Pod,并将Job退出状态标记为reason:DeadlineExceeded。
    • ttlSecondsAfterFinished

      1.12版本之后,k8s提出了通过TTL自动删除Job的特性,当前仅对job生效,对 Complete 和 Failed 状态的Job都会自动删除,以后会逐步对所有的其他资源对象生效。

      Job pi-with-ttl 的 ttlSecondsAfterFinished 值为 100,则,重启全盛时代在其结束 100 秒云计算是什么之后,将可以被自动删除云计算概念股

      如果 ttlSecondsAfterFinished 被设置为 0,则 TTL 控制云计算是什么意思器在 Job 执行结束后,立重启激荡年代刻就可以清理该 Job 及其 Pod

      云原生是什么意思果 ttlSecondsAfterFinished 值未设置,则 TTL 控制器不会清理该 Job

    创建pc-job.yaml容器是什么内容如下:

    apiVersion: batch/v1
    kind: Job
    metadata:
    name: pc-job
    namespace: dev
    spec:
    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"]

    跟其他控制器不同的是,Job 对象并不要求你定义一个 spec.selecto重启超级空域顾言r 来描述要控制哪些 Pod。

    Job 对容器苗象在创建后,它的 Pod 模板,云计算是什么意思被自动加上了一个 controller-uid=云原生加速器< 一个随机字符串 > 这样的 Label。而这个 Job 对象本身,则被自动加上了这个kubernetes是什么 Label 对应的 Selector,从而云原生是什么 保证了 Job 与它所管理的 Pod 之间的匹配关系。

    而 Job Controller 之所以要使用这种携带了 UID 的 Label,就是为了避免不容器英文同 Job 对象所管理的 Pod 发生重合。需要注意的是kubernetes与docker的关系,这种自动生成的 Label 对用户来说并不友好,所以不太适合推广到 Deployment 等长作kubernetes是什么意思业编排对象上。


    Cron云原生下载Job(CJ)

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

    k8s 实践经验(八)job && CronJob

    Cro云计算导论nJob的资源清单文件:

    apiVersion: batch/v1beta1 # 版本号
    kind: CronJob # 类型
    metadata: # 元数据
    name: # rs名称
    namespace: # 所属命名空间
    labels: #标签
    controller: cronjob
    spec: # 详情描述
    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"]

    需要重点解释的几个选项:

    schedule: cron表达式,用于指定任务的执行时间

    (这里的 schedule cron 表达式和别的地方不一样,这里是五位数)

    */1    *      *    *     *
    <分钟> <小时> <日> <月份> <星期>
    分钟 值从 0 到 59.
    小时 值从 0 到 23.
    日 值从 1 到 31.
    月 值从 1 到 12.
    星期 值从 0 到 6, 0 代表星期日
    多个时间可以用逗号隔开; 范围可以用连字符给出;*可以作为通配符; /表示每...

    concurrencyP容器是什么olicy:

    • Allow: 允许Jobs并云计算分为哪些类型发运行(默认)
    • Forbid: 禁止并发运行,如果上一次运行尚未完成,则跳过下一次运行
    • Replace: 替换,取消当前正在运行的作云计算最简单解释业并用新作业替换它

    创建pc-cronjob.yaml,内容如下:

    apiVersion: batch/v1beta1
    kind: CronJob
    metadata:
    name: pc-cronjob
    namespace: dev
    labels:
    controller: cronjob
    spec:
    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"]