【云原生】Kubernetes中的定时任务CronJob的详细用法与企业级应用案例分享

在这里插入图片描述

✨✨ 欢迎大家来到景天科技苑✨✨

🎈🎈 养成好习惯,先赞后看哦~🎈🎈

🏆 作者简介:景天科技苑
🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。
🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi,flask等框架,云原生k8s,linux,shell脚本等实操经验,网站搭建,数据库等分享。

所属的专栏:云原生K8S,零基础到进阶实战
景天的主页:景天科技苑

在这里插入图片描述

文章目录

  • CronJob
    • 引言
    • CronJob基本概念
    • CronJob的Cron表达式
    • CronJob的创建与管理
      • 1. 创建CronJob
      • 2. 查看CronJob
      • 3. 查看Pod日志
      • 4. 更新CronJob
      • 5. 删除CronJob
    • CronJob的并发策略
      • 并发策略示例
        • 1. Allow(默认)
        • 2. Forbid
        • 3. Replace
    • 实战案例:定时备份数据库
      • 1. 准备备份脚本
      • 2. 创建Docker镜像
      • 3. 定义CronJob
      • 4. 验证CronJob
    • CronJob 的高级应用
      • 1. 失败处理和重试
      • 2. 定时任务的优雅关闭
      • 3. 配置依赖和环境变量
      • 4. 监控和日志记录
      • 5. 版本控制和CI/CD
      • 6. 最佳实践

CronJob

引言

在现代的云原生应用中,定时任务是一个非常重要的组成部分。Kubernetes(简称k8s)提供了一种称为CronJob的机制,可以让我们方便地定义和管理定时任务。CronJob基于Cron表达式,允许在指定的时间间隔内自动运行容器化的任务,如定时备份、数据清理、定期报告等。本文将结合实际案例,详细介绍Kubernetes中CronJob的详细用法。

CronJob基本概念

CronJob是Kubernetes中的一种资源对象,用于定期执行任务。它基于Cron表达式,允许用户在指定的时间间隔内自动运行容器化的任务。CronJob的主要组成部分包括:

  • schedule:指定任务执行的时间表,使用标准的Cron表达式语法。
  • jobTemplate:定义要执行的任务的模板,通常是一个Pod模板,包含任务所需的容器镜像、命令、环境变量等配置。
  • concurrencyPolicy:指定任务并发策略,默认为Allow,表示允许并发执行任务。
  • successfulJobsHistoryLimit和failedJobsHistoryLimit:指定保留成功和失败任务历史记录的数量。

CronJob的Cron表达式

CronJob的Cron表达式由五个字段组成,分别代表分钟、小时、日、月、周几。每个字段可以使用单个数字、逗号分隔的数字列表、连续的数字范围、星号(*)或斜杠(/)来表示。

  • 单个数字:例如5表示第5分钟或5月份。
  • 逗号分隔的数字列表:例如5,15,25表示第5、15和25分钟。
  • 连续的数字范围:例如10-15表示从第10分钟到第15分钟。
  • 星号(*):表示匹配该字段的所有值。
  • 斜杠(/):表示步长值。

CronJob表达式示例:

  • 每小时执行:0 * * * *
  • 每天晚上10点执行:0 22 * * *
  • 每周一早上6点执行:0 6 * * 1
  • 每2分钟运行一次任务:*/2 * * * *

CronJob的创建与管理

1. 创建CronJob

在Kubernetes中,可以通过YAML文件定义CronJob资源,并使用kubectl apply命令创建。以下是一个CronJob的YAML文件示例:

apiVersion: batch/v1
kind: CronJob
metadata:name: hello-cronjob
spec:schedule: "*/1 * * * *"  # 每分钟执行一次jobTemplate:spec:template:spec:containers:- name: helloimage: busyboxargs:- /bin/sh- -c- date; echo Hello from CronJobrestartPolicy: OnFailure

该YAML文件定义了一个名为hello-cronjob的CronJob,它每分钟执行一次,执行的任务是打印当前日期和时间,并输出"Hello from CronJob"。

使用kubectl apply命令创建CronJob:

kubectl apply -f hello-cronjob.yaml

2. 查看CronJob

创建CronJob后,可以使用kubectl get cronjob命令查看CronJob的状态:

kubectl get cronjob

输出示例:

NAME           SCHEDULE      SUSPEND   ACTIVE   LAST SCHEDULE   AGE
hello-cronjob  */1 * * * *   False     0        <none>          1m

