通过文件将 Pod 信息呈现给容器

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

    这两种呈现 Pod 和容器字段的方式都称为 downward API

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

    在这部分的练习中,你将创建一个包含一个容器的 Pod,并将 Pod 级别的字段作为文件投射到正在运行的容器中。 Pod 的清单如下:

    pods/inject/dapi-volume.yaml

    在 Pod 清单中,你可以看到 Pod 有一个 downwardAPI 类型的卷,并且挂载到容器中的 /etc/podinfo 目录。

    查看 downwardAPI 下面的 items 数组。 数组的每个元素定义一个 downwardAPI 卷。 第一个元素指示 Pod 的 metadata.labels 字段的值保存在名为 labels 的文件中。 第二个元素指示 Pod 的 annotations 字段的值保存在名为 annotations 的文件中。

    说明:

    本示例中的字段是 Pod 字段,不是 Pod 中容器的字段。

    创建 Pod:

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

    查看容器的日志:

    1. kubectl logs kubernetes-downwardapi-volume-example

    输出显示 labels 文件和 annotations 文件的内容:

    1. cluster="test-cluster1"
    2. rack="rack-22"
    3. zone="us-est-coast"
    4. build="two"
    5. builder="john-doe"

    进入 Pod 中运行的容器,打开一个 Shell:

    在该 Shell中,查看 labels 文件:

    1. /# cat /etc/podinfo/labels

    输出显示 Pod 的所有标签都已写入 labels 文件。

    1. cluster="test-cluster1"
    2. rack="rack-22"
    3. zone="us-est-coast"

    同样,查看 annotations 文件:

    1. /# cat /etc/podinfo/annotations

    查看 /etc/podinfo 目录下的文件:

    1. /# ls -laR /etc/podinfo

    在输出中可以看到,labelsannotations 文件都在一个临时子目录中。 在这个例子中,这个临时子目录为 ..2982_06_02_21_47_53.299460680。 在 /etc/podinfo 目录中,..data 是指向该临时子目录的符号链接。 另外在 /etc/podinfo 目录中, 和 annotations 也是符号链接。

    用符号链接可实现元数据的动态原子性刷新;更新将写入一个新的临时目录, 然后通过使用 完成 ..data 符号链接的原子性更新。

    说明:

    退出 Shell:

    1. /# exit

    前面的练习中,你使用 downward API 使 Pod 级别的字段可以被 Pod 内正在运行的容器访问。 接下来这个练习,你将只传递由 Pod 定义的部分的字段到 Pod 内正在运行的容器中, 但这些字段取自特定而不是整个 Pod。 下面是一个同样只有一个容器的 Pod 的清单:

    pods/inject/dapi-volume-resources.yaml 通过文件将 Pod 信息呈现给容器 - 图2

    1. apiVersion: v1
    2. kind: Pod
    3. metadata:
    4. name: kubernetes-downwardapi-volume-example-2
    5. containers:
    6. - name: client-container
    7. image: registry.k8s.io/busybox:1.24
    8. command: ["sh", "-c"]
    9. args:
    10. - while true; do
    11. echo -en '\n';
    12. if [[ -e /etc/podinfo/cpu_limit ]]; then
    13. echo -en '\n'; cat /etc/podinfo/cpu_limit; fi;
    14. if [[ -e /etc/podinfo/cpu_request ]]; then
    15. echo -en '\n'; cat /etc/podinfo/cpu_request; fi;
    16. if [[ -e /etc/podinfo/mem_limit ]]; then
    17. echo -en '\n'; cat /etc/podinfo/mem_limit; fi;
    18. if [[ -e /etc/podinfo/mem_request ]]; then
    19. echo -en '\n'; cat /etc/podinfo/mem_request; fi;
    20. sleep 5;
    21. done;
    22. resources:
    23. requests:
    24. memory: "32Mi"
    25. cpu: "125m"
    26. limits:
    27. memory: "64Mi"
    28. cpu: "250m"
    29. volumeMounts:
    30. - name: podinfo
    31. mountPath: /etc/podinfo
    32. volumes:
    33. items:
    34. - path: "cpu_limit"
    35. resourceFieldRef:
    36. containerName: client-container
    37. resource: limits.cpu
    38. divisor: 1m
    39. - path: "cpu_request"
    40. resourceFieldRef:
    41. containerName: client-container
    42. resource: requests.cpu
    43. divisor: 1m
    44. - path: "mem_limit"
    45. resourceFieldRef:
    46. containerName: client-container
    47. resource: limits.memory
    48. divisor: 1Mi
    49. - path: "mem_request"
    50. resourceFieldRef:
    51. containerName: client-container
    52. resource: requests.memory
    53. divisor: 1Mi

    在这个清单中,你可以看到 Pod 有一个 , 并且这个卷会挂载到 Pod 内的单个容器的 /etc/podinfo 目录。

    查看 downwardAPI 下面的 items 数组。 数组的每个元素定义一个 downwardAPI 卷。

    第一个元素指定在名为 client-container 的容器中, 以 1m 所指定格式的 limits.cpu 字段的值应推送到名为 cpu_limit 的文件中。 divisor 字段是可选的,默认值为 1。1 的除数表示 CPU 资源的核数或内存资源的字节数。

    创建 Pod:

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

    打开一个 Shell,进入 Pod 中运行的容器:

    1. kubectl exec -it kubernetes-downwardapi-volume-example-2 -- sh

    在 Shell 中,查看 cpu_limit 文件:

    你可以使用同样的命令查看 cpu_request、 和 mem_request 文件。

    • 参阅 Pod spec API 的定义,其中包括了容器(Pod 的一部分)的定义。
    • 参阅你可以使用 downward API 公开的列表。

    阅读旧版的 API 参考中关于卷的内容:

    • 参阅 Volume API 定义,该 API 在 Pod 中定义通用卷以供容器访问。
    • 参阅 API 定义,该 API 定义包含 Downward API 信息的卷。
    • 参阅 DownwardAPIVolumeFile API 定义,该 API 包含对对象或资源字段的引用,用于在 Downward API 卷中填充文件。
    • 参阅 API 定义,该 API 指定容器资源及其输出格式。