「走进k8s」Kubernetes1.15.1的ConfigMap(26)

上次一起学习了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允许您将配置文件从容器镜像中解耦,从而增强容器应用的可移植性。

>>原创文章,欢迎转载。转载请注明:转载自IT人故事会,谢谢!
>>原文链接地址:「走进k8s」Kubernetes1.15.1的ConfigMap(26)
上一篇: 下一篇:

发表评论

电子邮件地址不会被公开。 必填项已用*标注