Kubernetes---存储--configMap
configMap在k8s中,专门用来存储配置文件。
Secret,有一些需要加密的信息,例如密钥、用户名密码信息在Secret中可以被加密,是k8s中加密的解决方案【base64】。
Volume,用于赋予k8s中pod共享存储卷的能力,例如可以通过nfs共享,本地磁盘目录共享等等。
Persistent Volume,简称PV【持久卷】,还包含一个PVC,通过服务进行持久卷的构建。
⒈描述
ConfigMap功能在 Kubernetes1.2版本中引入,许多应用程序会从配置文件、命令行参数或环境变量中读取配置信息。ConfigMap API给我们提供了向容器中注入配置信息的机制,ConfigMap可以被用来保存单个属性,也可以用来保存整个配置文件或者JSON 二进制大对象。
⒉引用 - 配置文件注册中心
在集群中有一个配置文件注册中心,集群中的节点向配置中心索要属于自身的配置,配置中心根据各节点的主机名或ip地址进行分发配置。
⒊作用
k8s创建configMap,pod去引用,来达到类似于配置文件注册中心的效果
⒋创建方式【三种方式】
1.使用目录创建
1.查看目录文件清单
ls docs/user-guide/configmap/kubectl/
2.查看文件内容
cat docs/user-guide/configmap/kubectl/game.properties
3.使用目录创建configMap
kubectl create configmap game-config --from-file=docs/user-guide/configmap/kubectl
* game-config指创建的configMap的名称
--from-file 指定该目录下的所有文件都会被用在ConfigMap里面创建一个键值对,键的名字就是文件名,值就是对应文件的内容【K/V结构】
2.使用文件创建
从单一文件创建configMap,只要指定为一个文件就可以从单个文件中创建ConfigMap
和目录创建configMap的区别就是 --from-file 一个指定到了目录,一个指定到了单一的文件
1.创建
kubectl create configmap game-config-2 --from-file=docs/user- guide/configmap/kubectl/game.properties
3.使用字面值创建
使用文字值创建,利用 --from-literal 参数传递配置信息,该参数可以使用多次,格式如下
1.创建
kubectl create configmap special-config --from-literal=special. how=very --from-literal=special.type=charm
⒌相关命令
1.查看所有的configMap
kubectl get cm
2.查看指定的configMap的详细信息
kubectl get cm game-config -o yaml
kubectl describe cm game-config
⒍Pod中使用ConfigMap
1.使用ConfigMap来替代环境变量
1.创建两个ConfigMap
apiVersion: v1 kind: ConfigMap metadata: name: special-config namespace: default data: special.how: very special.type: charm
apiVersion: v1 kind: ConfigMap metadata: name: env-config namespace: default data: log_level: INFO
2.创建Pod并以ConfigMap作为环境变量
2.用ConfigMap设置命令行参数
1.创建ConfigMap
apiVersion: v1 kind: ConfigMap metadata: name: special-config namespace: default data: special.how: very special.type: charm
2.创建Pod
apiVersion: v1 kind: Pod metadata: name: dapi-test-pod spec: containers: - name: test-container image: hub.coreqi.cn/library/myapp:v1 command: [ "/bin/sh","-c", "echo $(SPECIAL_LEVEL_KEY) $(SPECIAL_TYPE_KEY)" ] 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 restartPolicy: Never
3.通过数据卷插件使用ConfigMap
1.创建ConfigMap
apiVersion: v1 kind: ConfigMap metadata: name: special-config namespace: default data: special.how: very special.type: charm
在数据卷里面使用这个ConfigMap,有不同的选项。最基本的就是将文件填入数据卷,在这个文件中,键就是文件名,键值就是文件内容
2.新建Pod
apiVersion: v1 kind: Pod metadata: name: dapi-test-pod spec: containers: - name: test-container image: hub.coreqi.cn/library/myapp:v1 command: [ "/bin/sh", "-c", "cat /etc/config/special.how" ] volumeMounts: - name: config-volume mountPath: /etc/config volumes: - name: config-volume configMap: name: special-config restartPolicy: Never
⒎ConfigMap的热更新
1.新建ConfigMap
apiVersion: v1 kind: ConfigMap metadata: name: log-config namespace: default data: log_level: INFO
2.新建Deployment控制器
apiVersion: extensions/v1beta1 kind: Deployment metadata: name: my-nginx spec: replicas: 1 template: metadata: labels: run: my-nginx spec: containers: - name: my-nginx image: hub.coreqi.cn/library/myapp:v1 ports: - containerPort: 80 volumeMounts: - name: config-volume mountPath: /etc/config volumes: - name: config-volume configMap: name: log-config
3.查看数据卷中ConfigMap的值
kubectl exec `kubectl get pods -l run=my-nginx -o=name|cut -d "/" -f2` cat /etc/config/log_level
4.修改ConfigMap的值【使用该命令打开yaml文件进行修改】
kubectl edit configmap log-config
5.修改Configmap的值后等待大约10秒钟的时候,再次查看环境变量的值
kubectl exec `kubectl get pods -l run=my-nginx -o=name|cut -d "/" -f2` cat /etc/config/log_level
**ConfigMap更新后,Pod并不会重载这个文件,更新 ConfigMap目前并不会触发相关Pod 的滚动更新,可以通过修改 pod annotations 的方式强制触发滚动更新
6.ConfigMap更新后滚动更新 Pod
kubectl patch deployment my-nginx --patch '{"spec": {"template": {"metadata": {"annotations": {"version/config": "20200430"}}}}}'