溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Kubernetes的Job資源對象怎么用

發布時間:2020-06-05 12:51:55 來源:億速云 閱讀:400 作者:Leah 欄目:云計算

Kubernetes的Job資源對象怎么用?相信大部分人都還不知道Job資源對象的使用方法,為了讓大家學會,給大家總結了以下內容,話不多說,一起往下看吧。

概念

在有些場景下,是想要運行一些容器執行某種特定的任務,任務一旦執行完成,容器也就沒有存在的必要了。在這種場景下,創建pod就顯得不那么合適。于是就是了Job,Job指的就是那些一次性任務。通過Job運行一個容器,當其任務執行完以后,就自動退出,集群也不再重新將其喚醒。

從程序的運行形態上來區分,可以將Pod分為兩類:長時運行服務(jboss、mysql等)和一次性任務(數據計算、測試)。RC創建的Pod都是長時運行的服務,Job多用于執行一次性任務、批處理工作等,執行完成后便會停止(status.phase變為Succeeded)。

環境介紹

主機IP地址服務
master192.168.1.21k8s
node01192.168.1.22k8s
node02192.168.1.23k8s

基于[ https://blog.51cto.com/14320361/2464655]() 的實驗繼續進行

一、kubernetes支持以下幾種job

  • 非并行job:通常創建一個pod直至其成功結束。
  • 固定結束次數的job:設置spec.completions,創建多個pod,直到.spec.completions個pod成功結束。
  • 帶有工作隊列的并行job:設置.spec.Parallelism但不設置.spec.completions,當所有pod結束并且至少一個成功時,job就認為是成功。

Job Controller

Job Controller負責根據Job Spec創建pod,并持續監控pod的狀態,直至其成功結束,如果失敗,則根據restartPolicy(只支持OnFailure和Never,不支持Always)決定是否創建新的pod再次重試任務。

例子

(1)編寫一個job的yaml文件

[root@master yaml]# vim jop.yaml
kind: Job
apiVersion: batch/v1
metadata:
  name: test-job
spec:
  template:
    metadata:
      name: test-job
    spec:
      containers:
      - name: hello
        image: busybox
        command: ["echo","hello k8s job!"]
      restartPolicy: Never

(2)執行一下

[root@master yaml]# kubectl apply -f jop.yaml 

(3)查看一下

[root@master yaml]# kubectl get pod

Kubernetes的Job資源對象怎么用

查看日志
[root@master yaml]# kubectl logs test-job-gs45w 

Kubernetes的Job資源對象怎么用

我們可以看到job與其他資源對象不同,僅執行一次性任務,默認pod借宿運行后job即結束,狀態為Completed。

(4)修改一下jop的yaml文件,把echo命令換成亂碼

[root@master yaml]# vim jop.yaml
kind: Job
apiVersion: batch/v1
metadata:
  name: test-job
spec:
  template:
    metadata:
      name: test-job
    spec:
      containers:
      - name: hello
        image: busybox
        command: ["asdasxsddwefew","hello k8s job!"] #修改
      restartPolicy: Never

(5)先刪除之前的pod

[root@master yaml]# kubectl delete jobs.batch test-job 

(6)執行一下

[root@master yaml]# kubectl apply -f jop.yaml 

(7)查看一下

[root@master yaml]# kubectl get pod -w

Kubernetes的Job資源對象怎么用

它會一直創建pod直到完成命令。

(8)修改一下jop的yaml文件,修改重啟策略

[root@master yaml]# vim jop.yaml 
kind: Job
apiVersion: batch/v1
metadata:
  name: test-job
spec:
  template:
    metadata:
      name: test-job
    spec:
      containers:
      - name: hello
        image: busybox
        command: ["asdasxsddwefew","hello k8s job!"]
      restartPolicy: OnFailure

(9)先刪除之前的pod

[root@master yaml]# kubectl delete jobs.batch test-job 

(10)執行一下

[root@master yaml]# kubectl apply -f jop.yaml 

(11)查看一下

[root@master yaml]# kubectl get pod -w

Kubernetes的Job資源對象怎么用

它會一直重啟pod完成命令,直到重啟到一定次數就會刪除job。

二、提高Job的執行效率

1. 我們可以在Job.spec字段下加上[parallelism]()選項。表示同時運行多少個Pod執行任務。


(1)編寫一個job的yaml文件

[root@master yaml]# vim jop.yaml
kind: Job
apiVersion: batch/v1
metadata:
  name: test-job
spec:
  parallelism: 2    #同時啟用幾個pod
  template:
    metadata:
      name: test-job
    spec:
      containers:
      - name: hello
        image: busybox
        command: ["echo","hello k8s job!"]
      restartPolicy: OnFailure

(3)執行一下

[root@master yaml]# kubectl apply -f jop.yaml 

(4)查看一下

[root@master yaml]# kubectl get pod

Kubernetes的Job資源對象怎么用

查看日志

Kubernetes的Job資源對象怎么用

2. 我們可以在Job.spec字段下加上complations選項。表示總共需要完成Pod的數量

(1)編寫一個job的yaml文件

[root@master yaml]# vim jop.yaml
kind: Job
apiVersion: batch/v1
metadata:
  name: test-job
spec:
  complations: 8            #運行pod的總數量8個
  parallelism: 2            #同時運行2個pod
  template:
    metadata:
      name: test-job
    spec:
      containers:
      - name: hello
        image: busybox
        command: ["echo","hello k8s job!"]
      restartPolicy: OnFailure

job 字段解釋:

completions:標志Job結束需要成功運行的Pod個數,默認為1
parallelism:標志并行運行的Pod的個數,默認為1
activeDeadlineSeconds:標志失敗Pod的重試最大時間,超過這個時間不會繼續重試.

(2)先刪除之前的pod

[root@master yaml]# kubectl delete jobs.batch test-job 

(3)執行一下

[root@master yaml]# kubectl apply -f jop.yaml 

(4)查看一下

[root@master yaml]# kubectl get pod

Kubernetes的Job資源對象怎么用
可以看到pod是兩個兩個的啟動的。

3. 如何定時執行Job

(1)編寫一個cronjob的yaml文件

[root@master yaml]# vim cronjop.yaml
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

(2)先刪除之前的pod

[root@master yaml]# kubectl delete jobs.batch test-job 

(3)執行一下

[root@master yaml]# kubectl apply -f jop.yaml 

(4)查看一下

[root@master yaml]# kubectl get pod

Kubernetes的Job資源對象怎么用

[root@master yaml]# kubectl get cronjobs.batch 

Kubernetes的Job資源對象怎么用

此時查看Pod的狀態,會發現,每分鐘都會運行一個新的Pod來執行命令規定的任
務。

練習:規定2020.1.15.10.5分運行上面的crontab任務。

(1)編寫一個cronjob的yaml文件

[root@master yaml]# vim cronjop.yaml
kind: CronJob
apiVersion: batch/v1beta1
metadata:
  name: hello
spec:
  schedule: "5 10 15 1 *" #限定時間
  jobTemplate:
    spec:
      template:
        spec:
          containers:
          - name: hello
            image: busybox
            command: ["echo","hello","cronjob"]
          restartPolicy: OnFailure

(2)先刪除之前的pod

[root@master yaml]# kubectl delete cronjobs.batch hello 

(3)執行一下

[root@master yaml]# kubectl apply -f jop.yaml 

(4)查看一下

[root@master yaml]# kubectl get pod

Kubernetes的Job資源對象怎么用

這時會發現,如果規定具體時間,可能并不會執行任務。

(5)添加apiVersion庫

[root@master yaml]# vim /etc/kubernetes/manifests/kube-apiserver.yaml 
spec:
  containers:
  - command:
    - kube-apiserver
    - --runtime-config=batch/v2alpha1=true    #添加

Kubernetes的Job資源對象怎么用

(6)重啟kubelet

[root@master yaml]# systemctl restart kubelet.service 

(7)查看api版本

[root@master yaml]# kubectl api-versions 

Kubernetes的Job資源對象怎么用

(8)編寫一個cronjob的yaml文件

[root@master yaml]# vim cronjop.yaml
kind: CronJob
apiVersion: batch/v1beta1
metadata:
  name: hello
spec:
  schedule: "47 10 15 1 *" #限定時間
  jobTemplate:
    spec:
      template:
        spec:
          containers:
          - name: hello
            image: busybox
            command: ["echo","hello","cronjob"]
          restartPolicy: OnFailure

(9)執行一下

[root@master yaml]# kubectl apply -f jop.yaml 

(4)查看一下

[root@master yaml]# kubectl get pod -w

Kubernetes的Job資源對象怎么用

注意:此時仍然不能正常運行指定時間的Job,這是因為K8s官方在cronjob這個資源對象的支持中還沒有完善此功能,還待開發。

跟Job資源一樣在cronjob.spec.jobTemplate.spec 下同樣支持并發Job參數:
parallelism,也支持完成Pod的總數參數: completionsr

以上就是Kubernetes的Job資源對象的使用方法,看完之后是否有所收獲呢?如果想了解更多相關內容,歡迎關注億速云行業資訊!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女