ConfigMap用管理对象的方式管理配置(2)

发表于:2022-3-18 10:21

字体: | 上一篇 | 下一篇 | 我要投稿

 作者:kevinyan    来源:稀土掘金

  在Pod里使用ConfigMap
  用 ConfigMap 中的数据定义容器环境变量
  将上面用字符串键值对直接创建的ConfigMap 中定义的 special.how 值分配给下面YAML文件里定义的Pod的环境变量 SPECIAL_LEVEL_KEY 。
  apiVersion: v1
  kind: Pod
  metadata:
    name: dapi-test-pod
  spec:
    containers:
      - name: test-container
        image: k8s.gcr.io/busybox
        command: [ "/bin/sh", "-c", "env" ]
        env:
          # 定义环境变量
          - name: SPECIAL_LEVEL_KEY
            valueFrom:
              configMapKeyRef:
                # 通过名字指定要引用的ConfigMap对象
                name: special-config
                # 指定引用ConfigMap里的那个数据条目
                key: special.how
    restartPolicy: Never

  上面在Pod的spec.env定义环境变量SPECIAL_LEVEL_KEY时通过valueFrom的configMapKeyRef键告诉Pod要从ConfigMap中引用值,具体使用哪个ConfigMap对象里的那个数据条目则是通过name和key再去进一步指定。
  将 ConfigMap 挂载到数据卷
  在 Pod 定义的 spec.volumes 字段下添加 ConfigMap对象的名称。 这会将 ConfigMap 数据以文件的形式添加到容器定义部分 volumeMounts.mountPath 的指定的挂载目录中(在下面的例子中为 /etc/config)。在容器中即可通过目录/etc/config下的文件使用ConfigMap中定义的数据条目,比如这里定义的容器启动命令就是容器启动后使用ls查看/etc/config目录下配置文件:
  // pod-configmap-volume.yaml
  apiVersion: v1
  kind: Pod
  metadata:
    name: dapi-test-pod
  spec:
    containers:
      - name: test-container
        image: k8s.gcr.io/busybox
        command: [ "/bin/sh", "-c", "ls /etc/config/" ]
        volumeMounts:
        - name: config-volume
          mountPath: /etc/config
    volumes:
      - name: config-volume
        configMap:
          # Provide the name of the ConfigMap containing the files you want
          # to add to the container
          name: special-config
    restartPolicy: Never

  创建 Pod:
  kubectl create -f pod-configmap-volume.yaml

  Pod 运行时,命令 ls /etc/config/ 产生下面的输出:
  SPECIAL_LEVEL
  SPECIAL_TYPE
 
  在Pod的YAML定义文件里,ConfigMap引用配置中 使用path 字段为特定的 ConfigMap 项目指定预期的文件名。 在这里,SPECIAL_LEVEL 将挂载在 config-volume 数据卷中 /etc/config/keys 路径下。
  apiVersion: v1
  kind: Pod
  metadata:
    name: dapi-test-pod
  spec:
    containers:
      - name: test-container
        image: k8s.gcr.io/busybox
        command: [ "/bin/sh","-c","cat /etc/config/keys" ]
        volumeMounts:
        - name: config-volume
          mountPath: /etc/config
    volumes:
      - name: config-volume
        configMap:
          name: special-config
          items:
          - key: SPECIAL_LEVEL
            path: keys
    restartPolicy: Never

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

  本文内容不用于商业目的,如涉及知识产权问题,请权利人联系51Testing小编(021-64471599-8017),我们将立即处理
《2023软件测试行业现状调查报告》独家发布~

关注51Testing

联系我们

快捷面板 站点地图 联系我们 广告服务 关于我们 站长统计 发展历程

法律顾问:上海兰迪律师事务所 项棋律师
版权所有 上海博为峰软件技术股份有限公司 Copyright©51testing.com 2003-2024
投诉及意见反馈:webmaster@51testing.com; 业务联系:service@51testing.com 021-64471599-8017

沪ICP备05003035号

沪公网安备 31010102002173号