k8s初级实战06--Job CronJob

2024-05-31 00:08

本文主要是介绍k8s初级实战06--Job CronJob,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

k8s初级实战06--Job & CronJob

  • 1 基础概念
  • 2 常见用法
    • 2.1 Job
    • 2.2 CronJob
  • 3 注意事项
  • 4 说明

1 基础概念

  1. Job
    Job负责批量处理短暂的一次性任务 (short lived one-off tasks),即仅执行一次的任务,它保证批处理任务的一个或多个Pod成功结束。
    当第一个 Pod 失败或者被删除(比如因为节点硬件失效或者重启)时,Job 对象会启动一个新的 Pod。删除 Job 的操作会清除所创建的全部 Pods。
    Kubernetes支持以下几种Job:
    1. 非并行Job:通常创建一个Pod直至其成功结束
    2. 固定结束次数的Job:设置.spec.completions,创建多个Pod,直到.spec.completions个Pod成功结束
    3. 带有工作队列的并行Job:设置.spec.Parallelism但不设置.spec.completions,当所有Pod结束并且至少一个成功时,Job就认为是成功
  2. CronJob
    CronJob 即定时任务,就类似于 Linux 系统的 crontab,在指定的时间周期运行指定的任务。
    CronJobs 对于创建周期性的、反复重复的任务很有用,例如执行数据备份或者发送邮件。 CronJobs 也可以用来计划在指定时间来执行的独立任务,例如计划当集群看起来很空闲时 执行某个 Job。
    crontab 时间表7语法:
    # ┌───────────── 分钟 (0 - 59)
    # │ ┌───────────── 小时 (0 - 23)
    # │ │ ┌───────────── 月的某天 (1 - 31)
    # │ │ │ ┌───────────── 月份 (1 - 12)
    # │ │ │ │ ┌───────────── 周的某天 (0 - 6) (周日到周一;在某些系统上,7 也是星期日)
    # │ │ │ │ │ 
    # │ │ │ │ │
    # │ │ │ │ │
    # * * * * *
    

2 常见用法

2.1 Job

  1. 创建Job 计算pi小数点后100位
    $ kubectl create job cal-pi --image=perl:5.32 -- perl -Mbignum=bpi -wle 'print bpi(100)'
    job.batch/cal-pi created
    查看输出日志:
    $ kubectl logs cal-pi-dh766     
    3.141592653589793238462643383279502884197169399375105820974944592307816406286208998628034825342117068
    或者yaml
    vim job-cal-pi.yaml 
    kind: Job
    apiVersion: batch/v1
    metadata:name: cal-pi
    spec:template:spec:containers:- name: cal-piimage: perl:5.32command:- perl- '-Mbignum=bpi'- '-wle'- 'print bpi(100)'imagePullPolicy: IfNotPresentrestartPolicy: NeverbackoffLimit: 4
    $ kubectl apply -f job-cal-pi.yaml
    
  2. 查看job
    $ kubectl get jobs[.batch]
    NAME     COMPLETIONS   DURATION   AGE
    cal-pi   1/1           4s         22s
    
  3. 删除job
    $ kubectl delete -f job-cal-pi.yaml 
    job.batch "cal-pi" deleted
    
  4. 创建job 执行10次任务
    vim job-cal-pi-10.yaml 
    kind: Job
    apiVersion: batch/v1
    metadata:name: cal-pi-10
    spec:completions: 10template:spec:containers:- name: cal-piimage: perl:5.32command:- perl- '-Mbignum=bpi'- '-wle'- 'print bpi(100)'imagePullPolicy: IfNotPresentrestartPolicy: NeverbackoffLimit: 4
    $ kubectl apply -f job-cal-pi-10.yaml 
    
    过一会可以在lens前端上发现该任务执行完成: 在这里插入图片描述

2.2 CronJob

  1. 创建cronjob
    $ kubectl create cronjob cal-pi-cj --schedule="*/1 * * * *" --image=perl:5.32 -- perl -Mbignum=bpi -wle 'print bpi(100)'
    cronjob.batch/cal-pi-cj created或者yaml创建
    vim cronjob-cal-pi.yaml 
    kind: CronJob
    apiVersion: batch/v1beta1
    metadata:name: cal-pi-cj
    spec:schedule: '*/1 * * * *'jobTemplate:spec:template:spec:containers:- name: cal-pi-cjimage: perl:5.32command:- perl- '-Mbignum=bpi'- '-wle'- 'print bpi(100)'imagePullPolicy: IfNotPresentrestartPolicy: OnFailure
    $ kubectl apply -f cronjob-cal-pi.yaml 
    
    lens 中执行任务的状态如下: 在这里插入图片描述
  2. 查看cronjob
    $ kubectl get cronjobs.batch 
    NAME        SCHEDULE      SUSPEND   ACTIVE   LAST SCHEDULE   AGE
    cal-pi-cj   */1 * * * *   False     0        <none>          31s
    
  3. 删除cronjob
    kubectl delete cronjobs[.batch] cal-pi-cj 
    cronjob.batch "cal-pi-cj" deleted
    

