kubernetes的存儲ConfigMap

kubernetes的存儲ConfigMap

標籤(空格分隔): kubernetes系列


  • 一: kubernetes的存儲ConfigMap

一:kubernetes的存儲

1.1 configMap 描述信息

ConfigMap 功能在 Kubernetes1.2 版本中引入,許多應用程序會從配置文件、命令行參數或環境變量中讀取配
置信息。ConfigMap API 給我們提供了向容器中注入配置信息的機制,ConfigMap 可以被用來保存單個屬性,也
可以用來保存整個配置文件或者 JSON 二進制大對象

配置中心:

image_1e2sbd27410d2q9p1s17fh1g5e9.png-171.8kB

image_1e2sbj9al12j771ci7sj081rs3m.png-71.3kB

1.1.1 configmap 的創建

1. 使用目錄創建

$ ls docs/user-guide/configmap/kubectl/
game.properties
ui.properties

$ cat docs/user-guide/configmap/kubectl/game.properties
enemies=aliens
lives=3
enemies.cheat=true
enemies.cheat.level=noGoodRotten
secret.code.passphrase=UUDDLRLRBABAS
secret.code.allowed=true
secret.code.lives=30

$ cat docs/user-guide/configmap/kubectl/ui.properties
color.good=purple
color.bad=yellow
allow.textmode=true
how.nice.to.look=fairlyNice

$ kubectl create configmap game-config --from-file=docs/user-guide/configmap/kubectl
mkdir configmap/dir -p 

cd configmap/dir/

vim game.properties
---
enemies=aliens
lives=3
enemies.cheat=true
enemies.cheat.level=noGoodRotten
secret.code.passphrase=UUDDLRLRBABAS
secret.code.allowed=true
secret.code.lives=30
---

vim ui.properties
---
color.good=purple
color.bad=yellow
allow.textmode=true
how.nice.to.look=fairlyNice
---
—from-file 指定在目錄下的所有文件都會被用在 ConfigMap 裏面創建一個鍵值對,鍵的名字就是文件名,值就
是文件的內容

kubectl create configmap game-config --from-file=../dir/

kubectl get cm game-config -o yaml

kubectl describe cm game-config

image_1e2sc97ne1lhg15c57k112kge5i1j.png-64.2kB

image_1e2scb81l113s9ag36jfne8ea20.png-145.8kB

image_1e2scfg2519h41a7t1u3abjn1hbp2d.png-104.6kB


1.1.2 使用文件創建

只要指定爲一個文件就可以從單個文件中創建 ConfigMap

kubectl create configmap game-config-2 --from-file=game.properties

kubectl describe cm game-config-2

kubectl get configmaps game-config-2 -o yaml

—from-file 這個參數可以使用多次,你可以使用兩次分別指定上個實例中的那兩個配置文件,效果就跟指定整個
目錄是一樣的

image_1e2t54mu2j4j13jrdip1lrg11s02q.png-136.4kB

image_1e2t55hfs8dfuitkd89uq1kh237.png-114kB


1.1.3 使用字面值創建

使用文字值創建,利用  —from-literal 參數傳遞配置信息,該參數可以使用多次,格式如下
kubectl create configmap special-config --from-literal=special.how=very --from-literal=special.type=charm

kubectl get cm 

kubectl get cm special-config -o yaml

image_1e2t5f66e1sii1fnn6c1rtp1tri3n.png-164.1kB

1.1.4 Pod 中使用 ConfigMap

使用 ConfigMap 來替代環境變量

apiVersion: v1
kind: ConfigMap
metadata:
  name: special-config
  namespace: default
data:
  special.how: very
  special.type: charm

----

----
vim  env.yaml

apiVersion: v1
kind: ConfigMap
metadata:
  name: env-config
  namespace: default
data:
  log_level: INFO

-----------
kubectl apply -f  env.yaml

vim evnpod.yaml

------
apiVersion: v1
kind: Pod
metadata:
  name: dapi-test-pod
spec:
  containers:
    - name: test-container
      image: wangyanglinux/myapp:v1
      command: [ "/bin/sh", "-c", "env" ]
      env:
        - name: SPECIAL_LEVEL_KEY
          valueFrom:
            configMapKeyRef:
              name: special-config
              key: special.how
        - name: SPECIAL_TYPE_KEY
          valueFrom:
            configMapKeyRef:
              name: special-config
              key: special.type
      envFrom:
       - configMapRef:
           name: env-config
  restartPolicy: Never

---

kubectl apply -f evnpod.yaml

image_1e2t8v21j59ulfur7s1kvg1joq44.png-60.7kB

image_1e2t904b2gto166d1i5nslaflh4h.png-179.5kB

