Kubernetes ConfigMap

[TOC]


ConfigMap 介绍

在Kubernetes 1.2中新添加了功能ConfigMap,主要功能是为了解决应用程序会从配置文件、环境变量中获取配置信息。但是默认情况下配置信息需要与docker images解耦,ConfigMap API为我们提供了向容器中注入配置信息的机制,ConfigMap可以被用来保存单个属性,也可以用来保存整个配置文件或者JSON二进制对象

ConfigMap API资源用来保存key-vlaue pair配置数据,这个数据可以在pods里使用,或者被用来为contaroller一样的系统组件存储配置数据。ConfigMap 是为了方便的处理不含铭感信息的字符串,你可以将它理解为Linux系统中的/etc目录,专门用来存储配置文件的目录

注意: ConfigMap不是属性配置文件的代替品,ConfigMap只是作为多个properties文件的引用。


ConfigMap 项目演示

configmap主要还是方便处理非敏感的数据,比如注册中心地址、数据库地址、nginx地址等。像密码之类需要加密的还是需要使用secrets来进行管理

下方yaml文件中data一栏包括了配置数据,ConfigMap可以保存单个属性,也可以用来保存一个配置文件。配置数据可以通过很多种方式在Pods里被引用,ConfigMap可以用来:

  • 设置环境变量的值
  • 在容器里设置命令行参数
  • 在数据卷里面创建config文件

用户和系统两者都可以在ConfigMap里存储


1. 使用Yaml文件创建ConfigMap

说明 configmap支持单个key-value键值,也支持config文件的方式

单个环境变量引用

apiVersion: v1
kind: ConfigMap
metadata:
  name: configmap-demo
data:
  data1: hello
  data2: test

#其中这里data1=hello,类似于环境变量 (如果是数字需要添加双引号)

配置文件变量引用 比如我们需要创建多个环境变量,这里可以直接引用配置文件的方式

apiVersion: v1
kind: ConfigMap
metadata:
  name: configmap-demo
data:
  config: |                 ###这里是文件名称
    zuul_host=123456    #变量名称及值
    zuul_port=123
    mysql_url=456

下面进行创建文件演示

#编辑配置文件
---
apiVersion: v1
kind: ConfigMap
metadata:
  name: configmap-demo
data:
  config: |      
    zuul_host=123456   
    zuul_port=123
    mysql_url=456




#创建configmap
[root@abcdocker yaml]# kubectl apply -f configmap.yaml
configmap/configmap-demo created
[root@yzsjhl82-135 yaml]# kubectl get configmap
NAME              DATA   AGE
configmap-demo    1      6s

#这里可以看到DATA位1,说明只有一个文件

