TA的每日心情 | 擦汗 前天 09:04 |
---|
签到天数: 1047 天 连续签到: 5 天 [LV.10]测试总司令
|
在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 产生以下输出:
|
|