3. 查看Pod日志

CronJob根据指定的时间表自动创建和调度Job对象,每个Job对象代表了一次任务的执行。可以使用kubectl get pods查看由CronJob创建的Pod:

kubectl get pods

找到对应的Pod后,使用kubectl logs命令查看Pod的日志:

kubectl logs <pod-name>

4. 更新CronJob

如果需要更新CronJob的配置,可以修改YAML文件并重新应用。但是,直接修改正在运行的CronJob的配置可能会导致不可预测的行为。建议的做法是删除旧的CronJob并创建新的。

5. 删除CronJob

使用kubectl delete命令删除CronJob:

kubectl delete cronjob hello-cronjob

CronJob的并发策略

CronJob的concurrencyPolicy字段指定了任务的并发策略,有三种可选值:

  • Allow(默认):允许并发执行任务。
  • Forbid:禁止并发执行任务,新任务将会被跳过。
  • Replace:如果
    存在之前的任务还在运行,则取消之前的任务并启动新任务。

并发策略示例

1. Allow(默认)

在默认情况下,如果CronJob的调度时间重叠,Kubernetes会允许所有任务并行执行。这适用于那些可以并行处理且互不影响的任务。

2. Forbid

如果你希望在同一时间内只有一个任务实例运行,可以将concurrencyPolicy设置为Forbid。当新的任务触发时,如果之前的任务还在运行,新任务将不会被创建。

修改CronJob YAML文件如下:

apiVersion: batch/v1
kind: CronJob
metadata:name: hello-cronjob-forbid
spec:concurrencyPolicy: Forbidschedule: "*/2 * * * *"  # 每两分钟执行一次jobTemplate:spec:template:spec:containers:- name: helloimage: busyboxargs:- /bin/sh- -c- date; echo Hello from CronJob with Forbid policyrestartPolicy: OnFailure
3. Replace

在某些情况下,你可能希望新的任务能够取代正在运行的任务。这时,可以将concurrencyPolicy设置为Replace。当新的任务触发时,如果之前的任务还在运行,Kubernetes会取消之前的任务,并启动新任务。

修改CronJob YAML文件如下:

apiVersion: batch/v1
kind: CronJob
metadata:name: hello-cronjob-replace
spec:concurrencyPolicy: Replaceschedule: "*/3 * * * *"  # 每三分钟执行一次jobTemplate:spec:template:spec:containers:- name: helloimage: busyboxargs:- /bin/sh- -c- date; echo Hello from CronJob with Replace policyrestartPolicy: OnFailure

实战案例:定时备份数据库

假设你有一个运行在Kubernetes中的MySQL数据库,你需要每天凌晨1点自动备份数据库。以下是如何使用CronJob来实现这一需求的步骤。

1. 准备备份脚本

首先,你需要一个备份数据库的脚本。这里以Shell脚本为例,假设脚本名为backup-db.sh,内容如下:

#!/bin/bash
# 假设MySQL数据库的连接信息已经通过环境变量提供
mysqldump -h $DB_HOST -u $DB_USER -p$DB_PASSWORD $DB_NAME > /backup/db-$(date +%Y%m%d%H%M%S).sql

2. 创建Docker镜像

接下来,你需要将这个脚本打包到一个Docker镜像中。创建一个Dockerfile,内容如下:

FROM busybox
COPY backup-db.sh /usr/local/bin/backup-db.sh
RUN chmod +x /usr/local/bin/backup-db.sh
ENTRYPOINT ["/usr/local/bin/backup-db.sh"]

构建并推送这个Docker镜像到你的镜像仓库。

3. 定义CronJob

最后,使用YAML文件定义CronJob,并在Kubernetes中创建它。假设你的Docker镜像名为my-db-backup:latest,CronJob的YAML文件可能如下所示:

apiVersion: batch/v1
kind: CronJob
metadata:name: db-backup
spec:schedule: "0 1 * * *"  # 每天凌晨1点执行jobTemplate:spec:template:spec:containers:- name: db-backupimage: my-db-backup:latestenv:- name: DB_HOSTvalue: "your-db-host"- name: DB_USERvalue: "your-db-user"- name: DB_PASSWORDvalueFrom:secretKeyRef:name: db-secretkey: password- name: DB_NAMEvalue: "your-db-name"volumeMounts:- name: backup-volumemountPath: /backupvolumes:- name: backup-volumepersistentVolumeClaim:claimName: backup-pvcrestartPolicy: Never

