bl双性强迫侵犯h_国产在线观看人成激情视频_蜜芽188_被诱拐的少孩全彩啪啪漫画

kubernetes實踐之三十五:Pod配置管理ConfigMap

一:簡介
很多生產環境中的應用程序配置較為復雜,可能需要多個config文件、命令行參數和環境變量的組合。使用容器部署時,把配置應該從應用程序鏡像中解耦出來,以保證鏡像的可移植性。

ConfigMap是用來存儲配置文件的kubernetes資源對象,所有的配置內容都存儲在etcd中。ConfigMap讓我們能夠從容器鏡像中把配置的詳細信息給解耦出來。通過ConfigMap我們能夠把配置以key-value對的形式傳遞到container或者別的系統組件(比如Controller)里面。
二:ConfigMap的創建方式
1.From Literal Values   可以用kubectl create來創建一個ConfigMap,然后通過kubectl get來獲取

點擊(此處)折疊或打開

網站建設哪家好,找創新互聯公司!專注于網頁設計、網站建設、微信開發、微信小程序定制開發、集團企業網站建設等服務項目。為回饋新老客戶創新互聯還提供了南沙免費建站歡迎大家使用!

  1. # Create the ConfigMap
  2. $ kubectl create configmap my-config --from-literal=key1=value1 --from-literal=key2=value2
  3. configmap"my-config" created

  4. # Get the ConfigMap Details for my-config
  5. $ kubectl get configmaps my-config -o yaml
  6. apiVersion: v1
  7. data:
  8.   key1: value1
  9.   key2: value2
  10. kind: ConfigMap
  11. metadata:
  12.   creationTimestamp: 2017-05-31T07:21:55Z
  13.   name: my-config
  14.   namespace: default
  15.   resourceVersion: "241345"
  16.   selfLink: /api/v1/namespaces/default/configmaps/my-config
  17.   uid: d35f0a3d-45d1-11e7-9e62-080027a46057
2.From Configuration File 直接通過配置文件來創建

點擊(此處)折疊或打開

  1. apiVersion: v1
  2. kind: ConfigMap
  3. metadata:
  4.   name: special-config
  5.   namespace: default
  6. data:
  7.   special.how: very

點擊(此處)折疊或打開

  1. apiVersion: v1
  2. kind: ConfigMap
  3. metadata:
  4.   name: env-config
  5.   namespace: default
  6. data:
  7.   log_level: INFO
3. 當前目錄下包含如果有配置文件donkey.properties   可以通過kubectl命令創建一個包含該文件內容的ConfigMap

kubectl  create configmap donkey.properties --from-file=donkey.properties

三:ConfigMap的使用方式

1.Pod 通過env使用ConfigMap定義環境變量

點擊(此處)折疊或打開

  1. apiVersion: v1
  2. kind: Pod
  3. metadata:
  4.   name: dapi-test-pod
  5. spec:
  6.   containers:
  7.     - name: test-container
  8.       image: gcr.io/google_containers/busybox
  9.       command: ["/bin/sh", "-c", "env" ]
  10.       env:
  11.         - name: SPECIAL_LEVEL_KEY
  12.           valueFrom:
  13.             configMapKeyRef:
  14.               name: special-config
  15.               key: special.how
  16.         - name: LOG_LEVEL
  17.           valueFrom:
  18.             configMapKeyRef:
  19.               name: env-config
  20.               key: log_level
  21.   restartPolicy: Never
從Kubernetes V1.6 開始,引入一個新的字段envFrom,實現在Pod環境內將ConfigMap中所以定義的key=value自動生成環境變量:

點擊(此處)折疊或打開

  1. apiVersion: v1
  2. kind: Pod
  3. metadata:
  4.   name: dapi-test-pod
  5. spec:
  6.   containers:
  7.     - name: test-container
  8.       image: gcr.io/google_containers/busybox
  9.       command: [ "/bin/sh", "-c", "env" ]
  10.       envFrom:
  11.       - configMapRef:
  12.          name: special-config
  13.   restartPolicy: Never


2.使用ConfigMap設置容器啟動命令的啟動參數

點擊(此處)折疊或打開

  1. apiVersion: v1
  2. kind: Pod
  3. metadata:
  4.   name: dapi-test-pod
  5. spec:
  6.   containers:
  7.     - name: test-container
  8.       image: k8s.gcr.io/busybox
  9.       command: ["/bin/sh", "-c", "echo $(SPECIAL_LEVEL_KEY) $(SPECIAL_TYPE_KEY)" ]
  10.       env:
  11.         - name: SPECIAL_LEVEL_KEY
  12.           valueFrom:
  13.             configMapKeyRef:
  14.               name: special-config
  15.               key: SPECIAL_LEVEL
  16.         - name: SPECIAL_TYPE_KEY
  17.           valueFrom:
  18.             configMapKeyRef:
  19.               name: special-config
  20.               key: SPECIAL_TYPE
  21.   restartPolicy: Never
3.在存儲卷中使用ConfigMap

點擊(此處)折疊或打開

  1. apiVersion: v1
    kind: Pod
    metadata:
      name: busybox
      namespace: default
    spec:
      containers:
      - image: 120.79.156.135/desktop/busybox:latest
        command:
          - sleep
          - "3600"
        imagePullPolicy: IfNotPresent
        name: busybox
        volumeMounts:
        -  name: donkeyconfig
           mountPath: /configfiles
      volumes: 
      -  name: donkeyconfig
         configMap:
            name: donkey.properties
            items: 
            -  key: donkey.properties
               path: donkey.properties
      restartPolicy: Always
      imagePullSecrets:
      - name: registry-secret
四:使用ConfigMap的限制條件
1.ConfigMap必須在Pod之前創建
2.ConfigMap受Namespace限制,只有處于相同Namespaces中的Pod可以引用它
3.ConfigMap 中的配額管理還未能實現
4.kubelet只支持可以被API Server管理的Pod使用ConfigMap

新聞名稱:kubernetes實踐之三十五:Pod配置管理ConfigMap
新聞來源:http://vcdvsql.cn/article48/pepghp.html

成都網站建設公司_創新互聯,為您提供云服務器、做網站、建站公司、微信公眾號動態網站外貿建站

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

商城網站建設