原文链接: https://kubernetes.feisky.xyz/he-xin-yuan-li/index-2/configmap
ConfigMap
在执行应用程式或是生产环境等等, 会有许多的情况需要做变更, 而我们不希望因应每一种需求就要准备一个镜像档, 这时就可以透过 ConfigMap 来帮我们做一个配置档或是命令参数的映射, 更加弹性化使用我们的服务或是应用程式。
ConfigMap 用于保存配置数据的键值对,可以用来保存单个属性,也可以用来保存配置文件。ConfigMap 跟 secret 很类似,但它可以更方便地处理不包含敏感信息的字符串。
API 版本对照表
Kubernetes 版本 | Core API 版本 |
---|---|
v1.5+ | core/v1 |
ConfigMap 创建
可以使用 kubectl create configmap
从文件、目录或者 key-value 字符串创建等创建 ConfigMap。也可以通过 kubectl create -f file
创建。
从 key-value 字符串创建
1 | $ kubectl create configmap special-config --from-literal=special.how=very |
从 env 文件创建
1 | $ echo -e "a=b\nc=d" | tee config.env |
从目录创建
1 | $ mkdir config |
从文件 Yaml/Json 文件创建
1 | apiVersion: v1 |
1 | $ kubectl create -f config.yaml |
ConfigMap 使用
ConfigMap 可以通过三种方式在 Pod 中使用,三种分别方式为:设置环境变量、设置容器命令行参数以及在 Volume 中直接挂载文件或目录。
注意
- ConfigMap 必须在 Pod 引用它之前创建
- 使用
envFrom
时,将会自动忽略无效的键- Pod 只能使用同一个命名空间内的 ConfigMap
首先创建 ConfigMap:
1 | $ kubectl create configmap special-config --from-literal=special.how=very --from-literal=special.type=charm |
用作环境变量
1 | apiVersion: v1 |
当 Pod 结束后会输出
1 | SPECIAL_LEVEL_KEY=very |
用作命令行参数
将 ConfigMap 用作命令行参数时,需要先把 ConfigMap 的数据保存在环境变量中,然后通过 $(VAR_NAME)
的方式引用环境变量.
1 | apiVersion: v1 |
当 Pod 结束后会输出
1 | very charm |
使用 volume 将 ConfigMap 作为文件或目录直接挂载
将创建的 ConfigMap 直接挂载至 Pod 的 / etc/config 目录下,其中每一个 key-value 键值对都会生成一个文件,key 为文件名,value 为内容
1 | apiVersion: v1 |
当 Pod 结束后会输出
1 | very |
将创建的 ConfigMap 中 special.how 这个 key 挂载到 / etc/config 目录下的一个相对路径 / keys/special.level。如果存在同名文件,直接覆盖。其他的 key 不挂载
1 | apiVersion: v1 |
当 Pod 结束后会输出
1 | very |
ConfigMap 支持同一个目录下挂载多个 key 和多个目录。例如下面将 special.how 和 special.type 通过挂载到 / etc/config 下。并且还将 special.how 同时挂载到 / etc/config2 下。
1 | apiVersion: v1 |
1 | # ls /etc/config/keys/ |
使用 subpath 将 ConfigMap 作为单独的文件挂载到目录
在一般情况下 configmap 挂载文件时,会先覆盖掉挂载目录,然后再将 congfigmap 中的内容作为文件挂载进行。如果想不对原来的文件夹下的文件造成覆盖,只是将 configmap 中的每个 key,按照文件的方式挂载到目录下,可以使用 subpath 参数。1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21apiVersion: v1
kind: Pod
metadata:
name: dapi-test-pod
spec:
containers:
- name: test-container
image: nginx
command: ["/bin/sh","-c","sleep 36000"]
volumeMounts:
- name: config-volume
mountPath: /etc/nginx/special.how
subPath: special.how
volumes:
- name: config-volume
configMap:
name: special-config
items:
- key: special.how
path: special.how
restartPolicy: Never
1 | root@dapi-test-pod:/# ls /etc/nginx/ |
参考文档: