上次一起学习了Servie的使用,Service是Kubernetes系统中非常重要的一个核心概念,service的知识不可能一次就搞定了,在实践中我们继续学习吧。这次说说ConfigMap,它有点像springcloud的Spring Cloud Config。了解springcloud的老铁应该都知道,远程配置。
做开发的时候,需要很多的配置参数,有环境变量相关的,有配置文件相关的,有命令行相关的,这些配置信息不应该写死在程序中,比如开发了一个springboot程序,需要连接一个mysql数据库,生产环境的数据库地址变了,重新修改代码,重新生成镜像,这种方式可以是可以,但是只是mysql数据库这个变动次数比较少,如果是一些配置类的,上午要变,下午也要变回去,用上边的重新生成镜像就不可取了。 而 ConfigMap 就给我们提供了向容器注入配置的能力,不应该只配置属性,还可以配置对应的配置文件。直接在ConfigMap 配置mysql的配置文件。老铁会说可以用挂载啊,如果几个容器挂载没有一点问题,如果多呢,几十个你都崩溃了。
https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.15/#configmap-v1-core
configMap.yaml
kind: ConfigMap
apiVersion: v1
metadata:
name: cm-demo
namespace: default
data:
data.1: hello
data.2: world
config: |
property.1=value-1
property.2=value-2
property.3=value-3
kubectl create -f configMap.yaml
kubectl get configMap
kubectl describe configmap cm-demo
查看创建的命令实例
kubectl create configmap -h
mkdir testcm
cd testcm
vi mysql.conf
#ip=127.0.0.1
#port=3306
vi redis.conf
#ip=127.0.0.1
#port=6379
使用from-file关键字来创建包含这个目录下面所以配置文件的ConfigMap
cd ~
kubectl create configmap cm-demo2 --from-file=testcm
kubectl get configmap
kubectl describe configmap cm-demo2
kubectl create configmap cm-demo3 --from-literal=ip=localhost --from-literal=port=33061
kubectl get configmap
kubectl describe configmap cm-demo3
上边通过文件yaml配置,扫描指定的包,参数的方式 创建了 configmap,下面说说如何进行配置。
---
apiVersion: v1
kind: Pod
metadata:
name: testcm1-pod
spec:
containers:
- name: testcm1
image: busybox
command: [ "/bin/sh", "-c", "env" ]
env:
- name: DB_HOST
valueFrom:
configMapKeyRef:
name: cm-demo3
key: ip
- name: DB_PORT
valueFrom:
configMapKeyRef:
name: cm-demo3
key: ip
envFrom:
- configMapRef:
name: cm-demo
运行上边的pod
kubectl apply -f testcm1.yaml
执行完毕后,pod自动退出
kubectl describe pod testcm1-pod
kubectl logs testcm1-pod
---
apiVersion: v1
kind: Pod
metadata:
name: testcm2-pod
spec:
containers:
- name: testcm2
image: busybox
command: [ "/bin/sh", "-c", "echo $(DB_HOST) $(DB_PORT) " ]
env:
- name: DB_HOST
valueFrom:
configMapKeyRef:
name: cm-demo3
key: ip
- name: DB_PORT
valueFrom:
configMapKeyRef:
name: cm-demo3
key: port
envFrom:
- configMapRef:
name: cm-demo
执行查看,看到DBHOST和DBPORT都已经打印出来了。
kubectl apply -f testcm2.yaml
kubectl logs testcm2-pod
kubectl describe pod testcm2-pod
创建pod文件
apiVersion: v1
kind: Pod
metadata:
name: testcm3-pod
spec:
containers:
- name: testcm3
image: busybox
command: [ "/bin/sh", "-c", "cat /etc/config/redis.conf" ]
volumeMounts:
- name: config-volume
mountPath: /etc/config
volumes:
- name: config-volume
configMap:
name: cm-demo2
运行pod,查看log
kubectl apply -f testcm3-pod.yaml
kubectl logs testcm3-pod
kubectl get configmap cm-demo2 -o yaml
PS:ConfigMap是kubernetes的一个核心的概念,跟上次说的service一样,这个在实际的环境中使用很频繁。当ConfigMap以数据卷的形式挂载进Pod的时,这时更新ConfigMap(或删掉重建ConfigMap),Pod内挂载的配置信息会热更新。这时可以增加一些监测配置文件变更的脚本,然后reload对应服务。ConfigMap允许您将配置文件从容器镜像中解耦,从而增强容器应用的可移植性。