3 注意事项

  1. job执行完成后,对应的pod不会自动删除(),删除job后才会删除对应的pod。

4 说明

概念->工作负载->工作负载资源->Jobs
Kubernetes指南->Job

这篇关于k8s初级实战06--Job CronJob的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1017119

相关文章

Python并行处理实战之如何使用ProcessPoolExecutor加速计算

《Python并行处理实战之如何使用ProcessPoolExecutor加速计算》Python提供了多种并行处理的方式,其中concurrent.futures模块的ProcessPoolExecu... 目录简介完整代码示例代码解释1. 导入必要的模块2. 定义处理函数3. 主函数4. 生成数字列表5.

Java Spring 中的监听器Listener详解与实战教程

《JavaSpring中的监听器Listener详解与实战教程》Spring提供了多种监听器机制,可以用于监听应用生命周期、会话生命周期和请求处理过程中的事件,:本文主要介绍JavaSprin... 目录一、监听器的作用1.1 应用生命周期管理1.2 会话管理1.3 请求处理监控二、创建监听器2.1 Ser

Apache 高级配置实战之从连接保持到日志分析的完整指南

《Apache高级配置实战之从连接保持到日志分析的完整指南》本文带你从连接保持优化开始,一路走到访问控制和日志管理,最后用AWStats来分析网站数据,对Apache配置日志分析相关知识感兴趣的朋友... 目录Apache 高级配置实战:从连接保持到日志分析的完整指南前言 一、Apache 连接保持 - 性

MQTT SpringBoot整合实战教程

《MQTTSpringBoot整合实战教程》:本文主要介绍MQTTSpringBoot整合实战教程,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录MQTT-SpringBoot创建简单 SpringBoot 项目导入必须依赖增加MQTT相关配置编写

JavaScript实战:智能密码生成器开发指南

本文通过JavaScript实战开发智能密码生成器,详解如何运用crypto.getRandomValues实现加密级随机密码生成,包含多字符组合、安全强度可视化、易混淆字符排除等企业级功能。学习密码强度检测算法与信息熵计算原理,获取可直接嵌入项目的完整代码,提升Web应用的安全开发能力 目录

Redis迷你版微信抢红包实战

《Redis迷你版微信抢红包实战》本文主要介绍了Redis迷你版微信抢红包实战... 目录1 思路分析1.1hCckRX 流程1.2 注意点①拆红包:二倍均值算法②发红包:list③抢红包&记录:hset2 代码实现2.1 拆红包splitRedPacket2.2 发红包sendRedPacket2.3 抢

springboot项目redis缓存异常实战案例详解(提供解决方案)

《springboot项目redis缓存异常实战案例详解(提供解决方案)》redis基本上是高并发场景上会用到的一个高性能的key-value数据库,属于nosql类型,一般用作于缓存,一般是结合数据... 目录缓存异常实践案例缓存穿透问题缓存击穿问题(其中也解决了穿透问题)完整代码缓存异常实践案例Red

Spring Boot拦截器Interceptor与过滤器Filter深度解析(区别、实现与实战指南)

《SpringBoot拦截器Interceptor与过滤器Filter深度解析(区别、实现与实战指南)》:本文主要介绍SpringBoot拦截器Interceptor与过滤器Filter深度解析... 目录Spring Boot拦截器(Interceptor)与过滤器(Filter)深度解析:区别、实现与实

基于C#实现MQTT通信实战

《基于C#实现MQTT通信实战》MQTT消息队列遥测传输,在物联网领域应用的很广泛,它是基于Publish/Subscribe模式,具有简单易用,支持QoS,传输效率高的特点,下面我们就来看看C#实现... 目录1、连接主机2、订阅消息3、发布消息MQTT(Message Queueing Telemetr

Nginx使用Keepalived部署web集群(高可用高性能负载均衡)实战案例

《Nginx使用Keepalived部署web集群(高可用高性能负载均衡)实战案例》本文介绍Nginx+Keepalived实现Web集群高可用负载均衡的部署与测试,涵盖架构设计、环境配置、健康检查、... 目录前言一、架构设计二、环境准备三、案例部署配置 前端 Keepalived配置 前端 Nginx