[关闭]
@zhangyy 2020-03-23T22:31:46.000000Z 字数 4551 阅读 197

kubernetes的存储ConfigMap

kubernetes系列


  • 一: kubernetes的存储ConfigMap

一:kubernetes的存储

1.1 configMap 描述信息

  1. ConfigMap 功能在 Kubernetes1.2 版本中引入,许多应用程序会从配置文件、命令行参数或环境变量中读取配
  2. 置信息。ConfigMap API 给我们提供了向容器中注入配置信息的机制,ConfigMap 可以被用来保存单个属性,也
  3. 可以用来保存整个配置文件或者 JSON 二进制大对象

  1. 配置中心:

image_1e2sbd27410d2q9p1s17fh1g5e9.png-171.8kB

image_1e2sbj9al12j771ci7sj081rs3m.png-71.3kB

1.1.1 configmap 的创建

  1. 1. 使用目录创建
  2. $ ls docs/user-guide/configmap/kubectl/
  3. game.properties
  4. ui.properties
  5. $ cat docs/user-guide/configmap/kubectl/game.properties
  6. enemies=aliens
  7. lives=3
  8. enemies.cheat=true
  9. enemies.cheat.level=noGoodRotten
  10. secret.code.passphrase=UUDDLRLRBABAS
  11. secret.code.allowed=true
  12. secret.code.lives=30
  13. $ cat docs/user-guide/configmap/kubectl/ui.properties
  14. color.good=purple
  15. color.bad=yellow
  16. allow.textmode=true
  17. how.nice.to.look=fairlyNice
  18. $ kubectl create configmap game-config --from-file=docs/user-guide/configmap/kubectl
  1. mkdir configmap/dir -p
  2. cd configmap/dir/
  3. vim game.properties
  4. ---
  5. enemies=aliens
  6. lives=3
  7. enemies.cheat=true
  8. enemies.cheat.level=noGoodRotten
  9. secret.code.passphrase=UUDDLRLRBABAS
  10. secret.code.allowed=true
  11. secret.code.lives=30
  12. ---
  13. vim ui.properties
  14. ---
  15. color.good=purple
  16. color.bad=yellow
  17. allow.textmode=true
  18. how.nice.to.look=fairlyNice
  19. ---
  20. from-file 指定在目录下的所有文件都会被用在 ConfigMap 里面创建一个键值对,键的名字就是文件名,值就
  21. 是文件的内容
  22. kubectl create configmap game-config --from-file=../dir/
  23. kubectl get cm game-config -o yaml
  24. kubectl describe cm game-config

image_1e2sc97ne1lhg15c57k112kge5i1j.png-64.2kB

image_1e2scb81l113s9ag36jfne8ea20.png-145.8kB

image_1e2scfg2519h41a7t1u3abjn1hbp2d.png-104.6kB


1.1.2 使用文件创建

  1. 只要指定为一个文件就可以从单个文件中创建 ConfigMap
  2. kubectl create configmap game-config-2 --from-file=game.properties
  3. kubectl describe cm game-config-2
  4. kubectl get configmaps game-config-2 -o yaml
  5. from-file 这个参数可以使用多次,你可以使用两次分别指定上个实例中的那两个配置文件,效果就跟指定整个
  6. 目录是一样的

image_1e2t54mu2j4j13jrdip1lrg11s02q.png-136.4kB

image_1e2t55hfs8dfuitkd89uq1kh237.png-114kB


1.1.3 使用字面值创建

  1. 使用文字值创建,利用 from-literal 参数传递配置信息,该参数可以使用多次,格式如下
  2. kubectl create configmap special-config --from-literal=special.how=very --from-literal=special.type=charm
  3. kubectl get cm
  4. kubectl get cm special-config -o yaml

image_1e2t5f66e1sii1fnn6c1rtp1tri3n.png-164.1kB

1.1.4 Pod 中使用 ConfigMap

  1. 使用 ConfigMap 来替代环境变量
  2. apiVersion: v1
  3. kind: ConfigMap
  4. metadata:
  5. name: special-config
  6. namespace: default
  7. data:
  8. special.how: very
  9. special.type: charm
  10. ----
  11. ----
  12. vim env.yaml
  13. apiVersion: v1
  14. kind: ConfigMap
  15. metadata:
  16. name: env-config
  17. namespace: default
  18. data:
  19. log_level: INFO
  20. -----------
  21. kubectl apply -f env.yaml

  1. vim evnpod.yaml
  2. ------
  3. apiVersion: v1
  4. kind: Pod
  5. metadata:
  6. name: dapi-test-pod
  7. spec:
  8. containers:
  9. - name: test-container
  10. image: wangyanglinux/myapp:v1
  11. command: [ "/bin/sh", "-c", "env" ]
  12. env:
  13. - name: SPECIAL_LEVEL_KEY
  14. valueFrom:
  15. configMapKeyRef:
  16. name: special-config
  17. key: special.how
  18. - name: SPECIAL_TYPE_KEY
  19. valueFrom:
  20. configMapKeyRef:
  21. name: special-config
  22. key: special.type
  23. envFrom:
  24. - configMapRef:
  25. name: env-config
  26. restartPolicy: Never
  27. ---
  28. kubectl apply -f evnpod.yaml

image_1e2t8v21j59ulfur7s1kvg1joq44.png-60.7kB

image_1e2t904b2gto166d1i5nslaflh4h.png-179.5kB

