文章目录
- 主要内容
- 一.Volume 挂载 ConfigMap
- 1.创建一个Pod,起挂载的内容,将来自下面的configmap:
- 代码如下(示例):
- 2.解释
- 二.环境变量 ConfigMap
- 总结
主要内容
- Volume 挂载 ConfigMap
- 环境变量 ConfigMap
一.Volume 挂载 ConfigMap
在 Kubernetes 中,可以使用 Volume 来将 ConfigMap 挂载到 Pod 中。这样,Pod 中的容器就可以通过文件系统访问 ConfigMap 中的配置数据。
要将 ConfigMap 挂载到 Pod 中,需要执行以下步骤:
-
创建 ConfigMap:首先,需要创建一个 ConfigMap 对象来存储配置数据。可以使用
kubectl create configmap命令或通过 YAML 文件创建 ConfigMap。 -
定义 Volume:在 Pod 的规格(spec)中,需要定义一个 Volume,将其类型设置为 ConfigMap,并指定要挂载的 ConfigMap 的名称。
-
配置容器:在 Pod 的规格中,需要将 Volume 挂载到容器中的某个目录。可以使用
volumeMounts字段将 Volume 挂载到容器中,并指定挂载路径。
下面是一个示例,展示了如何将 ConfigMap 挂载到 Pod 中:
apiVersion: v1
kind: Pod
metadata:
name: my-pod
spec:
containers:
- name: my-container
image: my-image
volumeMounts:
- name: config-volume
mountPath: /etc/config
volumes:
- name: config-volume
configMap:
name: my-config
在这个示例中:
-
volumes字段定义了一个名为config-volume的 Volume,类型为 ConfigMap,并指定要挂载的 ConfigMap 的名称为my-config。 -
volumeMounts字段将config-volume挂载到容器的/etc/config目录。
这样,当 Pod 启动时,Kubernetes 会自动将 ConfigMap 中的配置数据挂载到 /etc/config 目录,容器就可以通过文件系统访问这些配置数据了。
需要注意的是,如果 ConfigMap 中的配置数据发生更改,挂载到 Pod 的 Volume 不会自动更新。如果想要更新 Pod 中的配置数据,可以重启 Pod 或使用 ConfigMap 的热更新功能。
希望这个解释能够帮助您理解如何将 ConfigMap 挂载到 Pod 中。
1.创建一个Pod,起挂载的内容,将来自下面的configmap:
代码如下(示例):
cat > cmvolume.yml <<EOF
apiVersion: v1
kind: Pod
metadata:
name: configmapvolume
labels:
app: configmaptest
spec:
containers:
- name: test
image: httpd
imagePullPolicy: IfNotPresent
volumeMounts:
- name: index
mountPath: /usr/local/apache2/htdocs
volumes:
- name: index
configMap:
name: indexcontent
EOF
kubectl create -f cmvolume.yml
kubectl get -f cmvolume.yml -o wide
kubectl delete -f cmvolume.yml

