文章目录
-
- ConfigMap
-
- 介绍
- 创建configMap
-
- 使用目录创建
- 使用文件创建
- 使用字面值创建
- Pod中使用configMap
-
- 使用configMap代替环境变量
- 用 ConfigMap 设置命令行参数
- 通过数据卷插件使用ConfigMap
- ConfigMap热更新
该文档内容来源于尚硅谷K8S教学视频课件尚硅谷
仅用于知识整理,便于后续巩固复习,如有侵权,请联系本人删除
k8s中提供了几种存储类型,configMap,Secret,volume,persistent volume
ConfigMap
介绍
ConfigMap 功能在 Kubernetes1.2 版本中引入,**许多应用程序会从配置文件、命令行参数或环境变量中读取配 置信息。ConfigMap API 给我们提供了向容器中注入配置信息的机制,**ConfigMap 可以被用来保存单个属性,也 可以用来保存整个配置文件或者 JSON 二进制大对象。ConfigMap 允许你将配置文件与镜像文件分离,以使容器化的应用程序具有可移植性。
创建configMap
使用目录创建
$ 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
# 使用目录创建configMap
#—from-file 指定在目录下的所有文件都会被用在 ConfigMap 里面创建一个键值对,键的名字就是文件名,值就是文件的内容
$ kubectl create configmap game-config(configmap的名称,可以自定义) --from-file=docs/user-guide/configmap/kubectl
使用文件创建
只要指定为一个文件就可以从单个文件中创建 ConfigMap
#—from-file 这个参数可以使用多次,你可以使用两次分别指定上个实例中的那两个配置文件,效果就跟指定整个目录是一样的$ kubectl create configmap game-config-2 --from-file=docs/userguide/configmap/kubectl/game.properties$ kubectl get configmaps game-config-2 -o yaml
使用字面值创建
使用文字值创建,利用 —from-literal 参数传递配置信息,该参数可以使用多次,格式如下
$ kubectl create configmap special-config --from-literal=special.how=very --fromliteral=special.type=charm$ kubectl get configmaps special-config -o yaml
Pod中使用configMap
使用configMap代替环境变量
apiVersion: v1
kind: ConfigMap
metadata:name: special-confignamespace: default
data:special.how: veryspecial.type: charm
---
apiVersion: v1
kind: ConfigMap
metadata:name: env-confignamespace: default
data:log_level: INFO
---
apiVersion: v1
kind: Pod
metadata:name: dapi-test-pod
spec:containers:- name: test-containerimage: hub.atguigu.com/library/myapp:v1command: [ "/bin/sh", "-c", "env" ]env:- name: SPECIAL_LEVEL_KEYvalueFrom:configMapKeyRef:name: special-configkey: special.how- name: SPECIAL_TYPE_KEYvalueFrom:configMapKeyRef:name: special-configkey: special.typeenvFrom:- configMapRef:name: env-configrestartPolicy: Never
用 ConfigMap 设置命令行参数
apiVersion: v1
kind: ConfigMap
metadata:name: special-confignamespace: default
data:special.how: veryspecial.type: charm
---
apiVersion: v1
kind: Pod
metadata:name: dapi-test-pod
spec:containers:- name: test-containerimage: hub.atguigu.com/library/myapp:v1command: [ "/bin/sh", "-c", "echo $(SPECIAL_LEVEL_KEY) $(SPECIAL_TYPE_KEY)" ]env:- name: SPECIAL_LEVEL_KEYvalueFrom:configMapKeyRef:name: special-configkey: special.how- name: SPECIAL_TYPE_KEYvalueFrom:configMapKeyRef:name: special-configkey: special.typerestartPolicy: Never
通过数据卷插件使用ConfigMap
apiVersion: v1
kind: ConfigMap
metadata:name: special-confignamespace: default
data:special.how: veryspecial.type: charm
---
#在数据卷里面使用这个 ConfigMap,有不同的选项。最基本的就是将ConfigMap文件填入数据卷,把configMap中的所有key挂载为一个单独的文件,文件名就是key值,这些文件中的内容就是这个key所对应的value
apiVersion: v1
kind: Pod
metadata:name: dapi-test-pod
spec:containers:- name: test-containerimage: hub.atguigu.com/library/myapp:v1command: [ "/bin/sh", "-c", "cat /etc/config/special.how" ]volumeMounts:- name: config-volumemountPath: /etc/configvolumes:- name: config-volumeconfigMap:name: special-configrestartPolicy: Never
ConfigMap热更新
apiVersion: v1
kind: ConfigMap
metadata:name: log-confignamespace: default
data:log_level: INFO
---
apiVersion: extensions/v1beta1
kind: Deployment
metadata:name: my-nginx
spec:replicas: 1template:metadata:labels:run: my-nginxspec:containers:- name: my-nginximage: hub.atguigu.com/library/myapp:v1ports:- containerPort: 80volumeMounts:- name: config-volumemountPath: /etc/configvolumes:- name: config-volumeconfigMap:name: log-config
# 执行操作后,在/etc/config路径下有一个名为log_level文件,文件内容为INFO
# `kubectl get pods -l run=my-nginx -o=name|cut -d "/" -f2`
#这个命令实际上就是找到之前创建的deployment 然后-it -- 调出tty交互
$ kubectl exec `kubectl get pods -l run=my-nginx -o=name|cut -d "/" -f2` cat
/etc/config/log_level
INFO
修改 ConfigMap
$ kubectl edit configmap log-config
修改 log_level 的值为 DEBUG 等待大概 10 秒钟时间,再次查看环境变量的值
# `kubectl get pods -l run=my-nginx -o=name|cut -d "/" -f2`
#这个命令实际上就是找到之前创建的deployment 然后-it -- 调出tty交互
$ kubectl exec `kubectl get pods -l run=my-nginx -o=name|cut -d "/" -f2` cat /etc/config/log_level
DEBUG
ConfigMap 更新后滚动更新 Pod
更新 ConfigMap 目前并不会触发相关 Pod 的滚动更新,可以通过修改 pod annotations 的方式强制触发滚动更新
#在 .spec.template.metadata.annotations 中添加 version/config ,每次通过修改 version/config 来触发滚动更新
# 20190411是一个自定义时间,
kubectl patch deployment my-nginx --patch '{"spec": {"template": {"metadata": {"annotations": {"version/config": "20190411" }}}}}'