Kubernetes 1.19.0——cronjob
时间:2022-07-27
本文章向大家介绍Kubernetes 1.19.0——cronjob,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
玩过Linux系统的童鞋都知道crontab定时任务
实际上cronjob就类似于crontab
[root@vms61 chap8-job]# cat job1.yaml
apiVersion: batch/v1
kind: Job
metadata:
name: job1
spec:
#backoffLimit: 6
#completions: 1
#parallelism: 1
template:
metadata:
name: pi
spec:
containers:
- name: hello
image: busybox
imagePullPolicy: IfNotPresent
command: ["sh","-c","echo hello world! ; sleep 10"]
restartPolicy: Never
[root@vms61 chap8-job]# kubectl apply -f job1.yaml
job.batch/job1 created
[root@vms61 chap8-job]# kubectl get job
NAME COMPLETIONS DURATION AGE
job1 0/1 3s 4s
[root@vms61 chap8-job]# kubectl get pods
NAME READY STATUS RESTARTS AGE
job1-wt6v5 1/1 Running 0 7s
[root@vms61 chap8-job]# kubectl get pods
NAME READY STATUS RESTARTS AGE
job1-wt6v5 1/1 Running 0 12s
[root@vms61 chap8-job]# kubectl get pods
NAME READY STATUS RESTARTS AGE
job1-wt6v5 0/1 Completed 0 22s
[root@vms61 chap8-job]# kubectl get job
NAME COMPLETIONS DURATION AGE
job1 1/1 11s 33s
如果配置文件中的sh改成一个不存在的比如shxxx,且restartPolicy一直未Never的话那么就会一直创建不了,报ContainerCannotRun,也仍然会一直创建;如果restartPolicy改为OnFailure,那么就会一直重启,RESTARTS会一直增加
所以,
job的restart策略只能是:
Nerver:只要任务没有完成,则是新创建pod运行,直到job完成会产生多个pod
OnFailure:只要pod没有完成,则会重启pod,直到job完成
parallelism: N 一次性运行N个pod
completions: M job结束需要成功运行的Pod个数,即状态为Completed的pod数
backoffLimit: N 如果job失败,则重试几次
这里parallelism的值指的是一次性运行几个pod,这个值不会超过completions的值。
[root@vms61 chap8-job]# cat job1.yaml
apiVersion: batch/v1
kind: Job
metadata:
name: job1
spec:
backoffLimit: 6
completions: 4
parallelism: 2
template:
metadata:
name: pi
spec:
containers:
- name: hello
image: busybox
imagePullPolicy: IfNotPresent
command: ["sh","-c","echo hello world! ; sleep 10"]
restartPolicy: OnFailure
[root@vms61 chap8-job]# kubectl apply -f job1.yaml
job.batch/job1 created
[root@vms61 chap8-job]# kubectl get pods
NAME READY STATUS RESTARTS AGE
job1-8fsbc 1/1 Running 0 4s
job1-nlqpl 1/1 Running 0 4s
[root@vms61 chap8-job]# kubectl get pods
NAME READY STATUS RESTARTS AGE
job1-8fsbc 1/1 Running 0 9s
job1-nlqpl 1/1 Running 0 9s
[root@vms61 chap8-job]# kubectl get pods
NAME READY STATUS RESTARTS AGE
job1-8fsbc 1/1 Running 0 11s
job1-nlqpl 1/1 Running 0 11s
[root@vms61 chap8-job]# kubectl get pods
NAME READY STATUS RESTARTS AGE
job1-25g8n 0/1 ContainerCreating 0 0s
job1-8fsbc 0/1 Completed 0 12s
job1-nlqpl 0/1 Completed 0 12s
job1-qmqbr 0/1 ContainerCreating 0 0s
[root@vms61 chap8-job]# kubectl get pods
NAME READY STATUS RESTARTS AGE
job1-25g8n 1/1 Running 0 6s
job1-8fsbc 0/1 Completed 0 18s
job1-nlqpl 0/1 Completed 0 18s
job1-qmqbr 1/1 Running 0 6s
[root@vms61 chap8-job]# kubectl get pods
NAME READY STATUS RESTARTS AGE
job1-25g8n 0/1 Completed 0 12s
job1-8fsbc 0/1 Completed 0 24s
job1-nlqpl 0/1 Completed 0 24s
job1-qmqbr 0/1 Completed 0 12s
例子:计算圆周率后200位
现在vms62和vms63下载perl镜像docker pull perl
然后在master上运行
[root@vms61 chap8-job]# kubectl create job job2 --image=perl -- perl -Mbignum=bpi -wle 'print bpi(200)'
job.batch/job2 created
[root@vms61 chap8-job]# kubectl get jobs
NAME COMPLETIONS DURATION AGE
job2 1/1 4s 4s
[root@vms61 chap8-job]# kubectl get pods
NAME READY STATUS RESTARTS AGE
job2-gggqz 0/1 Completed 0 7s
[root@vms61 chap8-job]# kubectl get pods -w
NAME READY STATUS RESTARTS AGE
job2-gggqz 0/1 Completed 0 13s
^C[root@vms61 chap8-job]# kubectl logs -f job2-gggqz
3.1415926535897932384626433832795028841971693993751058209749445923078164062862089986280348253421170679821480865132823066470938446095505822317253594081284811174502841027019385211055596446229489549303820
[root@vms61 chap8-job]# kubectl create cronjob mycronjob1 --image=busybox --schedule="*/1 * * * *" --dry-run=client -o yaml -- date > mycj1.yaml
[root@vms61 chap8-job]# cat mycj1.yaml
apiVersion: batch/v1beta1
kind: CronJob
metadata:
creationTimestamp: null
name: mycronjob1
spec:
schedule: '*/1 * * * *'
jobTemplate:
metadata:
creationTimestamp: null
name: mycronjob1
spec:
template:
metadata:
creationTimestamp: null
spec:
containers:
- command: ["sh","-c","date ; sleep 10"]
image: busybox
imagePullPolicy: IfNotPresent
name: mycronjob1
resources: {}
restartPolicy: OnFailure
status: {}
[root@vms61 chap8-job]# kubectl apply -f mycj1.yaml
cronjob.batch/mycronjob1 created
[root@vms61 chap8-job]# kubectl get pods
No resources found in chap8-job namespace.
[root@vms61 chap8-job]# kubectl get jobs
No resources found in chap8-job namespace.
[root@vms61 chap8-job]# kubectl get pods
NAME READY STATUS RESTARTS AGE
mycronjob1-1601805180-4x9qs 1/1 Running 0 2s
[root@vms61 chap8-job]# kubectl get pods
NAME READY STATUS RESTARTS AGE
mycronjob1-1601805180-4x9qs 0/1 Completed 0 37s
[root@vms61 chap8-job]# kubectl get pods
NAME READY STATUS RESTARTS AGE
mycronjob1-1601805180-4x9qs 0/1 Completed 0 62s
mycronjob1-1601805240-w48dq 0/1 ContainerCreating 0 1s
[root@vms61 chap8-job]# kubectl get pods
NAME READY STATUS RESTARTS AGE
mycronjob1-1601805180-4x9qs 0/1 Completed 0 72s
mycronjob1-1601805240-w48dq 0/1 Completed 0 11s
- ORA-01427问题的分析和解决(r6笔记第51天)
- 从编程实现角度学习 Faster R-CNN(附极简实现)
- Java基础-23(02)总结多线程,线程实现Runnable接口,线程名字获取和设置,线程控制,线程安全,同步线程
- 8 个最好的 Java RESTful 框架
- 【C++基础】C++11 lambda 表达式解析
- 大量redo生成的问题原因及改进(r6笔记第50天)
- Java基础-22总结登录注册IO版,数据操作流,内存操作流,打印流,标准输入输出流,
- YOLO,一种简易快捷的目标检测算法
- Java基础-22总结转换流,随机访问流,合并流,序列化流,Properties
- openshift镜像构建
- 关于数据库无法登录的问题反思(r6笔记第49天)
- SQL中distinct的用法
- 数据结构是哈希表(hashTable)(一)
- 关于奇怪的并行进程分析(三)(r6笔记第47天)
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 安全狗 {safedog} 最新版注入bypass
- C语言定时关机小程序
- 深入k8s:Pod对象中重要概念及用法
- Golang语言排序的几种方式
- 性能分析(1)- Java 进程导致 CPU 使用率升高,问题怎么定位?
- 安全服务之安全基线及加固(三)Apache篇
- 使用docsify来管理文献
- Cypress系列(41)- Cypress 的测试报告
- SSRF绕过
- 性能测试必备知识(6)- 如何查看“CPU 上下文切换”
- flex布局 div盒子居中
- 使用Apple Configurator 2提取商店ipa or app文件
- Spring 自动装配模式之byType
- 使用ATOMac进行Mac自动化测试
- 【赵渝强老师】什么是Oracle的数据字典?