配置 Pod 使用 ConfigMap

    ConfigMap 允许你将配置文件与镜像文件分离,以使容器化的应用程序具有可移植性。 本页提供了一系列使用示例,这些示例演示了如何创建 ConfigMap 以及配置 Pod 使用存储在 ConfigMap 中的数据。

    你必须拥有一个 Kubernetes 的集群,同时你的 Kubernetes 集群必须带有 kubectl 命令行工具。 建议在至少有两个节点的集群上运行本教程,且这些节点不作为控制平面主机。 如果你还没有集群,你可以通过 Minikube 构建一个你自己的集群,或者你可以使用下面任意一个 Kubernetes 工具构建:

    To check the version, enter .

    创建 ConfigMap

    你可以使用 kubectl create configmap 或者在 kustomization.yaml 中的 ConfigMap 生成器来创建 ConfigMap。注意,kubectl 从 1.14 版本开始支持 kustomization.yaml

    你可以使用 kubectl create configmap 命令基于目录、 或者字面值来创建 ConfigMap:

    其中,<映射名称> 是为 ConfigMap 指定的名称,<数据源> 是要从中提取数据的目录、 文件或者字面值。 ConfigMap 对象的名称必须是合法的 .

    在你基于文件来创建 ConfigMap 时,<数据源> 中的键名默认取自文件的基本名, 而对应的值则默认为文件的内容。

    你可以使用kubectl describe 或者 获取有关 ConfigMap 的信息。

    基于目录创建 ConfigMap

    你可以使用 kubectl create configmap 基于同一目录中的多个文件创建 ConfigMap。 当你基于目录来创建 ConfigMap 时,kubectl 识别目录下基本名可以作为合法键名的文件, 并将这些文件打包到新的 ConfigMap 中。普通文件之外的所有目录项都会被忽略 (例如:子目录、符号链接、设备、管道等等)。

    例如:

    1. # 创建本地目录
    2. mkdir -p configure-pod-container/configmap/
    3. # 将实例文件下载到 `configure-pod-container/configmap/` 目录
    4. wget https://kubernetes.io/examples/configmap/game.properties -O configure-pod-container/configmap/game.properties
    5. wget https://kubernetes.io/examples/configmap/ui.properties -O configure-pod-container/configmap/ui.properties
    6. # 创建 configmap
    7. kubectl create configmap game-config --from-file=configure-pod-container/configmap/

    以上命令将 configure-pod-container/configmap 目录下的所有文件,也就是 game.propertiesui.properties 打包到 game-config ConfigMap 中。你可以使用下面的命令显示 ConfigMap 的详细信息:

    1. kubectl describe configmaps game-config

    输出类似以下内容:

    1. Name: game-config
    2. Namespace: default
    3. Labels: <none>
    4. Annotations: <none>
    5. Data
    6. ====
    7. game.properties:
    8. ----
    9. enemies=aliens
    10. lives=3
    11. enemies.cheat=true
    12. enemies.cheat.level=noGoodRotten
    13. secret.code.passphrase=UUDDLRLRBABAS
    14. secret.code.allowed=true
    15. secret.code.lives=30
    16. ui.properties:
    17. ----
    18. color.good=purple
    19. color.bad=yellow
    20. allow.textmode=true
    21. how.nice.to.look=fairlyNice

    configure-pod-container/configmap/ 目录中的 game.propertiesui.properties 文件出现在 ConfigMap 的 data 部分。

    1. kubectl get configmaps game-config -o yaml

    输出类似以下内容:

    1. apiVersion: v1
    2. kind: ConfigMap
    3. metadata:
    4. creationTimestamp: 2016-02-18T18:52:05Z
    5. name: game-config
    6. namespace: default
    7. resourceVersion: "516"
    8. selfLink: /api/v1/namespaces/default/configmaps/game-config
    9. uid: b4952dc3-d670-11e5-8cd0-68f728db1985
    10. data:
    11. game.properties: |
    12. enemies=aliens
    13. lives=3
    14. enemies.cheat=true
    15. enemies.cheat.level=noGoodRotten
    16. secret.code.passphrase=UUDDLRLRBABAS
    17. secret.code.allowed=true
    18. secret.code.lives=30
    19. ui.properties: |
    20. color.good=purple
    21. color.bad=yellow
    22. allow.textmode=true
    23. how.nice.to.look=fairlyNice

    基于文件创建 ConfigMap

    你可以使用 kubectl create configmap 基于单个文件或多个文件创建 ConfigMap。

    例如:

    1. kubectl create configmap game-config-2 --from-file=configure-pod-container/configmap/game.properties

    将产生以下 ConfigMap:

    1. kubectl describe configmaps game-config-2

    输出类似以下内容:

    1. Name: game-config-2
    2. Namespace: default
    3. Labels: <none>
    4. Annotations: <none>
    5. Data
    6. ====
    7. game.properties:
    8. ----
    9. enemies=aliens
    10. lives=3
    11. enemies.cheat=true
    12. enemies.cheat.level=noGoodRotten
    13. secret.code.passphrase=UUDDLRLRBABAS
    14. secret.code.allowed=true
    15. secret.code.lives=30

    你可以多次使用 --from-file 参数,从多个数据源创建 ConfigMap。

    1. kubectl create configmap game-config-2 --from-file=configure-pod-container/configmap/game.properties --from-file=configure-pod-container/configmap/ui.properties

    描述上面创建的 game-config-2 ConfigMap:

    1. kubectl describe configmaps game-config-2

    输出类似以下内容:

    1. Name: game-config-2
    2. Namespace: default
    3. Labels: <none>
    4. Annotations: <none>
    5. Data
    6. ====
    7. game.properties:
    8. ----
    9. enemies=aliens
    10. lives=3
    11. enemies.cheat=true
    12. enemies.cheat.level=noGoodRotten
    13. secret.code.passphrase=UUDDLRLRBABAS
    14. secret.code.allowed=true
    15. secret.code.lives=30
    16. ui.properties:
    17. ----
    18. color.good=purple
    19. color.bad=yellow
    20. allow.textmode=true
    21. how.nice.to.look=fairlyNice

    kubectl 基于非 ASCII 或 UTF-8 的输入创建 ConfigMap 时, 该工具将这些输入放入 ConfigMap 的 binaryData 字段,而不是 data 中。 同一个 ConfigMap 中可同时包含文本数据和二进制数据源。 如果你想查看 ConfigMap 中的 binaryData 键(及其值), 你可以运行 kubectl get configmap -o jsonpath='{.binaryData}' <name>

    使用 --from-env-file 选项从环境文件创建 ConfigMap,例如:

    Env 文件包含环境变量列表。其中适用以下语法规则:

    • Env 文件中的每一行必须为 VAR=VAL 格式。
    • 以#开头的行(即注释)将被忽略。
    • 空行将被忽略。
    • 引号不会被特殊处理(即它们将成为 ConfigMap 值的一部分)。

    将示例文件下载到 configure-pod-container/configmap/ 目录:

    1. wget https://kubernetes.io/examples/configmap/game-env-file.properties -O configure-pod-container/configmap/game-env-file.properties
    2. wget https://kubernetes.io/examples/configmap/ui-env-file.properties -O configure-pod-container/configmap/ui-env-file.properties

    Env 文件 game-env-file.properties 如下所示:

    1. cat configure-pod-container/configmap/game-env-file.properties
    1. enemies=aliens
    2. lives=3
    3. allowed="true"
    1. kubectl create configmap game-config-env-file \
    2. --from-env-file=configure-pod-container/configmap/game-env-file.properties

    将产生以下 ConfigMap:

    1. kubectl get configmap game-config-env-file -o yaml

    输出类似以下内容:

    1. apiVersion: v1
    2. kind: ConfigMap
    3. metadata:
    4. name: game-config-env-file
    5. namespace: default
    6. resourceVersion: "809965"
    7. selfLink: /api/v1/namespaces/default/configmaps/game-config-env-file
    8. uid: d9d1ca5b-eb34-11e7-887b-42010a8002b8
    9. data:
    10. allowed: '"true"'
    11. enemies: aliens
    12. lives: "3"

    从 Kubernetes 1.23 版本开始,kubectl 支持多次指定 --from-env-file 参数来从多个数据源创建 ConfigMap。

    下面是一个多次使用 --from-env-file 参数的示例:

    1. kubectl create configmap config-multi-env-files \
    2. --from-env-file=configure-pod-container/configmap/game-env-file.properties \
    3. --from-env-file=configure-pod-container/configmap/ui-env-file.properties

    将产生以下 ConfigMap:

    1. kubectl get configmap config-multi-env-files -o yaml

    输出类似以下内容:

    1. kind: ConfigMap
    2. metadata:
    3. creationTimestamp: 2017-12-27T18:38:34Z
    4. name: config-multi-env-files
    5. namespace: default
    6. resourceVersion: "810136"
    7. selfLink: /api/v1/namespaces/default/configmaps/config-multi-env-files
    8. uid: 252c4572-eb35-11e7-887b-42010a8002b8
    9. data:
    10. allowed: '"true"'
    11. color: purple
    12. enemies: aliens
    13. how: fairlyNice
    14. lives: "3"
    15. textmode: "true"

    定义从文件创建 ConfigMap 时要使用的键

    在使用 --from-file 参数时,你可以定义在 ConfigMap 的 data 部分出现键名, 而不是按默认行为使用文件名:

    例如:

    1. kubectl create configmap game-config-3 --from-file=game-special-key=configure-pod-container/configmap/game.properties

    将产生以下 ConfigMap:

    1. kubectl get configmaps game-config-3 -o yaml

    输出类似以下内容:

    1. apiVersion: v1
    2. kind: ConfigMap
    3. metadata:
    4. creationTimestamp: 2016-02-18T18:54:22Z
    5. name: game-config-3
    6. namespace: default
    7. resourceVersion: "530"
    8. selfLink: /api/v1/namespaces/default/configmaps/game-config-3
    9. uid: 05f8da22-d671-11e5-8cd0-68f728db1985
    10. data:
    11. game-special-key: |
    12. enemies=aliens
    13. lives=3
    14. enemies.cheat=true
    15. enemies.cheat.level=noGoodRotten
    16. secret.code.passphrase=UUDDLRLRBABAS
    17. secret.code.allowed=true
    18. secret.code.lives=30

    根据字面值创建 ConfigMap

    你可以将 kubectl create configmap--from-literal 参数一起使用, 通过命令行定义文字值:

    1. kubectl create configmap special-config --from-literal=special.how=very --from-literal=special.type=charm

    你可以传入多个键值对。命令行中提供的每对键值在 ConfigMap 的 data 部分中均表示为单独的条目。

    1. kubectl get configmaps special-config -o yaml

    输出类似以下内容:

    1. apiVersion: v1
    2. kind: ConfigMap
    3. metadata:
    4. creationTimestamp: 2016-02-18T19:14:38Z
    5. name: special-config
    6. namespace: default
    7. resourceVersion: "651"
    8. selfLink: /api/v1/namespaces/default/configmaps/special-config
    9. uid: dadce046-d673-11e5-8cd0-68f728db1985
    10. data:
    11. special.how: very
    12. special.type: charm

    基于生成器创建 ConfigMap

    自 1.14 开始,kubectl 开始支持 kustomization.yaml。 你还可以基于生成器(Generators)创建 ConfigMap,然后将其应用于 API 服务器上创建对象。 生成器应在目录内的 kustomization.yaml 中指定。

    基于文件生成 ConfigMap

    例如,要基于 configure-pod-container/configmap/kubectl/game.properties 文件生成一个 ConfigMap:

    1. # 创建包含 ConfigMapGenerator 的 kustomization.yaml 文件
    2. cat <<EOF >./kustomization.yaml
    3. configMapGenerator:
    4. - name: game-config-4
    5. files:
    6. - configure-pod-container/configmap/kubectl/game.properties
    7. EOF

    应用(Apply)kustomization 目录创建 ConfigMap 对象:

    1. kubectl apply -k .
    1. configmap/game-config-4-m9dm2f92bt created

    你可以检查 ConfigMap 被创建如下:

    1. kubectl get configmap
    1. NAME DATA AGE
    2. game-config-4-m9dm2f92bt 1 37s
    3. kubectl describe configmaps/game-config-4-m9dm2f92bt
    4. Name: game-config-4-m9dm2f92bt
    5. Namespace: default
    6. Labels: <none>
    7. Annotations: kubectl.kubernetes.io/last-applied-configuration:
    8. {"apiVersion":"v1","data":{"game.properties":"enemies=aliens\nlives=3\nenemies.cheat=true\nenemies.cheat.level=noGoodRotten\nsecret.code.p...
    9. Data
    10. ====
    11. game.properties:
    12. ----
    13. enemies=aliens
    14. lives=3
    15. enemies.cheat=true
    16. enemies.cheat.level=noGoodRotten
    17. secret.code.passphrase=UUDDLRLRBABAS
    18. secret.code.allowed=true
    19. secret.code.lives=30
    20. Events: <none>

    请注意,生成的 ConfigMap 名称具有通过对内容进行散列而附加的后缀, 这样可以确保每次修改内容时都会生成新的 ConfigMap。

    定义从文件生成 ConfigMap 时要使用的键

    在 ConfigMap 生成器中,你可以定义一个非文件名的键名。 例如,从 configure-pod-container/configmap/game.properties 文件生成 ConfigMap, 但使用 game-special-key 作为键名:

    1. # 创建包含 ConfigMapGenerator 的 kustomization.yaml 文件
    2. cat <<EOF >./kustomization.yaml
    3. configMapGenerator:
    4. - name: game-config-5
    5. files:
    6. - game-special-key=configure-pod-container/configmap/kubectl/game.properties
    7. EOF

    应用 Kustomization 目录创建 ConfigMap 对象。

    1. kubectl apply -k .
    1. configmap/game-config-5-m67dt67794 created

    基于字面值生成 ConfigMap

    要基于字符串 special.type=charmspecial.how=very 生成 ConfigMap, 可以在 kusotmization.yaml 中配置 ConfigMap 生成器:

    1. # 创建带有 ConfigMapGenerator 的 kustomization.yaml 文件
    2. cat <<EOF >./kustomization.yaml
    3. configMapGenerator:
    4. - name: special-config-2
    5. literals:
    6. - special.how=very
    7. - special.type=charm
    8. EOF

    应用 Kustomization 目录创建 ConfigMap 对象。

    1. kubectl apply -k .
    1. configmap/special-config-2-c92b5mmcf2 created

    使用单个 ConfigMap 中的数据定义容器环境变量

    1. 在 ConfigMap 中将环境变量定义为键值对:

      1. kubectl create configmap special-config --from-literal=special.how=very
    2. 将 ConfigMap 中定义的 special.how 赋值给 Pod 规约中的 SPECIAL_LEVEL_KEY 环境变量。

      1. apiVersion: v1
      2. kind: Pod
      3. metadata:
      4. name: dapi-test-pod
      5. spec:
      6. containers:
      7. - name: test-container
      8. image: k8s.gcr.io/busybox
      9. command: [ "/bin/sh", "-c", "env" ]
      10. env:
      11. # 定义环境变量
      12. - name: SPECIAL_LEVEL_KEY
      13. valueFrom:
      14. configMapKeyRef:
      15. # ConfigMap 包含你要赋给 SPECIAL_LEVEL_KEY 的值
      16. name: special-config
      17. # 指定与取值相关的键名
      18. key: special.how
      19. restartPolicy: Never

      创建 Pod:

      1. kubectl create -f https://kubernetes.io/examples/pods/pod-single-configmap-env-variable.yaml

      现在,Pod 的输出包含环境变量 SPECIAL_LEVEL_KEY=very

    • 与前面的示例一样,首先创建 ConfigMap。

      configmap/configmaps.yaml

      创建 ConfigMap:

      1. kubectl create -f https://kubernetes.io/examples/configmap/configmaps.yaml
    • 在 Pod 规约中定义环境变量。

      1. kind: Pod
      2. metadata:
      3. name: dapi-test-pod
      4. spec:
      5. containers:
      6. - name: test-container
      7. image: k8s.gcr.io/busybox
      8. command: [ "/bin/sh", "-c", "env" ]
      9. env:
      10. - name: SPECIAL_LEVEL_KEY
      11. valueFrom:
      12. name: special-config
      13. key: special.how
      14. - name: LOG_LEVEL
      15. valueFrom:
      16. configMapKeyRef:
      17. name: env-config
      18. key: log_level
      19. restartPolicy: Never

      创建 Pod:

      1. kubectl create -f https://kubernetes.io/examples/pods/pod-multiple-configmap-env-variable.yaml

      现在,Pod 的输出包含环境变量 SPECIAL_LEVEL_KEY=veryLOG_LEVEL=INFO

    将 ConfigMap 中的所有键值对配置为容器环境变量

    Note: Kubernetes v1.6 和更高版本支持此功能。

    • 创建一个包含多个键值对的 ConfigMap。

      1. apiVersion: v1
      2. kind: ConfigMap
      3. metadata:
      4. name: special-config
      5. namespace: default
      6. data:
      7. SPECIAL_LEVEL: very
      8. SPECIAL_TYPE: charm

      创建 ConfigMap:

      1. kubectl create -f https://kubernetes.io/examples/configmap/configmap-multikeys.yaml
    • 使用 envFrom 将所有 ConfigMap 的数据定义为容器环境变量,ConfigMap 中的键成为 Pod 中的环境变量名称。

      pods/pod-configmap-envFrom.yaml

      1. apiVersion: v1
      2. kind: Pod
      3. metadata:
      4. name: dapi-test-pod
      5. spec:
      6. containers:
      7. - name: test-container
      8. image: k8s.gcr.io/busybox
      9. command: [ "/bin/sh", "-c", "env" ]
      10. envFrom:
      11. - configMapRef:
      12. name: special-config
      13. restartPolicy: Never
      1. kubectl create -f https://kubernetes.io/examples/pods/pod-configmap-envFrom.yaml

      现在,Pod 的输出包含环境变量 SPECIAL_LEVEL=verySPECIAL_TYPE=charm

    你可以使用 $(VAR_NAME) Kubernetes 替换语法在容器的 commandargs 属性中使用 ConfigMap 定义的环境变量。

    例如,以下 Pod 规约

    1. apiVersion: v1
    2. kind: Pod
    3. metadata:
    4. name: dapi-test-pod
    5. spec:
    6. containers:
    7. - name: test-container
    8. image: k8s.gcr.io/busybox
    9. command: [ "/bin/echo", "$(SPECIAL_LEVEL_KEY) $(SPECIAL_TYPE_KEY)" ]
    10. env:
    11. - name: SPECIAL_LEVEL_KEY
    12. valueFrom:
    13. configMapKeyRef:
    14. name: special-config
    15. key: SPECIAL_LEVEL
    16. - name: SPECIAL_TYPE_KEY
    17. valueFrom:
    18. configMapKeyRef:
    19. name: special-config
    20. key: SPECIAL_TYPE
    21. restartPolicy: Never

    通过运行下面命令创建 Pod:

    1. kubectl create -f https://kubernetes.io/examples/pods/pod-configmap-env-var-valueFrom.yaml

    test-container 容器中产生以下输出:

    1. very charm

    将 ConfigMap 数据添加到一个卷中

    如基于文件创建 中所述,当你使用 --from-file 创建 ConfigMap 时,文件名成为存储在 ConfigMap 的 data 部分中的键, 文件内容成为键对应的值。

    本节中的示例引用了一个名为 ‘special-config’ 的 ConfigMap,如下所示:

    configmap/configmap-multikeys.yaml

    1. apiVersion: v1
    2. kind: ConfigMap
    3. metadata:
    4. name: special-config
    5. namespace: default
    6. data:
    7. SPECIAL_LEVEL: very
    8. SPECIAL_TYPE: charm

    创建 ConfigMap:

    1. kubectl create -f https://kubernetes.io/examples/configmap/configmap-multikeys.yaml

    使用存储在 ConfigMap 中的数据填充卷

    在 Pod 规约的 volumes 部分下添加 ConfigMap 名称。 这会将 ConfigMap 数据添加到 volumeMounts.mountPath 所指定的目录 (在本例中为 /etc/config)。 command 部分引用存储在 ConfigMap 中的 special.level

    pods/pod-configmap-volume.yaml

    1. apiVersion: v1
    2. kind: Pod
    3. metadata:
    4. name: dapi-test-pod
    5. spec:
    6. containers:
    7. - name: test-container
    8. image: k8s.gcr.io/busybox
    9. command: [ "/bin/sh", "-c", "ls /etc/config/" ]
    10. volumeMounts:
    11. - name: config-volume
    12. mountPath: /etc/config
    13. volumes:
    14. - name: config-volume
    15. configMap:
    16. # 提供包含要添加到容器中的文件的 ConfigMap 的名称
    17. name: special-config
    18. restartPolicy: Never

    创建 Pod:

    1. kubectl create -f https://kubernetes.io/examples/pods/pod-configmap-volume.yaml

    Pod 运行时,命令 ls /etc/config/ 产生下面的输出:

    1. SPECIAL_LEVEL
    2. SPECIAL_TYPE

    Caution: 如果在 /etc/config/ 目录中有一些文件,这些文件将被删除。

    Note: 文本数据会展现为 UTF-8 字符编码的文件。如果使用其他字符编码, 可以使用 binaryData

    将 ConfigMap 数据添加到卷中的特定路径

    使用 path 字段为特定的 ConfigMap 项目指定预期的文件路径。 在这里,ConfigMap 中键 SPECIAL_LEVEL 的内容将挂载在 config-volume 卷中 /etc/config/keys 文件中。

    pods/pod-configmap-volume-specific-key.yaml

    1. apiVersion: v1
    2. kind: Pod
    3. metadata:
    4. name: dapi-test-pod
    5. spec:
    6. containers:
    7. - name: test-container
    8. image: k8s.gcr.io/busybox
    9. command: [ "/bin/sh","-c","cat /etc/config/keys" ]
    10. volumeMounts:
    11. - name: config-volume
    12. mountPath: /etc/config
    13. volumes:
    14. - name: config-volume
    15. configMap:
    16. name: special-config
    17. items:
    18. - key: SPECIAL_LEVEL
    19. path: keys
    20. restartPolicy: Never

    创建Pod:

    1. kubectl create -f https://kubernetes.io/examples/pods/pod-configmap-volume-specific-key.yaml

    当 Pod 运行时,命令 cat /etc/config/keys 产生以下输出:

    1. very

    Caution: 如前,/etc/config/ 目录中所有先前的文件都将被删除。

    你可以将指定键名投射到特定目录,也可以逐个文件地设定访问权限。 中为这一语法提供了解释。

    可选的引用

    ConfigMap 引用可以被标记为 “optional(可选的)”。如果所引用的 ConfigMap 不存在, 则所挂载的卷将会是空的。如果所引用的 ConfigMap 确实存在,但是所引用的主键不存在, 则在挂载点下对应的路径也会不存在。

    挂载的 ConfigMap 将自动更新

    当某个已被挂载的 ConfigMap 被更新,所投射的内容最终也会被更新。 对于 Pod 已经启动之后所引用的、可选的 ConfigMap 才出现的情形, 这一动态更新现象也是适用的。

    kubelet 在每次周期性同步时都会检查已挂载的 ConfigMap 是否是最新的。 但是,它使用其本地的基于 TTL 的缓存来获取 ConfigMap 的当前值。 因此,从更新 ConfigMap 到将新键映射到 Pod 的总延迟可能与 kubelet 同步周期(默认 1 分钟) + ConfigMap 在 kubelet 中缓存的 TTL (默认 1 分钟)一样长。 你可以通过更新 Pod 的某个注解来触发立即更新。

    Note: 使用 ConfigMap 作为 subPath 的数据卷将不会收到 ConfigMap 更新。

    ConfigMap API 资源将配置数据存储为键值对。 数据可以在 Pod 中使用,也可以用来提供系统组件(如控制器)的配置。 ConfigMap 与 类似, 但是提供的是一种处理不含敏感信息的字符串的方法。 用户和系统组件都可以在 ConfigMap 中存储配置数据。

    Note: ConfigMap 应该引用属性文件,而不是替换它们。可以将 ConfigMap 理解为类似于 Linux /etc 目录及其内容的东西。例如,如果你基于 ConfigMap 创建 Kubernetes 卷,则 ConfigMap 中的每个数据项都由该数据卷中的某个独立的文件表示。

    ConfigMap 的 data 字段包含配置数据。如下例所示,它可以简单 (如用 --from-literal 的单个属性定义)或复杂 (如用 --from-file 的配置文件或 JSON blob定义)。

    1. apiVersion: v1
    2. kind: ConfigMap
    3. metadata:
    4. creationTimestamp: 2016-02-18T19:14:38Z
    5. name: example-config
    6. namespace: default
    7. data:
    8. # 使用 --from-literal 定义的简单属性
    9. example.property.1: hello
    10. example.property.2: world
    11. # 使用 --from-file 定义复杂属性的例子
    12. example.property.file: |-
    13. property.1=value-1
    14. property.2=value-2
    15. property.3=value-3
    • 在 Pod 规约中引用某个 ConfigMap 之前,必须先创建它(除非将 ConfigMap 标记为 “optional(可选)”)。如果引用的 ConfigMap 不存在,则 Pod 将不会启动。 同样,引用 ConfigMap 中不存在的主键也会令 Pod 无法启动。

    • 如果你使用 envFrom 来基于 ConfigMap 定义环境变量,那么无效的键将被忽略。 Pod 可以被启动,但无效名称将被记录在事件日志中(InvalidVariableNames)。 日志消息列出了每个被跳过的键。例如:

      输出与此类似:

    • ConfigMap 位于确定的中。 每个 ConfigMap 只能被同一名字空间中的 Pod 引用.

    What’s next

    最后修改 April 14, 2022 at 8:18 PM PST: