9.4.k8s的控制器资源(job控制器,cronjob控制器)

目录

一、job控制器

二、cronjob控制器


一、job控制器

job控制器就是一次性任务的pod控制器,pod完成作业后不会重启,其重启策略是:Never;

简单案例

启动一个pod,执行完成一个事件,然后pod关闭;

例如:计算π的值,取前500位;

bash 复制代码
# 编辑资源清单
[root@k8s1 job]# cat job.yaml 
apiVersion: batch/v1
kind: Job
metadata:
  name: job-pi
spec:
  #定义pod模板
  template:
    spec:
      containers:
      - name: c1
        image: perl:5.34
        #执行任务命令,计算π值
        command: ["perl", "-Mbignum=bpi", "-wle", "print bpi(500)"]
      restartPolicy: Never
  #指定标记此次作业失败之前的重复次数,不写默认6次
  backoffLimit: 4

# 创建job资源
[root@k8s1 job]# kubectl apply -f job.yaml 
job.batch/job-pi created

# 查看pod
[root@k8s1 job]# kubectl get pod
NAME           READY   STATUS      RESTARTS   AGE
job-pi-j846r   0/1     Completed   0          32s

# 查看日志
[root@k8s1 job]# kubectl logs -f job-pi-j846r 
3.1415926535897932384626433832795028841971693993751058209749445923078164062862089986280348253421170679821480865132823066470938446095505822317253594081284811174502841027019385211055596446229489549303819644288109756659334461284756482337867831652712019091456485669234603486104543266482133936072602491412737245870066063155881748815209209628292540917153643678925903600113305305488204665213841469519415116094330572703657595919530921861173819326117931051185480744623799627495673518857527248912279381830119491

二、cronjob控制器

cronjob控制器,是基于job控制器,定期频率性执行任务;与linux系统中的crontab一样;

bash 复制代码
# 编辑crontab资源清单
[root@k8s1 job]# cat cronjob.yaml 
apiVersion: batch/v1
kind: CronJob
metadata:
  name: oslee
spec:
  schedule: "* * * * *"
  #定义job的模板
  jobTemplate:
    spec:
      template:
        spec:
          containers:
          - name: c1
            image: alpine:latest
            #执行命令,也是任务
            command:
            - /bin/sh
            - -c
            - date; echo Thus, it has become art;
          restartPolicy: OnFailure

# 创建crontab资源
[root@k8s1 job]# kubectl apply -f cronjob.yaml 
cronjob.batch/oslee created
相关推荐
扑火的小飞蛾1 小时前
RHEL 7 安装 Docker 过程总结
运维·docker·容器
web小白成长日记2 小时前
Node.js 编程实战:部署 Node.js 应用 —— Docker 容器化部署
docker·容器·node.js
柠檬汁Dev2 小时前
已有 K8s 集群如何加装 Sealos 桌面
云原生·容器·kubernetes
ProgrammerPulse2 小时前
企业云原生转型选型参考:VM / 容器混合负载场景青云云易捷容器版与 SmartX 技术适配解析
云原生·超融合
飞翔沫沫情4 小时前
kubeadm部署 Kubernetes(k8s) 高可用集群 V1.32
云原生·容器·kubernetes
江畔何人初4 小时前
理解容器挂载点
linux·运维·云原生
晚霞的不甘6 小时前
Flutter for OpenHarmony 引力弹球游戏开发全解析:从零构建一个交互式物理小游戏
前端·flutter·云原生·前端框架·游戏引擎·harmonyos·骨骼绑定
春日见6 小时前
Docker中如何删除镜像
运维·前端·人工智能·驱动开发·算法·docker·容器
【赫兹威客】浩哥6 小时前
【赫兹威客】完全分布式ZooKeeper测试教程
分布式·zookeeper·云原生
Anastasiozzzz6 小时前
Docker介绍与常见指令
运维·docker·容器