1.1.5 用 ConfigMap 设置命令行参数

  1. vim pod1.yaml
  2. ----
  3. apiVersion: v1
  4. kind: ConfigMap
  5. metadata:
  6. name: special-config-1
  7. namespace: default
  8. data:
  9. special.how: very
  10. special.type: charm
  11. ---
  12. kubectl apply -f pod1.yaml

image_1e36nais81d7f10ph1tmkscsqu9.png-126kB


  1. vim pod2.yaml
  2. ----
  3. apiVersion: v1
  4. kind: Pod
  5. metadata:
  6. name: dapi-test-pod1
  7. spec:
  8. containers:
  9. - name: test-container
  10. image: wangyanglinux/myapp:v1
  11. command: [ "/bin/sh", "-c", "echo $(SPECIAL_LEVEL_KEY) $(SPECIAL_TYPE_KEY)" ]
  12. env:
  13. - name: SPECIAL_LEVEL_KEY
  14. valueFrom:
  15. configMapKeyRef:
  16. name: special-config-1
  17. key: special.how
  18. - name: SPECIAL_TYPE_KEY
  19. valueFrom:
  20. configMapKeyRef:
  21. name: special-config-1
  22. key: special.type
  23. restartPolicy: Never
  24. ----
  25. kubectl apply -f pod2.yaml

image_1e36ndu95u181fk4n1j2m21h5p16.png-150.7kB

1.1.6 通过数据卷插件使用ConfigMap

  1. vim stoage1.yaml
  2. ---
  3. apiVersion: v1
  4. kind: ConfigMap
  5. metadata:
  6. name: special-config-2
  7. namespace: default
  8. data:
  9. special.how: very
  10. special.type: charm
  11. ---
  12. kubectl apply -f stoage1.yaml

image_1e36nss82uudr5v5h119gpemk2t.png-195.4kB

  1. 在数据卷里面使用这个 ConfigMap,有不同的选项。最基本的就是将文件填入数据卷,在这个文件中,键就是文
  2. 件名,键值就是文件内容
  3. vim pod3.yaml
  4. ---
  5. apiVersion: v1
  6. kind: Pod
  7. metadata:
  8. name: dapi-test-pod4
  9. spec:
  10. containers:
  11. - name: test-container
  12. image: wangyanglinux/myapp:v1
  13. command: [ "/bin/sh", "-c", "sleep 600" ]
  14. volumeMounts:
  15. - name: config-volume
  16. mountPath: /etc/config
  17. volumes:
  18. - name: config-volume
  19. configMap:
  20. name: special-config-2
  21. restartPolicy: Never
  22. ---
  23. kubectl apply -f pod3.yaml

image_1e36om2o910ms1b3u1v4h18hg5gs3a.png-145.2kB

1.1.7 ConfigMap 的热更新

  1. vim log-cm.yaml
  2. ---
  3. apiVersion: v1
  4. kind: ConfigMap
  5. metadata:
  6. name: log-config
  7. namespace: default
  8. data:
  9. log_level: INFO
  10. ---
  11. kubectl apply -f log-cm.yaml

image_1e36oso8v1gcc1oga4cb1if91gqu3n.png-192.7kB

  1. vim pod4.yaml
  2. ---
  3. apiVersion: extensions/v1beta1
  4. kind: Deployment
  5. metadata:
  6. name: my-nginx
  7. spec:
  8. replicas: 1
  9. template:
  10. metadata:
  11. labels:
  12. run: my-nginx
  13. spec:
  14. containers:
  15. - name: my-nginx
  16. image: wangyanglinux/myapp:v1
  17. ports:
  18. - containerPort: 80
  19. volumeMounts:
  20. - name: config-volume
  21. mountPath: /etc/config
  22. volumes:
  23. - name: config-volume
  24. configMap:
  25. name: log-config
  26. ---
  27. kubectl apply -f pod4.yaml

image_1e36pj5c110hs1asi3nu52o1kff4k.png-99.8kB

image_1e36pmu2d1pen3h8h3c1sicff851.png-108.2kB

  1. 修改 log_level 的值为 DEBUG 等待大概 10 秒钟时间,再次查看环境变量的值
  2. loglevel 改为DEBUG
  3. kubectl edit cm log_config
  4. ---
  5. log_level : DEBUG
  6. ---
  7. kubectl exec my-nginx-c484b98b4-tgblg -ti -- cat /etc/config/log_level

image_1e36pt3k4gfdb9515g81ui81al45e.png-185.9kB

image_1e36pu2b7u2v1pjc1sfi19ue1c8k5r.png-122.5kB

  1. ConfigMap 更新后滚动更新 Pod
  2. 更新 ConfigMap 目前并不会触发相关 Pod 的滚动更新,可以通过修改 pod annotations 的方式强制触发滚动更新
  3. 这个例子里我们在 .spec.template.metadata.annotations 中添加 version/config ,每次通过修改
  4. version/config 来触发滚动更新
  5. !!! 更新 ConfigMap 后:
  6. 使用该 ConfigMap 挂载的 Env 不会同步更新
  7. 使用该 ConfigMap 挂载的 Volume 中的数据需要一段时间(实测大概10秒)才能同步更新
  8. kubectl patch deployment my-nginx --patch '{"spec": {"template": {"metadata": {"annotations":
  9. {"version/config": "20190411" }}}}}

image_1e36qd38cnp71tqmasf5bu1f0v68.png-39.8kB

添加新批注
在作者公开此批注前,只有你和作者可见。
回复批注