上次一起学习了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
执行查看,看到DB_HOST和DB_PORT都已经打印出来了。
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允许您将配置文件从容器镜像中解耦,从而增强容器应用的可移植性。
>>原创文章,欢迎转载。转载请注明:转载自,谢谢!>>原文链接地址:上一篇:已是最新文章