博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
kubernetes视频教程笔记 (17)-Job和CronJob
阅读量:2037 次
发布时间:2019-04-28

本文共 2433 字,大约阅读时间需要 8 分钟。

一、Job

Job 负责批处理任务,即仅执行一次的任务,它保证批处理任务的一个或多个 Pod 成功结束

特殊说明

  • spec.template格式同Pod
  • RestartPolicy仅支持Never或OnFailure
  • 单个Pod时,默认Pod成功运行后Job即结束
  • .spec.completions 标志Job结束需要成功运行的Pod个数,默认为1
  • .spec.parallelism 标志并行运行的Pod的个数,默认为1
  • spec.activeDeadlineSeconds 标志失败Pod的重试最大时间,超过这个时间不会继续重试
  •  

 

apiVersion: batch/v1kind: Jobmetadata: name: pispec: template:  metadata:   name: pi  spec:   containers:   - name: pi     image: perl     command: ["perl", "-Mbignum=bpi", "-wle", "print bpi(2000)"]   restartPolicy: Never

 

 

node1和node2都得安装镜像

 

 

 

失败很多次了,所以删掉重新开始

 

 

 

 

 

 

 

 

 

 

 

二、CronJob Spec

  • spec.template格式同Pod
  • RestartPolicy仅支持Never或OnFailure
  • 单个Pod时,默认Pod成功运行后Job即结束
  • .spec.completions 标志Job结束需要成功运行的Pod个数,默认为1
  • .spec.parallelism 标志并行运行的Pod的个数,默认为1
  • spec.activeDeadlineSeconds 标志失败Pod的重试最大时间,超过这个时间不会继续重试

 

 

 

 

 

三、CronJob

Cron Job 管理基于时间的 Job,即:

  • 在给定时间点只运行一次
  • 周期性地在给定时间点运行

 

使用条件:当前使用的 Kubernetes 集群,版本 >= 1.8(对 CronJob)

 

典型的用法如下所示:

  • 在给定的时间点调度 Job 运行
  • 创建周期性运行的 Job,例如:数据库备份、发送邮件

 

四、CronJob Spec

  • .spec.schedule :调度,必需字段,指定任务运行周期,格式同 Cron
  • .spec.jobTemplate :Job 模板,必需字段,指定需要运行的任务,格式同 Job
  • .spec.startingDeadlineSeconds :启动 Job 的期限(秒级别),该字段是可选的。如果因为任何原因而错 过了被调度的时间,那么错过执行时间的 Job 将被认为是失败的。如果没有指定,则没有期限
  • .spec.concurrencyPolicy :并发策略,该字段也是可选的。它指定了如何处理被 Cron Job 创建的 Job 的 并发执行。只允许指定下面策略中的一种: Allow (默认):允许并发运行 Job ;Forbid :禁止并发运行,如果前一个还没有完成,则直接跳过下一个 ;Replace :取消当前正在运行的 Job,用一个新的来替换 注意,当前策略只能应用于同一个 Cron Job 创建的 Job。如果存在多个 Cron Job,它们创建的 Job 之间总 是允许并发运行。
  • .spec.suspend :挂起,该字段也是可选的。如果设置为 true ,后续所有执行都会被挂起。它对已经开始 执行的 Job 不起作用。默认值为 false 。
  • .spec.successfulJobsHistoryLimit 和 .spec.failedJobsHistoryLimit :历史限制,是可选的字段。它 们指定了可以保留多少完成和失败的 Job。默认情况下,它们分别设置为 3 和 1 。设置限制的值为 0 ,相 关类型的 Job 完成后将不会被保留。

 

apiVersion: batch/v1beta1kind: CronJobmetadata: name: hellospec: schedule: "*/1 * * * *" jobTemplate:  spec:   template:    spec:     containers:     - name: hello       image: busybox       args:       - /bin/sh       - -c       - date; echo Hello from the Kubernetes cluster     restartPolicy: OnFailure
$ kubectl get cronjobNAME SCHEDULE SUSPEND ACTIVE LAST-SCHEDULEhello */1 * * * * False 0 
$ kubectl get jobsNAME DESIRED SUCCESSFUL AGEhello-1202039034 1 1 49s$ pods=$(kubectl get pods --selector=job-name=hello-1202039034 --output=jsonpath={.items..metadata.name})$ kubectl logs $podsMon Aug 29 21:34:09 UTC 2016Hello from the Kubernetes cluster# 注意,删除 cronjob 的时候不会自动删除 job,这些 job 可以用 kubectl delete job 来删除$ kubectl delete cronjob hellocronjob "hello" deleted

 

五、CronJob 本身的一些限制

创建 Job 操作应该是 幂等的

 

 

 

 

 

内容来自

 

 

 

 

 

 

 

转载地址:http://vlkof.baihongyu.com/

你可能感兴趣的文章
java 获取HttpRequest Header 的几种方法
查看>>
SpringMVC在Controller层中注入request的坑
查看>>
Spring事务总结---事务概述及Spring事务的基本使用(完整)
查看>>
子类可以继承到父类上的注解吗--有结论了
查看>>
Spring事务总结---传播级别以及REQUIRED_NEW及NESTED的使用场景(赞)
查看>>
通过Spring @PostConstruct 和 @PreDestroy 方法 实现初始化和销毁bean之前进行的操作
查看>>
spring 默认事务传播属性
查看>>
shutdown和shutdownNow--多线程任务的关闭
查看>>
JVM实用参数(七)CMS收集器
查看>>
nginx 已有80端口服务如何在开启一个非80端口的静态资源指向
查看>>
nginx root静态资源地址默认路径
查看>>
redis多个线程操作单个key场景的并发问题
查看>>
textArea没有value 属性 如何显示
查看>>
mysql 嵌套查询
查看>>
svn Cleanup failed to process the following paths错误的解决
查看>>
全国各个城市代码
查看>>
ArrayBlockingQueue和LinkedBlockingQueue的区别
查看>>
Spring Boot配置的第一个应用(如何启动)
查看>>
Spring Boot中使用@Async实现异步调用
查看>>
Netty 源码分析之 三 我就是大名鼎鼎的 EventLoop(一)
查看>>