管理服务账号

    对鉴权和用户账号的支持已在规划中,当前并不完备。 为了更好地描述服务账号,有时这些不完善的特性也会被提及。

    Kubernetes 区分用户账号和服务账号的概念,主要基于以下原因:

    • 用户账号是全局性的。其名称跨集群中名字空间唯一的。服务账号是名字空间作用域的。
    • 通常情况下,集群的用户账号可能会从企业数据库进行同步,其创建需要特殊权限, 并且涉及到复杂的业务流程。 服务账号创建有意做得更轻量,允许集群用户为了具体的任务创建服务账号 以遵从权限最小化原则。
    • 对人员和服务账号审计所考虑的因素可能不同。
    • 针对复杂系统的配置包可能包含系统组件相关的各种服务账号的定义。因为服务账号 的创建约束不多并且有名字空间域的名称,这种配置是很轻量的。

    服务账号的自动化

    三个独立组件协作完成服务账号相关的自动化:

    • 准入控制器
    • Token 控制器
    • ServiceAccount 控制器

    对 Pod 的改动通过一个被称为 的插件来实现。它是 API 服务器的一部分。 当 Pod 被创建或更新时,它会同步地修改 Pod。 如果该插件处于激活状态(在大多数发行版中都是默认激活的),当 Pod 被创建 或更新时它会进行以下操作:

    1. 如果该 Pod 没有设置 ServiceAccount,将其 ServiceAccount 设为 default
    2. 如果服务账号的 automountServiceAccountToken 或 Pod 的 automountServiceAccountToken 都未显式设置为 ,则为 Pod 创建一个 volume,在其中包含用来访问 API 的令牌。
    3. 如果前一步中为服务账号令牌创建了卷,则为 Pod 中的每个容器添加一个 volumeSource,挂载在其 /var/run/secrets/kubernetes.io/serviceaccount 目录下。
    4. 如果 Pod 不包含 imagePullSecrets 设置,将 ServiceAccount 所引用 的服务账号中的 imagePullSecrets 信息添加到 Pod 中。

    绑定的服务账号令牌卷

    ServiceAccount 准入控制器将添加如下投射卷,而不是为令牌控制器 所生成的不过期的服务账号令牌而创建的基于 Secret 的卷。

    此投射卷有三个数据源:

    1. 通过 TokenRequest API 从 kube-apiserver 处获得的 ServiceAccountToken。 这一令牌默认会在一个小时之后或者 Pod 被删除时过期。 该令牌绑定到 Pod 实例上,并将 kube-apiserver 作为其受众(audience)。
    2. 包含用来验证与 kube-apiserver 连接的 CA 证书包的 ConfigMap 对象。 这一特性依赖于 特性门控。该特性被启用时, 控制面会公开一个名为 kube-root-ca.crt 的 ConfigMap 给所有名字空间。 RootCAConfigMap 在 1.21 版本中进入 GA 状态,默认被启用, 该特性门控会在 1.22 版本中从 --feature-gate 参数中删除。
    3. 引用 Pod 名字空间的一个 DownwardAPI。

    参阅 了解进一步的细节。

    TokenController 作为 kube-controller-manager 的一部分运行,以异步的形式工作。 其职责包括:

    • 监测 ServiceAccount 的创建并创建相应的服务账号令牌 Secret 以允许访问 API。
    • 监测 ServiceAccount 的删除并删除所有相应的服务账号令牌 Secret。
    • 监测服务账号令牌 Secret 的删除,如有需要,从相应的 ServiceAccount 中移除引用。

    创建额外的 API 令牌

    控制器中有专门的循环来保证每个 ServiceAccount 都存在对应的包含 API 令牌的 Secret。 当需要为 ServiceAccount 创建额外的 API 令牌时,可以创建一个类型为 的 Secret,并在其注解中引用对应的 ServiceAccount。控制器会生成令牌并更新该 Secret:

    下面是这种 Secret 的一个示例配置:

    删除/废止服务账号令牌 Secret

    服务账号控制器管理各名字空间下的 ServiceAccount 对象,并且保证每个活跃的 名字空间下存在一个名为 “default” 的 ServiceAccount。

    最后修改 November 16, 2021 at 8:46 AM PST: remove useless content (89d06b512)