注意,在这个例子中,数据库密码是通过Kubernetes的Secret来管理的,而备份文件被存储在一个PersistentVolumeClaim(PVC)中。

使用kubectl apply命令将上面定义的CronJob YAML文件应用到Kubernetes集群中。首先,确保你的YAML文件(假设名为db-backup-cronjob.yaml)保存在你的本地机器上,并且你已经配置了kubectl以连接到你的Kubernetes集群。

然后,在命令行中运行以下命令:

kubectl apply -f db-backup-cronjob.yaml

这个命令会读取db-backup-cronjob.yaml文件,并将其中的CronJob定义应用到Kubernetes集群中。如果CronJob成功创建,你将看到一条消息,指出CronJob已被创建(例如,“cronjob.batch/db-backup created”)。

现在,CronJob会根据你指定的调度时间(在这个例子中是每天凌晨1点)自动触发。每次触发时,Kubernetes都会根据CronJob中的定义启动一个新的Job,该Job将执行你的备份脚本。

4. 验证CronJob

要验证CronJob是否按预期工作,你可以使用kubectl来检查CronJob的状态和相关的Job。

  • 查看CronJob的状态:

    kubectl get cronjobs
    

    这将列出集群中所有的CronJob,包括你的db-backup CronJob。检查它的SCHEDULESUSPENDACTIVE列,以确保它正在按预期运行。

  • 查看由CronJob创建的Job:

    CronJob每次触发都会创建一个新的Job。要查看这些Job,你可以使用以下命令:

    kubectl get jobs
    

    注意,由于Job在成功完成后可能会自动删除(取决于backoffLimitttlSecondsAfterFinished等设置),你可能需要查看稍早时间点的Job,或者调整你的CronJob和Job定义以保留旧的Job以供查看。

  • 查看Job的日志:

    如果你想要查看由特定Job执行的容器的日志,你可以使用以下命令(将<job-name>替换为实际的Job名称):

    kubectl logs <job-name>
    

    由于Job可能包含多个Pod(尽管在大多数情况下,CronJob触发的Job只会有一个Pod),你可能需要指定Pod的名称或使用其他选项来过滤日志。但是,在大多数情况下,CronJob触发的Job只有一个Pod,因此你可以直接使用上面的命令。

通过这些步骤,你可以验证你的CronJob是否按预期工作,并检查备份脚本是否成功执行。如果出现问题,你可以根据日志和Kubernetes事件来诊断问题,并相应地调整你的CronJob和Job定义。

当然,我们可以继续讨论关于Kubernetes CronJob的一些高级话题和最佳实践。

CronJob 的高级应用

1. 失败处理和重试

如果你的备份脚本或任何CronJob中的任务失败了,你可能想要配置重试策略。然而,CronJob 本身并不直接支持任务失败后的重试。但你可以通过配置 Job 的 backoffLimit 字段来实现一定程度的重试。backoffLimit 指定了Job失败后可以重试的次数。设置为0表示不重试。

spec:template:spec:restartPolicy: Nevercontainers:...backoffLimit: 4  # Job失败后最多重试4次

但是,请注意,这并不意味着CronJob会在下一个调度时间之前重试失败的Job。相反,它会在Job失败后立即尝试重新创建它,直到达到backoffLimit指定的次数。

2. 定时任务的优雅关闭

有时,你可能需要在CronJob的任务被终止之前执行一些清理操作,比如优雅地关闭数据库连接或释放资源。这可以通过在容器中运行一个前置脚本或命令来实现,该脚本或命令会在容器接收到终止信号时执行。

然而,CronJob 并不直接支持在任务被取消时执行特定的清理操作。但是,你可以通过在你的应用程序或脚本中监听SIGTERM信号来实现这一点。当Kubernetes决定终止Pod时,它会向Pod中的每个容器发送SIGTERM信号,然后等待一段指定的宽限期(默认为30秒),之后发送SIGKILL信号强制终止容器。

3. 配置依赖和环境变量

正如之前的示例所示,你可以通过环境变量将配置信息传递给CronJob中的容器。这包括数据库连接信息、API密钥、配置文件的路径等。确保这些信息以安全的方式存储和传递,例如使用Kubernetes的Secrets或ConfigMaps。

4. 监控和日志记录

