上次一起学习了Servie的使用,Service是Kubernetes系统中非常重要的一个核心概念,service的知识不可能一次就搞定了,在实践中我们继续学习吧。这次说说ConfigMap,它有点像springcloud的Spring Cloud Config。了解springcloud的老铁应该都知道,远程配置。
(一)ConfigMap
- ① 场景
做开发的时候,需要很多的配置参数,有环境变量相关的,有配置文件相关的,有命令行相关的,这些配置信息不应该写死在程序中,比如开发了一个springboot程序,需要连接一个mysql数据库,生产环境的数据库地址变了,重新修改代码,重新生成镜像,这种方式可以是可以,但是只是mysql数据库这个变动次数比较少,如果是一些配置类的,上午要变,下午也要变回去,用上边的重新生成镜像就不可取了。
而 ConfigMap 就给我们提供了向容器注入配置的能力,不应该只配置属性,还可以配置对应的配置文件。直接在ConfigMap 配置mysql的配置文件。老铁会说可以用挂载啊,如果几个容器挂载没有一点问题,如果多呢,几十个你都崩溃了。
- ② 官网
https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.15/#configmap-v1-core
- ③ 配置ConfigMap的yaml文件,添加属性的方式
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
- ④ 配置ConfigMap的yaml文件,添加配置文件的方式
查看创建的命令实例
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
- ⑤可以直接使用字符串进行创建,通过–from-literal参数传递配置信息,同样的,这个参数可以使用多次
kubectl create configmap cm-demo3 --from-literal=ip=localhost --from-literal=port=33061 kubectl get configmap kubectl describe configmap cm-demo3
- ⑥ 使用configmap 查看所有的环境变量
上边通过文件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
- ⑦ 使用configmap 查看打印某个变量
--- 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
- ⑧ 使用ConfigMap的方式:通过数据卷使用,在数据卷里面使用ConfigMap
创建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
- ⑨ 查看configmap的内部详情
kubectl get configmap cm-demo2 -o yaml
- ⑩ dashboard 查看配置字典
PS:ConfigMap是kubernetes的一个核心的概念,跟上次说的service一样,这个在实际的环境中使用很频繁。当ConfigMap以数据卷的形式挂载进Pod的时,这时更新ConfigMap(或删掉重建ConfigMap),Pod内挂载的配置信息会热更新。这时可以增加一些监测配置文件变更的脚本,然后reload对应服务。ConfigMap允许您将配置文件从容器镜像中解耦,从而增强容器应用的可移植性。
>>原创文章,欢迎转载。转载请注明:转载自,谢谢!>>原文链接地址:上一篇:
已是最新文章
原文
https://idig8.com/2019/08/28/zoujink8skubernetes1-15-1deconfigmap26/
本站部分文章源于互联网,本着传播知识、有益学习和研究的目的进行的转载,为网友免费提供。如有著作权人或出版方提出异议,本站将立即删除。如果您对文章转载有任何疑问请告之我们,以便我们及时纠正。PS:推荐一个微信公众号: askHarries 或者qq群:474807195,里面会分享一些资深架构师录制的视频录像:有Spring,MyBatis,Netty源码分析,高并发、高性能、分布式、微服务架构的原理,JVM性能优化这些成为架构师必备的知识体系。还能领取免费的学习资源,目前受益良多

转载请注明原文出处:Harries Blog™ » 「走进k8s」Kubernetes1.15.1的ConfigMap(26)