Keycloak📜
Overview📜
Keycloak provides open source identity and access management for modern applications and services. This document will cover the architectural touchpoints for the Big Bang Keycloak package, which has been extended to include customizable registration and group segmentation.
Keycloak Architecture📜
graph LR
    urlkc(Keycloak URL) -->|HTTPS| pg
    urlpr(Prometheus URL) -->|HTTPS| ig
    subgraph "Istio System"
        ig(Public Gateway)
        pg(Passthrough Gateway)
    end
    subgraph "Monitoring"
        ig --> servpr("Service<BR>Prometheus") --> prom
        prom(Prometheus)
    end
    subgraph "Keycloak"
        pg --> servkc("Service<BR>Keycloak") --> pod0("Keycloak Pod 0")
        prom --> monitor(Service Monitor CRD) --> servkc
    end
    pod0("Keycloak Pod 0") --> db[(Keycloak DB)]Integration with Big Bang📜
Big Bang’s integration with Keycloak requires special considerations and configuration compared to other applications. This document will help you set it up.
Configuration📜
See Keycloak Configuration in the Big Bang Keycloak Helm chart repo for help configuring the following:
- TLS Certificates
- Custom Admin Password
- Registration Plugin
- Keycloak Helm values
Big Bang Touch-points📜
GUI📜
Keycloak has two main end point URLs: https://keycloak.yourdomain.com for authentication. https://keycloak.yourdomain.com/auth/admin for administration.
The yourdomain.com domain name can be customized by setting the value domain
in Big Bang’s values.yaml
Database📜
An external shared database is required for Keycloak operation in production. It should be setup according to the Keycloak database configuration documentation.
For development and testing, a Postgres database is provided inside the cluster. This should NOT be used in production.
The following values can be customized in Big Bang’s values.yaml to connect to
your external database:
addons:
  keycloak:
    values:
      upstream:
        database:
          hostname: yourdb.yourdomain.com
          vendor: postgres
          port: 5432
          database: keycloak
          username: kcuser
          password: p@ssw0rd
Logging📜
Logging is automatic for Keycloak when the Logging package is enabled in Big Bang. Fluentbit captures the logs and ships them to Elastic.
Monitoring📜
When the Monitoring package is enabled, Big Bang will turn on Keycloak’s
production of Prometheus metrics and set up a Service Monitor to scrape those
metrics. By default, metrics for the datasources (db), undertow (http), and
jgroup subsystems are enabled.
Health Checks📜
Liveness and readiness probes are included in the Keycloak Helm chart for all
deployments. The probes check the endpoint at /auth/realm/master/ on port 8080
of the pods. This means the probes will still succeed even if you have an
invalid certificate loaded into Keycloak.
If you wish to adjust the probes, you can override the values in values.yaml:
addons:
  keycloak:
    upstream:
      values:
        livenessProbe: |
          httpGet:
            path: /auth/realms/master
            port: http
            scheme: HTTP
          initialDelaySeconds: 120
          failureThreshold: 15
          periodSeconds: 15
        readinessProbe: |
          httpGet:
            path: /auth/realms/master
            port: http
            scheme: HTTP
          initialDelaySeconds: 120
          failureThreshold: 15
          timeoutSeconds: 2
Licensing📜
Keycloak is available under the Apache License 2.0 for free.
High Availability📜
By default, Big Bang deploys Keycloak via a stateful set with one replica. It is
already configured to support cache sharing, anti-affinity, fail-overs, and
rolling updates. If you wish to increase the number of replicas you must first
make sure you are pointed to an external database, and then the replicas can be
increased, all of which can be set in values.yaml:
addons:
  keycloak:
    values:
      upstream:
        replicas: 3 # Override the default
The Keycloak package also comes with a HorizontalPodAutoscaler resource which
can be enabled. Enabling the HPA will overwrite the replicas key shown above:
addons:
  keycloak:
    values:
      upstream:
        autoscaling:
          enabled: true
          minReplicas: 2
          maxReplicas: 4
Dependent Packages📜
- Istio for ingress
- (Optional) Monitoring for metrics
- PostgreSQL database (development/test only)