监控CronJob的执行情况和日志记录是确保任务按预期运行的关键。你可以使用Kubernetes的日志收集工具(如Fluentd、Fluent Bit、Logstash等)将Pod日志发送到中央日志系统(如Elasticsearch、Splunk、Graylog等)。此外,你还可以使用Prometheus等监控工具来跟踪CronJob的性能指标,如任务执行时间、成功率和失败率。

5. 版本控制和CI/CD

将你的CronJob定义和相关的Docker镜像纳入版本控制系统(如Git)中,并使用持续集成/持续部署(CI/CD)管道来自动化构建、测试和部署过程。这有助于确保你的CronJob在每次更改后都能以可预测和可靠的方式运行。

6. 最佳实践

  • 使用Secrets和ConfigMaps来管理敏感信息和配置
  • 定期审查和更新CronJob的调度时间和任务逻辑
  • 监控CronJob的性能和日志,以快速识别和解决潜在问题
  • 确保CronJob中的任务能够优雅地处理终止信号和异常
  • 将CronJob定义纳入版本控制,并使用CI/CD管道来管理部署

通过遵循这些最佳实践,你可以确保你的Kubernetes CronJob能够稳定、可靠地运行,从而满足你的定时任务需求。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://xiahunao.cn/news/3280364.html

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

数据库安全:MySQL文件权限的安全问题和解决方案

「作者简介」&#xff1a;冬奥会网络安全中国代表队&#xff0c;CSDN Top100&#xff0c;就职奇安信多年&#xff0c;以实战工作为基础著作 《网络安全自学教程》&#xff0c;适合基础薄弱的同学系统化的学习网络安全&#xff0c;用最短的时间掌握最核心的技术。 这一章节我们需…

Java8新特性之Stream-Map

