job資源對象

Job資源對象
服務類的Pod容器:RC、RS、DS、Deployment.
工做類的Pod容器:Job--->執行一次,或者批量執行處理程序,完成以後推出容器。
[root@master ~]# cat job.yaml
kind: Job
apiVersion: batch/v1
metadata:
name: test-job
spec:
template:
metadata:
name: test-job
spec:
containers:vim

  • name: hello
    image: busybox
    command: ["echo","hello k8s job!"]
    restartPolicy: Never
    [root@master ~]# kubectl get pod
    NAME READY STATUS RESTARTS AGE
    test-job-qgc6p 0/1 Completed 0 55s
    [root@master ~]# kubectl logs test-job-qgc6p
    hello k8s job!
    PS:注意,若是容器內執行任務有誤,會根據容器的重啓策略操做容器,不過這裏的容器重啓策略只能是:Never、OnFailure
    提升Job的執行效率
    咱們能夠在Job.spec字段下加上parallelism選項。表示同時運行多少個Pod執行任務
    咱們能夠在Job.spec字段下加上completions選項。表示總共須要完成Pod的數量。
    [root@master ~]# cat job.yaml
    kind: Job
    apiVersion: batch/v1
    metadata:
    name: test-job
    spec:
    completions: 8 //總共須要完成多少個Pod
    parallelism: 2 //同時運行幾個pod
    template:
    metadata:
    name: test-job
    spec:
    containers:
  • name: hello
    image: busybox
    command: ["echo","hello k8s job!"]
    restartPolicy: OnFailure
    如何定時執行Job
    kind: CronJob
    apiVersion: batch/v1beta1
    metadata:
    name: hello
    spec:
    schedule: "/1 *"
    jobTemplate:
    spec:
    template:
    spec:
    containers:
    • name: hello
      image: busybox
      command: ["echo","hello cronjob!"]
      restartPolicy: OnFailure
      [root@master ~]# kubectl apply -f cronjob.yaml
      [root@master ~]# kubectl get cronjobs.batch
      NAME SCHEDULE SUSPEND ACTIVE LAST SCHEDULE AGE
      hello /1 * False 0 47s 51s
      [root@master ~]# kubectl logs hello-1579053480-vpm6t
      hello cronjob!
      此時查看Pod的狀態,會發現,每分鐘都會運行一個新的Pod來執行命令規定的任務。
      練習:
      規定2020年1月15號上午十點五分運行上面的crontab任務。
      [root@master ~]# cat cronjob.yaml
      kind: CronJob
      apiVersion: batch/v1beta1
      metadata:
      name: hello
      spec:
      schedule: "5 10 15 1 3"
      jobTemplate:
      spec:
      template:
      spec:
      containers:
    • name: hello
      image: busybox
      command: ["echo","hello cronjob!"]
      restartPolicy: OnFailure
      這時會發現,若是規定具體時間,可能並不會執行任務。
      [root@master ~]# kubectl api-versions //查看api版本
      添加apiVersion庫。
      [root@master ~]# vim /etc/kubernetes/manifests/kube-apiserver.yaml

//在yaml文件中添加api

  • --runtime-config=batch/v2alpha1=true

而後重啓kubelet服務,從新識別api yaml文件內容便可。
//查看api版本庫
[root@master ~]# kubectl api-versions
PS:注意,此時任然不能正常運行指定時間的job,這時由於k8s官方在cronjob這個資源對象的支持中尚未完善此功能。還待開發。
跟job資源同樣在cronjob.spec.jobTemplate.spec下一樣支持併發Job參數:parallelism,也支持完成Pod的總數參數:completions併發

相關文章
相關標籤/搜索