news 2026/5/30 17:04:46

kubernetes之Cronjob

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
kubernetes之Cronjob

Cronjob 简介

Cronjob是一个计划任务,与 Linux 系统 Crontab 一样,格式也是基本一样。

格式如下

# ┌───────────── minute (0 - 59) # │ ┌───────────── hour (0 - 23) # │ │ ┌───────────── day of the month (1 - 31) # │ │ │ ┌───────────── month (1 - 12) # │ │ │ │ ┌───────────── day of the week (0 - 6) (Sunday to Saturday; # │ │ │ │ │ 7 is also Sunday on some systems) # │ │ │ │ │ # │ │ │ │ │ # * * * * * command to execute

具体见 https://en.wikipedia.org/wiki/Cron#Overview

Cronjob 结构草图

Cronjob 运行

CronJob使用 Job 对象来完成任务。CronJob每次运行时都会创建一个Job对象,Job会创建一个Pods来执行任务,任务执行完成后停止容器。

Cronjob 用途

CronJob在特定时间 或 按特定间隔运行任务。CronJob非常适合用于自动执行任务,例如备份、报告、发送电子邮件或清理任务。

Cronjob 例子

apiVersion:batch/v1beta1kind:CronJobmetadata:name:demo# Cronjob的名称labels:app:democron:hellospec:concurrencyPolicy:ForbidfailedJobsHistoryLimit:1jobTemplate:spec:template:metadata:labels:app:democron:hellospec:containers:-image:harbor.example.com/hello:v1imagePullPolicy:IfNotPresentname:hellocommand:[/bin/bash]args:--c-echo "Hello World!!!"# job 具体执行的任务resources:limits:cpu:300mmemory:300Mirequests:cpu:100mmemory:100MinodeSelector:label:testimagePullSecrets:-name:harbor-certificationrestartPolicy:Neverschedule:"15 * * * *"# job执行的周期,cron格式的字符串successfulJobsHistoryLimit:1

Cronjob 重要参数解释

  • 调度

    .spec.schedule.spec中必需的字段,它的值是Cron格式字的符串,例如:0 * * * *,或者 @hourly,根据指定的调度时间Job会被创建和执行。

  • 启动 Job 的期限(秒级别)

    .spec.startingDeadlineSeconds字段是可选的。它表示启动 Job 的期限(秒级别),如果因为任何原因而错过了被调度的时间,那么错过执行时间的 Job 将被认为是失败的。如果没有指定,则没有期限。

  • Job 历史版本限制

    • .spec.successfulJobsHistoryLimit:# 字段是可选的,成功完成的作业保存多少个
    • .spec.failedJobsHistoryLimit: # 字段是可选的,失败的作业保存多少个

    默认没有限制,所有成功和失败的 Job 都会被保留。然而,当运行一个 Cron Job 时,很快就会堆积很多 Job,推荐设置这两个字段的值。设置为0则不会保存,这两个字段与jobTemplate同级。

  • 并发策略

    .spec.concurrencyPolicy字段也是可选的。它指定了如何处理被 Cron Job 创建的 Job 的并发执行。只允许指定下面策略中的一种:

    • Allow(默认):允许并发运行 Job
    • Forbid:禁止并发运行,如果前一个还没有完成,则直接跳过下一个
    • Replace:取消当前正在运行的 Job,用一个新的来替换

    注意,当前策略只能应用于同一个 Cron Job 创建的 Job。如果存在多个 Cron Job,它们创建的 Job 之间总是允许并发运行。

  • 挂起

    .spec.suspend字段也是可选的。如果设置为true,后续所有执行都将被挂起。它对已经开始执行的Job不起作用。默认值为false

  • 重启策略

    restartPolicy仅支持NeverOnFailure

🔥运维干货分享

  • 软考高级系统架构设计师备考学习资料
  • 软考中级数据库系统工程师学习资料
  • 软考高级网络规划设计师备考学习资料
  • 软考高级系统规划与管理师学习资料
  • 软考中级系统集成项目管理师学习资料
  • Kubernetes CKA认证学习资料分享
  • AI大模型学习资料合集
  • PuTTY中文版安装包
  • MobaXterm中文版安装包
  • pinginfoview网络诊断工具中文版
  • Xshell、Xsftp、Xmanager中文版安装包
  • 毕业设计高质量毕业答辩 PPT 模板分享
  • IT行业工程师面试简历模板分享
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/27 15:52:17

Termshark实战指南:5个技巧让你在3分钟内掌握终端网络分析

Termshark实战指南:5个技巧让你在3分钟内掌握终端网络分析 【免费下载链接】termshark A terminal UI for tshark, inspired by Wireshark 项目地址: https://gitcode.com/gh_mirrors/te/termshark 还在为服务器上庞大的pcap文件而烦恼吗?每次都要…

作者头像 李华
网站建设 2026/5/29 18:16:48

2025小模型革命:Jamba Reasoning 3B如何用30亿参数重构AI效率范式

导语 【免费下载链接】AI21-Jamba-Reasoning-3B 项目地址: https://ai.gitcode.com/hf_mirrors/ai21labs/AI21-Jamba-Reasoning-3B AI21 Labs推出的Jamba Reasoning 3B以30亿参数实现"速度-智能-成本"三角突破,混合架构设计使边缘设备推理成本降低…

作者头像 李华
网站建设 2026/5/27 7:40:14

UniHacker:Unity授权解决方案

UniHacker:Unity授权解决方案 【免费下载链接】UniHacker 为Windows、MacOS、Linux和Docker修补所有版本的Unity3D和UnityHub 项目地址: https://gitcode.com/GitHub_Trending/un/UniHacker 还在为Unity授权费用而烦恼吗?UniHacker作为一款强大的…

作者头像 李华
网站建设 2026/5/28 23:03:59

万亿级AI大模型开源新纪元:Kimi-K2-Base如何重构技术边界?

在人工智能技术快速迭代的当下,开源社区迎来重量级突破。Moonshot AI正式发布万亿参数规模的Kimi-K2-Base基础模型,这一混合专家架构的预训练模型以1万亿总参数和320亿激活参数的配置,为全球开发者和研究者提供了全新的技术基座。 【免费下载…

作者头像 李华
网站建设 2026/5/25 13:42:45

效率革命:Wan2.2-Animate-14B如何让动画制作成本降70%?

效率革命:Wan2.2-Animate-14B如何让动画制作成本降70%? 【免费下载链接】Wan2.2-Animate-14B 项目地址: https://ai.gitcode.com/hf_mirrors/Wan-AI/Wan2.2-Animate-14B 导语 阿里巴巴通义实验室于2025年9月19日正式开源Wan2.2-Animate-14B模型…

作者头像 李华