为 Windows 的 Pod 和容器配置 RunAsUserName

    本页展示如何为运行为在 Windows 节点上运行的 Pod 和容器配置 RunAsUserName。 大致相当于 Linux 上的 runAsUser,允许在容器中以与默认值不同的用户名运行应用。

    你必须有一个 Kubernetes 集群,并且 kubectl 必须能和集群通信。 集群应该要有 Windows 工作节点,将在其中调度运行 Windows 工作负载的 pod 和容器。

    要指定运行 Pod 容器时所使用的用户名,请在 Pod 声明中包含 securityContext (PodSecurityContext) 字段, 并在其内部包含 windowsOptions () 字段的 runAsUserName 字段。

    你为 Pod 指定的 Windows SecurityContext 选项适用于该 Pod 中(包括 init 容器)的所有容器。

    这儿有一个已经设置了 runAsUserName 字段的 Windows Pod 的配置文件:

    windows/run-as-username-pod.yaml

    创建 Pod:

    1. kubectl apply -f https://k8s.io/examples/windows/run-as-username-pod.yaml
    1. kubectl get pod run-as-username-pod-demo

    获取该容器的 shell:

    1. kubectl exec -it run-as-username-pod-demo -- powershell

    检查运行 shell 的用户的用户名是否正确:

    输出结果应该是这样:

    1. ContainerUser

    要指定运行容器时所使用的用户名,请在容器清单中包含 securityContext (SecurityContext) 字段,并在其内部包含 windowsOptions () 字段的 runAsUserName 字段。

    你为容器指定的 Windows SecurityContext 选项仅适用于该容器,并且它会覆盖 Pod 级别设置。

    这里有一个 Pod 的配置文件,其中只有一个容器,并且在 Pod 级别和容器级别都设置了 runAsUserName

    windows/run-as-username-container.yaml 为 Windows 的 Pod 和容器配置 RunAsUserName - 图2

    1. apiVersion: v1
    2. kind: Pod
    3. metadata:
    4. spec:
    5. securityContext:
    6. windowsOptions:
    7. runAsUserName: "ContainerUser"
    8. containers:
    9. - name: run-as-username-demo
    10. image: mcr.microsoft.com/windows/servercore:ltsc2019
    11. command: ["ping", "-t", "localhost"]
    12. securityContext:
    13. windowsOptions:
    14. runAsUserName: "ContainerAdministrator"
    15. nodeSelector:
    1. kubectl apply -f https://k8s.io/examples/windows/run-as-username-container.yaml

    验证 Pod 容器是否在运行:

    获取该容器的 shell:

    1. kubectl exec -it run-as-username-container-demo -- powershell

    检查运行 shell 的用户的用户名是否正确(应该是容器级别设置的那个):

    1. echo $env:USERNAME

    输出结果应该是这样:

    1. ContainerAdministrator

    想要使用此功能,在 字段中设置的值必须是有效的用户名。 它必须是 DOMAIN\USER 这种格式,其中 DOMAIN\ 是可选的。 Windows 用户名不区分大小写。此外,关于 DOMAINUSER 还有一些限制:

    • runAsUserName 字段不能为空,并且不能包含控制字符(ASCII 值:0x00-0x1F0x7F
    • DOMAIN 必须是 NetBios 名称或 DNS 名称,每种名称都有各自的局限性:
      • NetBios 名称:最多 15 个字符,不能以 .(点)开头,并且不能包含以下字符:\ / : * ? " < > |
      • DNS 名称:最多 255 个字符,只能包含字母、数字、点和中划线,并且不能以 .(点)或 -(中划线)开头和结尾。
    • USER 最多不超过 20 个字符,不能 包含点或空格,并且不能包含以下字符:" / \ [ ] : ; | = , + * ? < > @

    runAsUserName 字段接受的值的一些示例:ContainerAdministratorContainerUser、 、NT AUTHORITY\LOCAL SERVICE

    关于这些限制的更多信息,可以查看这里和。