通过环境变量将Pod信息呈现给容器
此页面显示了Pod如何使用环境变量把自己的信息呈现给pod中运行的容器。环境变量可以呈现pod的字段和容器字段。
有两种方式可以将Pod和Container字段呈现给运行中的容器: 环境变量 和DownwardAPIVolumeFiles. 这两种呈现Pod和Container字段的方式都称为*Downward API*。
准备开始
你必须拥有一个 Kubernetes 的集群,同时你的 Kubernetes 集群必须带有 kubectl 命令行工具。 如果你还没有集群,你可以通过 Minikube 构建一 个你自己的集群,或者你可以使用下面任意一个 Kubernetes 工具构建:
要获知版本信息,请输入 kubectl version
.
Downward API
有两种方式可以将Pod和Container字段呈现给运行中的容器:
这两种呈现Pod和Container字段的方式都称为*Downward API*。
用Pod字段作为环境变量的值
在这个练习中,你将创建一个包含一个容器的pod。这是该pod的配置文件:
pods/inject/dapi-envars-pod.yaml |
---|
|
这个配置文件中,你可以看到五个环境变量。env
字段是一个EnvVars类型的数组。 数组中第一个元素指定MY_NODE_NAME
这个环境变量从Pod的spec.nodeName
字段获取变量值。同样,其它环境变量也是从Pod的字段获取它们的变量值。
注意: 本示例中的字段是Pod字段,不是Pod中容器的字段。
创建Pod:
kubectl apply -f https://k8s.io/examples/pods/inject/dapi-envars-pod.yaml
验证Pod中的容器运行正常:
kubectl get pods
查看容器日志:
kubectl logs dapi-envars-fieldref
输出信息显示了所选择的环境变量的值:
minikube
dapi-envars-fieldref
default
172.17.0.4
default
要了解为什么这些值在日志中,请查看配置文件中的command
和 args
字段。 当容器启动时,它将五个环境变量的值写入stdout。每十秒重复执行一次。
接下来,进入Pod中运行的容器,打开一个shell:
kubectl exec -it dapi-envars-fieldref -- sh
在shell中,查看环境变量:
/# printenv
输出信息显示环境变量已经指定为Pod的字段的值。
MY_POD_SERVICE_ACCOUNT=default
...
MY_POD_NAMESPACE=default
MY_POD_IP=172.17.0.4
...
MY_NODE_NAME=minikube
...
MY_POD_NAME=dapi-envars-fieldref
用容器字段作为环境变量的值
前面的练习中,你将Pod字段作为环境变量的值。接下来这个练习,你将用容器字段作为环境变量的值。这里是包含一个容器的pod的配置文件:
pods/inject/dapi-envars-container.yaml |
---|
|
这个配置文件中,你可以看到四个环境变量。env
字段是一个EnvVars 类型的数组。数组中第一个元素指定MY_CPU_REQUEST
这个环境变量从容器的requests.cpu
字段获取变量值。同样,其它环境变量也是从容器的字段获取它们的变量值。
创建Pod:
kubectl apply -f https://k8s.io/examples/pods/inject/dapi-envars-container.yaml
验证Pod中的容器运行正常:
kubectl get pods
查看容器日志:
kubectl logs dapi-envars-resourcefieldref
输出信息显示了所选择的环境变量的值:
1
1
33554432
67108864