epamedp/keycloak-operator| :heavy_exclamation_mark: 请参考KubeRocketCI文档获取主要概念和指南。 |
|---|
本文介绍Keycloak Operator的基本信息、安装流程、快速入门及本地开发指南。
Keycloak Operator是KubeRocketCI的操作器,负责配置现有的Keycloak实例,可在OpenShift和Kubernetes上运行。
注意: 操作器是平台无关的,因此部署说明是统一的。
安装Keycloak Operator请遵循以下步骤:
运行以下命令为本地客户端添加Helm EPAMEDP Charts仓库:
bashhelm repo add epamedp [***]
选择可用的Helm chart版本:
bashhelm search repo epamedp/keycloak-operator -l NAME CHART VERSION APP VERSION DESCRIPTION epamedp/keycloak-operator 1.24.0 1.24.0 A Helm chart for EDP Keycloak Operator epamedp/keycloak-operator 1.23.0 1.23.0 A Helm chart for EDP Keycloak Operator
注意: 强烈建议使用最新稳定版本。
完整的chart参数可在deploy-templates/README.md中查看。
使用helm命令在
bashhelm install keycloak-operator epamedp/keycloak-operator --version <chart_version> --namespace <edp-project> --set name=keycloak-operator
检查
在Keycloak的Master领域中创建用户,并分配create-realm角色。
将新创建的用户凭据插入Kubernetes Secret:
yamlapiVersion: v1 kind: Secret metadata: name: keycloak-access type: Opaque data: username: dXNlcg== # "user"的base64编码值 password: cGFzcw== # "pass"的base64编码值
创建kind: Keycloak自定义资源,包含Keycloak实例URL和上一步创建的secret:
yamlapiVersion: v1.edp.epam.com/v1 kind: Keycloak metadata: name: keycloak-sample spec: secret: keycloak-access # Secret名称 url: [***] # Keycloak URL
等待.status字段出现status.connected: true。
使用自定义资源创建Keycloak领域和组:
yamlapiVersion: v1.edp.epam.com/v1 kind: KeycloakRealm metadata: name: keycloakrealm-sample spec: realmName: realm-sample keycloakRef: name: keycloak-sample kind: Keycloak
yamlapiVersion: v1.edp.epam.com/v1 kind: KeycloakRealmGroup metadata: name: argocd-admins spec: name: ArgoCDAdmins realmRef: name: keycloakrealm-sample kind: KeycloakRealm
更多示例请查看可用自定义资源和CR模板文件夹。
要防止操作器从Keycloak中删除资源,可向资源添加edp.epam.com/preserve-resources-on-deletion: "true"注解:
yamlapiVersion: v1.edp.epam.com/v1 kind: KeycloakRealm metadata: name: keycloakrealm-sample annotations: edp.epam.com/preserve-resources-on-deletion: "true" spec: realmName: realm-sample keycloakRef: name: keycloak-sample kind: Keycloak
要开发操作器,请先设置本地环境,并参考本地开发页面。
开发版本也可从snapshot Helm Chart仓库获取。
manifest unknown 错误
TLS 证书验证失败
DNS 解析超时
410 错误:版本过低
402 错误:流量耗尽
身份认证失败错误
429 限流错误
凭证保存错误
来自真实用户的反馈,见证轩辕镜像的优质服务