[root@abcdocker yaml]# kubectl describe configmap configmap-demo
Name:         configmap-demo
Namespace:    default
Labels:       <none>
Annotations:  kubectl.kubernetes.io/last-applied-configuration:
                {"apiVersion":"v1","data":{"config":"zuul_host=123456   \nzuul_port=123\nmysql_url=456\n"},"kind":"ConfigMap","metadata":{"annotations":{}...

Data
====
config:
----
zuul_host=123456
zuul_port=123
mysql_url=456

Events:  <none>

2.使用kubectl创建

#创建的帮助,下面有创建的方法以及例子

[root@abcdocker yaml]# kubectl create configmap -h


Examples:
  # Create a new configmap named my-config based on folder bar
  kubectl create configmap my-config --from-file=path/to/bar

  # Create a new configmap named my-config with specified keys instead of file basenames on disk
  kubectl create configmap my-config --from-file=key1=/path/to/bar/file1.txt --from-file=key2=/path/to/bar/file2.txt

  # Create a new configmap named my-config with key1=config1 and key2=config2
  kubectl create configmap my-config --from-literal=key1=config1 --from-literal=key2=config2

  # Create a new configmap named my-config from the key=value pairs in the file
  kubectl create configmap my-config --from-file=path/to/bar

  # Create a new configmap named my-config from an env file
  kubectl create configmap my-config --from-env-file=path/to/bar.env

这里我模拟挂载test目录下的2个文件

#当前目录结构
[root@abcdocker~]# ll test/
总用量 8
-rw-r--r-- 1 root root 21 11月 19 20:43 mysql.conf
-rw-r--r-- 1 root root 21 11月 19 20:44 nginx.conf

#创建configmap
[root@abcdocker ~]# kubectl create configmap cm-demo-test --from-file=test
configmap/cm-demo-test created
#后面--from-file接的是目录,也可以是文件

#创建完毕后我们进行查看
[root@abcdocker ~]# kubectl get configmap
NAME             DATA   AGE
cm-demo-test     2      13s
configmap-demo   3      16m
[root@abcdocker ~]# kubectl describe configmap cm-demo-test
Name:         cm-demo-test
Namespace:    default
Labels:       <none>
Annotations:  <none>

Data
====
mysql.conf:
----
mysql_url=10.4.82.11

nginx.conf:
----
nginx_url=10.4.11.11

Events:  <none>

#也可以使用命令行创建单个
kubectl create configmap cm-name --from-literal=abc.host=localhost --from-literal=aaa.port=80

#--from-literal支持引用多个

温馨提示:使用describe的时候,配置文件如果过大,不会完全显示,如果要查看详细信息需要使用kubectl get configmap [cm-name] -o yaml使用yaml展示(输出格式也可以修改为json)


3.使用环境变量引用configmap

引用单个环境变量

首先创建configmap

apiVersion: v1
kind: ConfigMap
metadata:
  name: configmap-demo
  namespace: default
data:
  db.host: localhost
  db.port: "3306"

创建Pod进行引用

apiVersion: v1
kind: Pod
metadata:
  name: test-demo-configmap
spec:
  containers:
    - name: test-demo-cm
      image: busybox
      command: [ "/bin/sh","-c","env" ]
      env:                      #引用环境变量
        - name: ZUUL_HOST       #环境变量值 (这个值可以与下面configmap key中不相同)
          valueFrom:            #环境变量值来源
             configMapKeyRef:   #使用configmap值
               name: configmap-demo    #configmap 名称
               key: db.host     #configmap中的值

检查结果

[root@abcdocker yaml]# kubectl get pod
NAME                  READY   STATUS      RESTARTS   AGE
test-demo-configmap   0/1     Completed   2          48s
[root@yzsjhl82-135 yaml]# kubectl logs test-demo-configmap
HOSTNAME=test-demo-configmap
ZUUL_HOST=localhost
...

#这里我将原来是db.host变量修改为ZUUL_HOST变量等于

引用文件,不定义key

另外的一种写法,直接引用变量,不自定义Key,主要是用于引用文件,可以使用这种方式

##yaml文件如下
apiVersion: v1
kind: Pod
metadata:
  name: test-demo-configmap-file
spec:
  containers:
    - name: test-demo-cm
      image: busybox
      command: [ "/bin/sh","-c","env" ]
      envFrom:                  #引用文件作为环境变量
      - configMapRef:             #configmap来源
        name: configmap-demo        #configmap名称

####直接创建就可以,这里就是将configmap里面的值全部引用进来


## 查看日志
[root@yzsjhl82-135 yaml]# kubectl logs test-demo-configmap-file
...
db.host=localhost
db.port=3306
...

4.通过命令引用configmap

在configmap里面支持命令引用变量的方式

#这里还是拿之前的configmap举例
apiVersion: v1
kind: Pod
metadata:
  name: test-demo-configmap-env
spec:
  containers:
    - name: test-demo-cm
      image: busybox
      command: [ "/bin/sh","-c","echo $(DB_HOST) $(DB_PORT)" ]
      env:
        - name: DB_HOST
          valueFrom:
            configMapKeyRef:
              name: configmap-demo
              key: db.host
        - name: DB_PORT
          valueFrom:
            configMapKeyRef:
              name: configmap-demo
              key: db.port

#这里还是使用Key的方式,命令行直接echo下面的环境变量就可以

由于使用的busybox镜像,没有后台执行命令,所以会出现CrashLoopBackOff状态,是属于正常状态

4.通过数据卷挂载引用configmap

配置文件如下,包含configmap文件

apiVersion: v1
kind: ConfigMap
metadata:
  name: configmap-demo-volume
  namespace: default
data:
  nginx.conf: |
    nginx.host: localhost
    nginx.port: "3306"


---

apiVersion: v1
kind: Pod
metadata:
  name: test-demo-configmap-vloume
spec:
  containers:
    - name: test-demo-cm
      image: busybox
      command: [ "/bin/sh","-c","cat /etc/config/nginx.conf" ]
      volumeMounts:         #挂载声明
      - name: config-volume       #volume名称
        mountPath: /etc/config    #挂载点
  volumes:        
  - name: config-volume  #和volumeMounts的名称要一致
    configMap:
      name: configmap-demo-volume   #configmap名称

将上面的yaml保存到文件进行执行,然后我们直接看pod日志就可以了,从pod日志可以看出我们挂载已经完成,因为默认的busybox镜像中没有nginx.conf,通过挂载才获取到的

[root@abcdocker yaml]# kubectl apply -f  cn-test3.yaml
configmap/configmap-demo-volume created
pod/test-demo-configmap-vloume created
[root@abcdocker yaml]# kubectl logs test-demo-configmap-vloume
nginx.host: localhost
nginx.port: "3306"

如果/etc/没有config目录也是可以挂载的,并不影响

如果我们有2个pod都需要挂载configmap,其中一个是在/etc/config/nginx.conf,还有一个是在/etc/config/path/to目录下,这时候就可以使用下面的案例

apiVersion: v1
kind: Pod
metadata:
  name: test-demo-configmap-nginx
spec:
  containers:
    - name: test-demo-cm
      image: busybox
      command: [ "/bin/sh","-c","cat /etc/config/path/go/nginx.conf" ]
      volumeMounts:         #挂载声明
      - name: config-volume       #volume名称
        mountPath: /etc/config    #挂载点
  volumes:        
  - name: config-volume  #和volumeMounts的名称要一致
    configMap:
      name: configmap-demo-volume   #configmap名称
      items:
      - key: nginx.conf       #configmap中的key
        path: path/go/nginx.conf  #挂载路径

日志如下

[root@abcdocker yaml]# kubectl logs test-demo-configmap-nginx
nginx.host: localhost
nginx.port: "3306"

需要注意的是,当configmap以数据卷的形式挂载Pod时,这时更新ConfigMap,Pod内挂载的配置信息会热更新。如果服务也需要更新则需要对应的reload服务

Copyright © i4t.com 2019 all right reserved,powered by Gitbook该文件修订时间: 2020-02-25 08:23:01

results matching ""

    No results matching ""