设置外部身份验证
本文档描述了如何在 KubeSphere 上使用外部身份提供者,例如 LDAP 服务或 Active Directory 服务。
KubeSphere 提供了一个内置的 OAuth 服务。用户通过获取 OAuth 访问令牌以对 API 进行身份验证。作为 KubeSphere 管理员,您可以编辑 CRD ClusterConfiguration
中的 ks-installer
来配置 OAuth 并指定身份提供者。
准备工作
您需要部署一个 Kubernetes 集群,并在集群中安装 KubeSphere。有关详细信息,请参阅在 Linux 上安装和在 Kubernetes 上安装。
步骤
-
以
admin
身份登录 KubeSphere,将光标移动到右下角 ,点击 kubectl,然后执行以下命令来编辑 CRDClusterConfiguration
中的ks-installer
:kubectl -n kubesphere-system edit cc ks-installer
-
在
spec.authentication.jwtSecret
字段下添加以下字段。示例:
spec: authentication: jwtSecret: '' authenticateRateLimiterMaxTries: 10 authenticateRateLimiterDuration: 10m0s loginHistoryRetentionPeriod: 168h maximumClockSkew: 10s multipleLogin: true oauthOptions: accessTokenMaxAge: 1h accessTokenInactivityTimeout: 30m identityProviders: - name: LDAP type: LDAPIdentityProvider mappingMethod: auto provider: host: 192.168.0.2:389 managerDN: uid=root,cn=users,dc=nas managerPassword: ******** userSearchBase: cn=users,dc=nas loginAttribute: uid mailAttribute: mail
字段描述如下:
jwtSecret
:签发用户令牌的密钥。在多集群环境下,所有的集群必须使用相同的密钥。authenticateRateLimiterMaxTries
:authenticateLimiterDuration
指定的期间内允许的最大连续登录失败次数。如果用户连续登录失败次数达到限制,则该用户将被封禁。authenticateRateLimiterDuration
:authenticateRateLimiterMaxTries
适用的时间段。loginHistoryRetentionPeriod
:用户登录记录保留期限,过期的登录记录将被自动删除。maximumClockSkew
:时间敏感操作(例如验证用户令牌的过期时间)的最大时钟偏差,默认值为10秒。multipleLogin
:是否允许多个用户同时从不同位置登录,默认值为true
。oauthOptions
:accessTokenMaxAge
:访问令牌有效期。对于多集群环境中的成员集群,默认值为0h
,这意味着访问令牌永不过期。对于其他集群,默认值为2h
。accessTokenInactivityTimeout
:令牌空闲超时时间。该值表示令牌过期后,刷新用户令牌最大的间隔时间,如果不在此时间窗口内刷新用户身份令牌,用户将需要重新登录以获得访问权。identityProviders
:name
:身份提供者的名称。type
:身份提供者的类型。mappingMethod
:帐户映射方式,值可以是auto
或者lookup
。- 如果值为
auto
(默认),需要指定新的用户名。通过第三方帐户登录时,KubeSphere 会根据用户名自动创建关联帐户。 - 如果值为
lookup
,需要执行步骤 3 以手动关联第三方帐户与 KubeSphere 帐户。 provider
:身份提供者信息。此部分中的字段根据身份提供者的类型而异。
-
如果
mappingMethod
设置为lookup
,可以运行以下命令并添加标签来进行帐户关联。如果mappingMethod
是auto
可以跳过这个部分。kubectl edit user <KubeSphere username>
labels: iam.kubesphere.io/identify-provider: <Identity provider name> iam.kubesphere.io/origin-uid: <Third-party username>
-
字段配置完成后,保存修改,然后等待 ks-installer 重启完成。
备注
多集群环境中,只需要在主集群中进行配置。
身份提供者
您可以在 identityProviders
部分中配置多个身份提供者(IdPs)。身份提供者会对用户进行认证,并向 KubeSphere 提供身份令牌。
KubeSphere 默认提供了以下几种类型的身份提供者:
您也可以拓展 KubeSphere OAuth2 认证插件 与您的帐户系统进行集成。
反馈
这篇文章对您有帮助吗?
通过邮件接收 KubeSphere 最新的技术博客与产品更新的通知
感谢您的反馈。如果您有关于如何使用 KubeSphere 的具体问题,请在 Slack 上提问。如果您想报告问题或提出改进建议,请在 GitHub 存储库中打开问题。