第 2 章 使用 Dex 为 Argo CD 配置 SSO
安装 Red Hat OpenShift GitOps Operator 后,Argo CD 会自动创建一个具有 admin
权限的用户。要管理多个用户,集群管理员可以使用 Argo CD 来配置 Single Sign-On(SSO)。
ArgoCD CR 中的 spec.dex
参数不再支持 Red Hat OpenShift GitOps v1.10.0。考虑改用 .spec.sso
参数。
2.1. 配置以启用 Dex OpenShift OAuth Connector
对于 Operator 创建的所有 Argo CD 实例,默认安装 Dex。您可以通过设置 .spec.sso
参数,将 Red Hat OpenShift GitOps 配置为使用 Dex 作为 SSO 身份验证供应商。
Dex 通过检查平台提供的 OAuth
服务器,使用 OpenShift Container Platform 中定义的用户和组。
流程
要启用 Dex,请在 Operator 的 YAML 资源中将
.spec.sso.provider
参数设置为dex
:# ... spec: sso: provider: dex dex: openShiftOAuth: true 1 # ...
- 1
openShiftOAuth
属性触发 Operator,当值设为true
时自动配置内置 OpenShift Container PlatformOAuth
服务器。
2.1.1. 将用户映射到特定的角色
如果有直接 ClusterRoleBinding
角色,Argo CD 无法将用户映射到特定角色。您可以通过 OpenShift,手动更改 SSO 上的 role:admin
角色。
流程
创建名为
cluster-admins
的组。$ oc adm groups new cluster-admins
将用户添加到组。
$ oc adm groups add-users cluster-admins USER
将
cluster-admin
ClusterRole
应用到组:$ oc adm policy add-cluster-role-to-group cluster-admin cluster-admins