1.1.5 用 ConfigMap 設置命令行參數

vim pod1.yaml
----
apiVersion: v1
kind: ConfigMap
metadata:
  name: special-config-1
  namespace: default
data:
  special.how: very
  special.type: charm
---
kubectl apply -f pod1.yaml

image_1e36nais81d7f10ph1tmkscsqu9.png-126kB


vim pod2.yaml

----
apiVersion: v1
kind: Pod
metadata:
  name: dapi-test-pod1
spec:
  containers:
    - name: test-container
      image: wangyanglinux/myapp:v1
      command: [ "/bin/sh", "-c", "echo $(SPECIAL_LEVEL_KEY) $(SPECIAL_TYPE_KEY)" ]
      env:
        - name: SPECIAL_LEVEL_KEY
          valueFrom:
            configMapKeyRef:
              name: special-config-1
              key: special.how
        - name: SPECIAL_TYPE_KEY
          valueFrom:
            configMapKeyRef:
              name: special-config-1
              key: special.type
  restartPolicy: Never

----
kubectl apply -f pod2.yaml

image_1e36ndu95u181fk4n1j2m21h5p16.png-150.7kB

1.1.6 通過數據卷插件使用ConfigMap

vim stoage1.yaml
---
apiVersion: v1
kind: ConfigMap
metadata:
  name: special-config-2
  namespace: default
data:
  special.how: very
  special.type: charm
---

kubectl apply -f stoage1.yaml

image_1e36nss82uudr5v5h119gpemk2t.png-195.4kB

在數據卷裏面使用這個 ConfigMap,有不同的選項。最基本的就是將文件填入數據卷,在這個文件中,鍵就是文
件名,鍵值就是文件內容

vim pod3.yaml
---

apiVersion: v1
kind: Pod
metadata:
  name: dapi-test-pod4
spec:
  containers:
    - name: test-container
      image: wangyanglinux/myapp:v1
      command: [ "/bin/sh", "-c", "sleep 600" ]
      volumeMounts:
      - name: config-volume
        mountPath: /etc/config
  volumes:
    - name: config-volume
      configMap:
        name: special-config-2
  restartPolicy: Never
---
kubectl apply -f pod3.yaml

image_1e36om2o910ms1b3u1v4h18hg5gs3a.png-145.2kB

1.1.7 ConfigMap 的熱更新

vim log-cm.yaml
---
apiVersion: v1
kind: ConfigMap
metadata:
  name: log-config
  namespace: default
data:
  log_level: INFO

---
kubectl apply -f log-cm.yaml

image_1e36oso8v1gcc1oga4cb1if91gqu3n.png-192.7kB


vim pod4.yaml
---
apiVersion: extensions/v1beta1
kind: Deployment
metadata:
  name: my-nginx
spec:
  replicas: 1
  template:
    metadata:
      labels:
        run: my-nginx
    spec:
       containers:
       - name: my-nginx
         image: wangyanglinux/myapp:v1
         ports:
         - containerPort: 80
         volumeMounts:
         - name: config-volume
           mountPath: /etc/config
       volumes:
         - name: config-volume
           configMap:
             name: log-config
---
kubectl apply -f pod4.yaml 

image_1e36pj5c110hs1asi3nu52o1kff4k.png-99.8kB

image_1e36pmu2d1pen3h8h3c1sicff851.png-108.2kB

修改  log_level 的值爲  DEBUG 等待大概 10 秒鐘時間,再次查看環境變量的值

將 log—level 改爲DEBUG 

kubectl edit cm log_config
---
log_level : DEBUG
---

kubectl exec my-nginx-c484b98b4-tgblg -ti -- cat /etc/config/log_level

image_1e36pt3k4gfdb9515g81ui81al45e.png-185.9kB

image_1e36pu2b7u2v1pjc1sfi19ue1c8k5r.png-122.5kB

ConfigMap 更新後滾動更新 Pod
更新 ConfigMap 目前並不會觸發相關 Pod 的滾動更新,可以通過修改 pod annotations 的方式強制觸發滾動更新
這個例子裏我們在  .spec.template.metadata.annotations 中添加  version/config ,每次通過修改
version/config 來觸發滾動更新

!!! 更新 ConfigMap 後:
使用該 ConfigMap 掛載的 Env 不會同步更新
使用該 ConfigMap 掛載的 Volume 中的數據需要一段時間(實測大概10秒)才能同步更新

kubectl patch deployment my-nginx --patch '{"spec": {"template": {"metadata": {"annotations":
{"version/config": "20190411" }}}}}

image_1e36qd38cnp71tqmasf5bu1f0v68.png-39.8kB

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章