Map一些新方法的具体使用案例 1、getOrDefault:default V getOrDefault(Object key, V defaultValue) package com.qbb.threadpool;import java.util.HashMap; import java.util.Map;/*** author QiuQiu&LL (个人博客:https://www.cnblogs.com/qbbit)* version 1.0* date…

从功能出发:优化超市商品陈列,助力销售额提升

随着时代的发展&#xff0c;竞争的加剧&#xff0c;人们的生活节奏加快&#xff0c;时间观念越来越强。在这种情形下&#xff0c;作为超市&#xff0c;怎样为顾客提供一个舒适方便的购物环境&#xff0c;尽可能让顾客逛完整个卖场&#xff0c;满足一站式购足呢&#xff1f;除了…

外卖项目day10---缓存商品/Spring Cache初学、购物车功能

缓存菜品&#xff0c;只需要在DishController中修改一下代码即可 /*** 菜品管理*/ RestController RequestMapping("/admin/dish") Api(tags "菜品相关接口") Slf4j public class DishController {Autowiredprivate DishService dishService;Autowiredpri…

【前端面试】七、算法-递归

遍历方法总结 链式调用 数组的很多操作可以构成链式操作&#xff0c;类似这样的格式&#xff1a;…map().filter(…).sort(…).map(….)链式操作就是对象方法返回类型是自身的。比如map是属于数组的方法&#xff0c;它返回数组&#xff0c;所以构成了链式操作优势&#xff1a;…

The Llama 3 Herd of Models 第4部分后训练的全文

Llama 3前三部分包括介绍、总体概述和预训练https://blog.csdn.net/qq_51570094/article/details/140682445?spm=1001.2014.3001.5501 4 Post-Training 后训练 我们通过应用几轮后训练6或将模型与人类反馈对齐来生成对齐的Llama 3模型(Ouyang等人,2022;Rafailov等人,2024)在…

Null Pointer Exception: 如何快速定位和修复?️

Null Pointer Exception: 如何快速定位和修复&#xff1f;&#x1f4a1;&#x1f6e0;️ Null Pointer Exception: 如何快速定位和修复&#xff1f;&#x1f4a1;&#x1f6e0;️摘要引言正文内容什么是Null Pointer Exception&#xff1f;&#x1f914;NPE的常见原因&#x1f…

使子查询可行

使用 子查询 时&#xff0c;行为或要求可能不会保存为普通查询。 此查询有效&#xff1a; 但是&#xff0c;作为子查询&#xff0c;它不再起作用&#xff1a; 原因是子查询需要别名&#xff1a;当我们添加它时&#xff0c;原来的错误消失了&#xff0c;但又出现了新的错误&…

springboot集成thymeleaf实战

引言 笔者最近接到一个打印标签的需求&#xff0c;由于之前没有做过类似的功能&#xff0c;所以这也是一次学习探索的机会了&#xff0c;打印的效果图如下&#xff1a; 这个最终的打印是放在58mm*58mm的小标签纸上&#xff0c;条形码就是下面的35165165qweqweqe序列号生成的&…

FPGA知识基础之--按键控制LED灯项目

文章目录 前言一、按键简介按键:通过按下或者释放来控制电路通断的电子元件按键原理图 二、实验要求三、程序设计3.1思路整理3.2 模型搭建3.3 顶层模块3.4 波形分析 四、代码整理4.1RTL代码4.2 仿真只需在Testbench上增加上述一段代码即可将参数实例化,可达到在Testbench上更改…

卷积神经网络的入门基本介绍 | 带你快速上手各种概念【附图解】

文章目录 1、简介2、核心概念3、关键操作4、常见架构5、训练过程6、重要概念图解⭐6.1、卷积神经网络工作⭐6.2、卷积核6.3、全连接与卷积网络的对比6.4、池化层6.5、感受野和卷积堆叠6.6、神经元计算和激活函数 7、卷积网络可以改进的地方8、结论 &#x1f343;作者介绍&#…

vue3集成LuckySheet实现导入本地Excel进行在线编辑

第一步&#xff1a;克隆或者下载下面的代码 git clone https://github.com/dream-num/Luckysheet.git第二步&#xff1a;安装依赖 npm install npm install gulp -g 第三步&#xff1a;运行 npm run dev效果如下图所示 第四步&#xff1a;打包 打包执行成功后&#xff0c;…

TypeError: Components is not a function

Vue中按需引入Element-plus时&#xff0c;报错TypeError: Components is not a function。 1、参考Element-plus官方文档 安装unplugin-vue-components 和 unplugin-auto-import这两款插件 2、然后需要在vue.config.js中配置webPack打包plugin配置 3、重新启动项目会报错 T…

程序员开发指南

在这个快节奏的时代&#xff0c;作为一名程序员&#xff0c;大家都希望能更快地开发出高质量的应用&#xff0c;而不是花费大量时间在基础设施和后台服务的搭建上。今天&#xff0c;我要向大家介绍一款专为懒人开发者准备的一站式开发应用的神器——MemFire Cloud。 一站式开发…

制品库nexus

详见&#xff1a;Sonatype Nexus Repository搭建与使用&#xff08;详细教程3.70.1&#xff09;-CSDN博客 注意事项&#xff1a; 1.java8环境使用nexus-3.69.0-02-java8-unix.tar.gz包 2.java11环境使用nexus-3.70.1-02-java11-unix.tar.gz包 3.注意使用制品库/etc/yum.repos.…

动物大联盟游戏攻略:必备游戏攻略!VMOS云手机升级攻略教程!

在《动物大联盟》中&#xff0c;合理的称号选择、活动参与和组队合作可以极大提升游戏体验和效率。以下是详细的攻略建议&#xff1a; 称号选择 称号不仅能展示玩家的实力和成就&#xff0c;还能提供额外的属性加成。合理选择和更换称号是提升战力的重要途径。 前期称号选择&…

Matlab编程资源库(19)级数与符号方程求解

一、级数符号求和 求无穷级数的和需要 符号表达式求和函数 symsum &#xff0c;其调用 格式为&#xff1a; symsum(s,v,n,m) 其中 s 表示一个级数的通项&#xff0c;是一个符号表达式。 v 是求和变 量&#xff0c; v 省略时使用系统的默认变量。 n 和 m 是求和的开始项 和…

【康复学习--LeetCode每日一题】3111. 覆盖所有点的最少矩形数目

题目&#xff1a; 给你一个二维整数数组 point &#xff0c;其中 points[i] [xi, yi] 表示二维平面内的一个点。同时给你一个整数 w 。你需要用矩形 覆盖所有 点。 每个矩形的左下角在某个点 (x1, 0) 处&#xff0c;且右上角在某个点 (x2, y2) 处&#xff0c;其中 x1 < x…

职业教育计算机网络综合实验实训室建设应用案例

近年来&#xff0c;职业教育在培养技能型人才方面发挥着越来越重要的作用。然而&#xff0c;传统的计算机网络技术教学模式往往重理论、轻实践&#xff0c;导致学生缺乏实际操作能力和职业竞争力。为了改变这一现状&#xff0c;唯众结合职业教育特点&#xff0c;提出了“教、学…