2.解释
上述命令依次执行以下操作:
-
cat > cmvolume.yml <<EOF:此命令将 YAML 文件的内容输入到cmvolume.yml文件中。<<EOF是一个 shell 的输入重定向符号,表示将输入的内容直到遇到EOF为止。 -
kubectl create -f cmvolume.yml:此命令使用kubectl工具根据cmvolume.yml文件中的配置创建一个 Pod。 -
kubectl get -f cmvolume.yml -o wide:此命令使用kubectl工具获取 Pod 的详细信息,并使用-o wide参数以更详细的格式显示输出。 -
kubectl delete -f cmvolume.yml:此命令使用kubectl工具根据cmvolume.yml文件中的配置删除一个 Pod。
通过执行上述命令,您将创建一个名为 configmapvolume 的 Pod,并将其配置为使用名为 indexcontent 的 ConfigMap 中的数据作为卷挂载到容器的 /usr/local/apache2/htdocs 目录中。然后,您可以使用 kubectl get -f cmvolume.yml -o wide 命令查看 Pod 的详细信息,包括名称、标签、IP 地址等。最后,使用 kubectl delete -f cmvolume.yml 命令删除该 Pod。
二.环境变量 ConfigMap
在 Kubernetes 中,可以使用 ConfigMap 来存储环境变量的配置数据。ConfigMap 是一种用于存储非敏感数据的 Kubernetes 资源,可以包含键值对、配置文件或者整个目录。
使用 ConfigMap 存储环境变量的好处是可以将配置数据与容器的定义分离,使得容器的配置更加灵活和可维护。通过将环境变量配置在 ConfigMap 中,可以在不修改容器镜像的情况下,动态地更新容器的配置。
要使用 ConfigMap 存储环境变量,需要执行以下步骤:
-
创建 ConfigMap:首先,需要创建一个 ConfigMap 对象来存储环境变量的配置数据。可以使用
kubectl create configmap命令或通过 YAML 文件创建 ConfigMap。 -
在 Pod 中使用 ConfigMap:在 Pod 的规格(spec)中,可以使用
env字段来定义环境变量。可以通过valueFrom.configMapKeyRef来引用 ConfigMap 中的键值对,并将其作为环境变量的值。
下面是一个示例,展示了如何使用 ConfigMap 存储环境变量:
apiVersion: v1
kind: ConfigMap
metadata:
name: my-config
data:
ENV_VAR1: value1
ENV_VAR2: value2
---
apiVersion: v1
kind: Pod
metadata:
name: my-pod
spec:
containers:
- name: my-container
image: my-image
env:
- name: ENV_VAR1
valueFrom:
configMapKeyRef:
name: my-config
key: ENV_VAR1
- name: ENV_VAR2
valueFrom:
configMapKeyRef:
name: my-config
key: ENV_VAR2
在这个示例中:
-
首先,我们创建了一个名为
my-config的 ConfigMap,其中包含了两个键值对ENV_VAR1: value1和ENV_VAR2: value2。 -
然后,我们创建了一个名为
my-pod的 Pod,其中包含了一个名为my-container的容器。 -
在容器的环境变量定义中,我们使用
valueFrom.configMapKeyRef来引用 ConfigMap 中的键值对。例如,ENV_VAR1的值来自于 ConfigMapmy-config中的键ENV_VAR1。
这样,当 Pod 启动时,Kubernetes 会自动将 ConfigMap 中的键值对作为环境变量注入到容器中。容器就可以通过环境变量访问这些配置数据了。
需要注意的是,如果 ConfigMap 中的配置数据发生更改,挂载到 Pod 的环境变量不会自动更新。如果想要更新 Pod 中的环境变量,可以重启 Pod 或使用 ConfigMap 的热更新功能。
希望这个解释能够帮助您理解如何使用 ConfigMap 存储环境变量。使用 ConfigMap 可以更好地管理容器的配置,并实现配置与容器定义的分离。
1.创建一个名为 mysqlpass 且包含 password=ABCabc123 的 configmap:
代码如下(示例):
kubectl create configmap mysqlpw --from-literal=password=ABCabc123
cat > cmenv.yml <<EOF
apiVersion: v1
kind: Pod
metadata:
name: mysql
spec:
containers:
- name: mysqlname
image: mysql
imagePullPolicy: IfNotPresent
env:
- name: MYSQL_ROOT_PASSWORD
valueFrom:
configMapKeyRef:
name: mysqlpw
key: password
EOF
2.解释
上述命令依次执行以下操作:
-
kubectl create configmap mysqlpw --from-literal=password=ABCabc123:此命令使用kubectl工具创建一个名为mysqlpw的 ConfigMap,并将password键的值设置为ABCabc123。--from-literal参数指定要从字面值创建 ConfigMap。 -
cat > cmenv.yml <<EOF:此命令将 YAML 文件的内容输入到cmenv.yml文件中。<<EOF是一个 shell 的输入重定向符号,表示将输入的内容直到遇到EOF为止。 -
apiVersion: v1:这是一个 YAML 文件中的配置项,指定要创建的资源的 API 版本。 -
kind: Pod:这是一个 YAML 文件中的配置项,指定要创建的资源类型为 Pod。 -
metadata: name: mysql:这是一个 YAML 文件中的配置项,指定要创建的 Pod 的名称为mysql。 -
spec: containers::这是一个 YAML 文件中的配置项,指定 Pod 的规范,其中containers是一个列表,可以指定多个容器。 -
- name: mysqlname:这是一个 YAML 文件中的配置项,指定容器的名称为mysqlname。 -
image: mysql:这是一个 YAML 文件中的配置项,指定容器要使用的镜像为mysql。 -
imagePullPolicy: IfNotPresent:这是一个 YAML 文件中的配置项,指定容器的镜像拉取策略为IfNotPresent,即只在本地不存在该镜像时才拉取。 -
env::这是一个 YAML 文件中的配置项,指定容器的环境变量,其中env是一个列表,可以指定多个环境变量。 -
- name: MYSQL_ROOT_PASSWORD:这是一个 YAML 文件中的配置项,指定环境变量的名称为MYSQL_ROOT_PASSWORD。 -
valueFrom: configMapKeyRef::这是一个 YAML 文件中的配置项,指定环境变量的值从 ConfigMap 中获取。 -
name: mysqlpw:这是一个 YAML 文件中的配置项,指定要使用的 ConfigMap 的名称为mysqlpw。 -
key: password:这是一个 YAML 文件中的配置项,指定要从 ConfigMap 中获取的键为password。
通过执行上述命令,您将创建一个名为 mysqlpw 的 ConfigMap,并将其添加到 Kubernetes 集群中。然后,使用 kubectl create -f cmenv.yml 命令可以创建一个名为 mysql 的 Pod,该 Pod 包含一个名为 mysqlname 的容器。容器中的环境变量 MYSQL_ROOT_PASSWORD 的值将从 ConfigMap mysqlpw 中的 password 键获取。
3.创建一个名为 mysqlpass 且包含 password=ABCabc123 的 configmap:
代码如下(示例):
kubectl create -f cmenv.yml
kubectl exec -it mysql -- mysql -uroot -pABCabc123
kubectl describe configmaps mysqlpass
kubectl delete -f cmenv.yml

因为 configMap 是明文的,通常用于配置文件等明文场景,但数据库口令等密文应该使用 secret。

4.解释
-
kubectl create -f cmenv.yml:此命令将使用kubectl工具根据cmenv.yml文件中的配置创建一个 Pod。该 Pod 的名称为mysql,其中包含一个名为mysqlname的容器。容器使用mysql镜像,并从 ConfigMapmysqlpw中获取环境变量MYSQL_ROOT_PASSWORD的值。 -
kubectl exec -it mysql -- mysql -uroot -pABCabc123:此命令将使用kubectl工具在运行名为mysql的 Pod 的容器中执行命令。命令是mysql -uroot -pABCabc123,意味着以root用户身份连接到 MySQL 数据库,并提供密码ABCabc123。 -
kubectl describe configmaps mysqlpass:此命令将使用kubectl工具获取名为mysqlpass的 ConfigMap 的详细信息,包括名称、命名空间、数据等。 -
kubectl delete -f cmenv.yml:此命令将使用kubectl工具根据cmenv.yml文件中的配置删除先前创建的 Pod。
总结
以上是今天要讲的内容,学到了Volume 挂载 ConfigMap,环境变量 ConfigMap。



















