日本熟妇hd丰满老熟妇,中文字幕一区二区三区在线不卡 ,亚洲成片在线观看,免费女同在线一区二区

設置容器啟動和退出順序

本文介紹如何通過環境變量的方式,為一個ECI實例(即ECI Pod)內的各個容器設置啟動和退出優先級,實現容器按順序啟動和退出。

功能說明

默認情況下,ECI實例內的各個容器是并發進行啟動和退出的,沒有固定的前后順序。在某些場景下,一個實例內的多個容器之間可能存在依賴關系,某一容器需要在另一容器啟動后再啟動,或者某一容器需要在另一容器退出后再退出。例如:

  • istio服務治理場景,需要保證在業務容器產生流量時,istio-proxy容器已經Ready;在業務容器退出后,istio-proxy容器才退出。

  • 采集日志時,需要保證在業務容器產生日志前,日志容器已經Ready;在業務容器退出后,日志容器才退出。

針對上述場景,ECI支持通過設置容器環境變量的方式,為ECI實例內的容器設置啟動和退出優先級。您可以按照您的業務需求為容器添加相應的環境變量,來保證容器按順序啟動或按順序退出。

配置說明

設置容器啟動和退出順序的環境變量如下:

配置項

環境變量名稱

配置說明

容器啟動優先級

ECI_CONTAINER_LAUNCH_PRIORITY

  • 取值范圍為-1000~1000,默認值為0。數值越大,啟動優先級越高。

  • 優先級高的容器保證會在優先級低的容器啟動之前啟動,相同優先級的容器不保證啟動順序(并發啟動)。

  • 如果某容器依賴上一個容器提供服務,需要為容器配置Readiness Probe。例如:B容器依賴A容器提供服務,則在設置A容器的啟動優先級高于B容器的同時,還需要為A容器配置Readiness Probe,確保A容器準備就緒后才啟動B容器。

容器退出優先級

ECI_CONTAINER_EXIT_PRIORITY

  • 取值范圍為-1000~1000,默認值為0。數值越大,退出優先級越高。

  • 優先級高的容器保證會在優先級低的容器退出之前退出,相同優先級的容器不保證退出順序(并發退出)。

重要

設置容器退出順序后,Pod總體的銷毀時間可能會大于Pod Spec中TerminationGracePeriodSeconds聲明的時間。

配置示例

設置容器啟動順序

  1. 編寫應用的YAML配置文件,然后使用該YAML文件創建Deployment。

    kubectl apply -f test-launch.yaml

    test-launch.yaml的內容示例如下,表示創建一個包含1個Pod副本的Deployment。Pod內包含兩個容器,c1容器的啟動優先級高于c2容器,且c1容器配置了Readiness Probe,c2容器會在c1容器準備就緒后才啟動。

    apiVersion: apps/v1
    kind: Deployment
    metadata:
      name: test-launch
      labels:
        app: test
    spec:
      replicas: 1 
      selector:
        matchLabels:
          app: test
      template:
        metadata:
          labels:
            app: test
        spec:
          containers:
          - image: registry-vpc.cn-shanghai.aliyuncs.com/eci_open/nginx:alpine
            name: c1
            env:
            - name: ECI_CONTAINER_LAUNCH_PRIORITY
              value: "1000"
            readinessProbe:                  
              httpGet:
                path: /
                port: 80
              initialDelaySeconds: 30     
              periodSeconds: 3
          - image: registry-vpc.cn-shanghai.aliyuncs.com/eci_open/nginx:alpine
            name: c2
            env:
            - name: ECI_CONTAINER_LAUNCH_PRIORITY
              value: "0"
            args:
            - /bin/sh
            - -c
            - sleep 3600s
  2. 觀察Pod status中各個容器的啟動時間。

    kubectl describe pod <pod name>

    從返回信息的Containers中,可以看出c2容器的啟動時間晚于c1容器。示例如下:

    容器啟動k8s.png

設置容器退出順序

  1. 編寫應用的YAML配置文件,然后使用該YAML文件創建Deployment。

    kubectl apply -f test-exit.yaml

    test-exit.yaml的內容示例如下,表示創建一個包含1個Pod副本的Deployment。Pod內包含三個容器,退出優先級從高到低依次為c1、c2、c3。

    apiVersion: apps/v1
    kind: Deployment
    metadata:
      name: test-exit
      labels:
        app: test
    spec:
      replicas: 1 
      selector:
        matchLabels:
          app: test
      template:
        metadata:
          labels:
            app: test
        spec:
          containers:
          - image: registry-vpc.cn-shanghai.aliyuncs.com/eci_open/nginx:alpine
            name: c1
            env:
            - name: ECI_CONTAINER_EXIT_PRIORITY
              value: "1000"
          - image: registry-vpc.cn-shanghai.aliyuncs.com/eci_open/nginx:alpine
            name: c2
            env:
            - name: ECI_CONTAINER_EXIT_PRIORITY
              value: "0"
            args:
            - /bin/sh
            - -c
            - sleep 3600s
          - image: registry-vpc.cn-shanghai.aliyuncs.com/eci_open/nginx:alpine
            name: c3
            env:
            - name: ECI_CONTAINER_EXIT_PRIORITY
              value: "-1000"
            args:
            - /bin/sh
            - -c
            - sleep 3600s
  2. 刪除Pod,然后觀察Pod內容器Killing事件的順序。

    說明

    如果需要確認容器退出順序,請及時查看事件,Pod徹底刪除后可能無法觀察到相關事件。

    kubectl describe pod <pod name>

    從返回信息的Events中,可以看出容器退出順序依次為c1、c2、c3。示例如下:

    容器退出.png