通过环境变量将 Pod 信息呈现给容器

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

    To check the version, enter .

    有两种方式可以将 Pod 和 Container 字段呈现给运行中的容器:

    • 环境变量

    这两种呈现 Pod 和 Container 字段的方式统称为 Downward API

    在这个练习中,你将创建一个包含一个容器的 Pod。这是该 Pod 的配置文件:

    pods/inject/dapi-envars-pod.yaml

    这个配置文件中,你可以看到五个环境变量。env 字段是一个 . 对象的数组。 数组中第一个元素指定 MY_NODE_NAME 这个环境变量从 Pod 的 spec.nodeName 字段获取变量值。 同样,其它环境变量也是从 Pod 的字段获取它们的变量值。

    创建Pod:

    1. kubectl apply -f https://k8s.io/examples/pods/inject/dapi-envars-pod.yaml

    验证 Pod 中的容器运行正常:

      查看容器日志:

      1. kubectl logs dapi-envars-fieldref

      输出信息显示了所选择的环境变量的值:

      要了解为什么这些值在日志中,请查看配置文件中的command 和 字段。 当容器启动时,它将五个环境变量的值写入 stdout。每十秒重复执行一次。

      接下来,通过打开一个 Shell 进入 Pod 中运行的容器:

      1. kubectl exec -it dapi-envars-fieldref -- sh

      在 Shell 中,查看环境变量:

      1. /# printenv
      1. MY_POD_SERVICE_ACCOUNT=default
      2. ...
      3. MY_POD_NAMESPACE=default
      4. MY_POD_IP=172.17.0.4
      5. ...
      6. ...

      前面的练习中,你将 Pod 字段作为环境变量的值。 接下来这个练习中,你将用 Container 字段作为环境变量的值。这里是包含一个容器的 Pod 的配置文件:

      pods/inject/dapi-envars-container.yaml

      这个配置文件中,你可以看到四个环境变量。env 字段是一个 . 对象的数组。数组中第一个元素指定 MY_CPU_REQUEST 这个环境变量从 Container 的 requests.cpu 字段获取变量值。同样,其它环境变量也是从 Container 的字段获取它们的变量值。

      Note: 本例中使用的是 Container 的字段而不是 Pod 的字段。

      创建Pod:

      1. kubectl apply -f https://k8s.io/examples/pods/inject/dapi-envars-container.yaml

      验证 Pod 中的容器运行正常:

      1. kubectl get pods

      查看容器日志:

      最后修改 December 14, 2020 at 6:35 PM PST: