• Kubernetes组件-CronJob(定时任务)


    ⒈简介:

      Kubernetes的Job资源在创建时会立即运行pod。但是许多批处理任务需要在特定的时间运行,或者在指定的时间间隔内重复运行。在Linux和类UNIX操作系统中,这些任务通常被称为cron任务。Kubernetes也支持这种任务。
      Kubernetes中的cron任务通过创建 CronJob资源进行配置。运行任务的时间表以知名的cron格式指定,所以如果你熟悉常规cron任务,你将在几秒钟内了解Kubernetes的CronJob。
      在配置的时间,Kubernetes将根据在CronJob对象中配置的Job模板创建Job资源。创建Job资源时,将根据任务的pod模板创建并启动一个或多个pod副本。

    ⒉定义(创建)CronJob

    apiVersion: batch/v1beta1  #指定当前描述文件遵循batch/v1beta1版本的KubernetesAPI
    kind: CronJob #我们在描述一个CronJob
    metadata:
      name: batch-job-every-fifteen-minutes  #指定CronJob的名称
    spec: #当没有指定pod选择器时它将根据pod模板中的标签创建
      schedule: "0,15,30,45 * * * *"  #这项工作应该每天在每小时0、15、30和45分钟运行
      jobTemplate: #创建新pod所使用的pod模板
        spec:
          template: #此CronJob创建Job资源会用到的模板
            metadata:
              labels:
                app: periodic-batch-job
            spec:
              restartPolicy: OnFailure  #Job不能使用Always作为默认的重新启动策略
              containers:
              - name: main
                image: fanqisoft/batch-job
                ports:
                - containerPort: 8080

    时间表从左到右包含以下五个条目:
      ·分钟
      ·小时
      ·每月中的第几天
      ·月
      ·星期几
      在该示例中,每15分钟运行一次任务因此schedule字段的值应该是“0,15,30,45****”这意味着每小时的0、15、30和45分钟(第一个星号),每月的每一天(第二个星号),每月(第三个星号)和每周的每一天(第四个星号)。
      相反,如果你希望每隔30分钟运行一次,但仅在每月的第一天运行,则应将计划设置为“0,30*1**”,并且如果你希望它每个星期天的3AM运行,将它设置为“03**0”(最后一个零代表星期天)。

    ⒊计划任务的运行方式

      在计划的时间内,CronJob资源会创建Job资源,然后Job创建pod。
      可能发生Job或pod创建并运行得相对较晚的情况。你可能对这项工作有很高的要求,任务开始不能落后于预定的时间过多。在这种情况下,可以通过指定CronJob规范中的startingDeadlineseconds字段来指定截止日期。

    apiVersion: batch/v1beta1  #指定当前描述文件遵循batch/v1beta1版本的KubernetesAPI
    kind: CronJob #我们在描述一个CronJob
    metadata:
      name: batch-job-every-fifteen-minutes  #指定CronJob的名称
    spec: #当没有指定pod选择器时它将根据pod模板中的标签创建
      schedule: "0,15,30,45 * * * *"  #这项工作应该每天在每小时0、15、30和45分钟运行
      startingDeadlineSeconds: 15 #pod最迟必须在预定时间后15秒开始运行
      jobTemplate: #创建新pod所使用的pod模板
        spec:
          template: #此CronJob创建Job资源会用到的模板
            metadata:
              labels:
                app: periodic-batch-job
            spec:
              restartPolicy: OnFailure  #Job不能使用Always作为默认的重新启动策略
              containers:
              - name: main
                image: fanqisoft/batch-job
                ports:
                - containerPort: 8080

      在上面的例子中,工作运行的时间应该是10:30:00。如果因为任何原因10:30:15不启动,任务将不会运行,并将显示为Failed。
      在正常情况下,CronJob总是为计划中配置的每个执行创建一个Job,但可能会同时创建两个Job,或者根本没有创建。为了解决第一个问题,你的任务应该是幂等的(多次而不是一次运行不会得到不希望的结果)。对于第二个问题,请确保下一个任务运行完成本应该由上一次的(错过的)运行完成的任何工作。

  • 相关阅读:
    多选下拉框带搜索(aps.net)
    asp.net无刷新上传(带预览)
    http免费升级https 攻略(超简单)
    用JS获取地址栏参数的方法
    C#生成二维码
    update更新另一个字段
    自适应瀑布型布局(手机,PC全兼容)
    微信扫码支付.net版本
    常用css3技巧
    Repeater 嵌套,子级Repeater获取 父级Repeater 中的值
  • 原文地址:https://www.cnblogs.com/fanqisoft/p/11425351.html
Copyright © 2020-2023  润新知