Install the Run:ai Control Plane¶
Prerequisites and preparations¶
Make sure you have followed the Control Plane prerequisites and preparations.
Helm Install¶
Run the helm command below:
helm repo add runai-backend https://runai.jfrog.io/artifactory/cp-charts-prod
helm repo update
helm upgrade -i runai-backend -n runai-backend runai-backend/control-plane --version "~2.18.0" \
--set global.domain=runai.apps.<OPENSHIFT-CLUSTER-DOMAIN> \ # (1)
--set global.config.kubernetesDistribution=openshift
- The subdomain configured for the OpenShift cluster.
Info
To install a specific version, add --version <version>
to the install command. You can find available versions by running helm search repo -l runai-backend
.
helm upgrade -i runai-backend ./control-plane-<version>.tgz -n runai-backend \
--set global.domain=runai.apps.<OPENSHIFT-CLUSTER-DOMAIN> \ # (1)
--set global.config.kubernetesDistribution=openshift \
--set global.customCA.enabled=true \ # (2)
-f custom-env.yaml # (3)
- The domain configured for the OpenShift cluster. To find out the OpenShift cluster domain, run
oc get routes -A
- See the Local Certificate Authority instructions below
custom-env.yaml
should have been created by the prepare installation script in the previous section.
(replace <version>
with the control plane version)
Tip
Use the --dry-run
flag to gain an understanding of what is being installed before the actual installation.
Additional Run:ai configurations (optional)¶
There may be cases where you need to set additional properties, To apply the changes run helm upgrade
and use --set
to set specific configurations, and restart the relevant Run:ai pods so they can fetch the new configurations.
Key | Change | Description |
---|---|---|
<component> resources: limits: cpu: 500m memory: 512Mi requests: cpu: 250m memory: 256Mi | Pod request and limits | Set Run:ai and 3rd party services' resources |
Additional 3rd party configurations (optional)¶
The Run:ai Control Plane chart, includes multiple sub-charts of 3rd party components:
- PostgreSQL - Data store
- Keycloakx - Identity & Access Management
- Grafana - Analytics Dashboard
- Redis - Caching (Disabled, by default)
Tip
Click on any component, to view it's chart values and configurations
If you have opted to connect to an external PostgreSQL database, refer to the additional configurations table below. Adjust the following parameters based on your connection details:
- Disable PostgreSQL deployment -
postgresql.enabled
- Run:ai connection details -
global.postgresql.auth
- Grafana connection details -
grafana.dbUser
,grafana.dbPassword
PostgreSQL¶
Key | Change | Description |
---|---|---|
postgresql.enabled | PostgreSQL installation | If set to false the PostgreSQL will not be installed |
global.postgresql.auth.host | PostgreSQL host | Hostname or IP address of the PostgreSQL server |
global.postgresql.auth.port | PostgreSQL port | Port number on which PostgreSQL is running |
global.postgresql.auth.username | PostgreSQL username | Username for connecting to PostgreSQL |
global.postgresql.auth.password | PostgreSQL password | Password for the PostgreSQL user specified by global.postgresql.auth.username |
global.postgresql.auth.postgresPassword | PostgreSQL default admin password | Password for the built-in PostgreSQL superuser (postgres ) |
global.postgresql.auth.existingSecret | Postgres Credentials (secret) | Existing secret name with authentication credentials |
postgresql.primary.initdb.password | PostgreSQL default admin password | Set the same password as in global.postgresql.auth.postgresPassword (if changed) |
postgresql.primary.persistence.storageClass | Storage class | The installation to work with a specific storage class rather than the default one |
Keycloakx¶
Key | Change | Description |
---|---|---|
keycloakx.adminUser | User name of the internal identity provider administrator | This user is the administrator of Keycloak |
keycloakx.adminPassword | Password of the internal identity provider administrator | This password is for the administrator of Keycloak |
keycloakx.existingSecret | Keycloakx credentials (secret) | Existing secret name with authentication credentials |
global.keycloakx.host | KeyCloak (Run:ai internal identity provider) host path | Override the DNS for Keycloak. This can be used to access Keycloak from outside the Run:ai Control Plane cluster via ingress |
Grafana¶
Key | Change | Description |
---|---|---|
grafana.db.existingSecret | Grafana database connection credentials (secret) | Existing secret name with authentication credentials |
grafana.dbUser | Grafana database username | Username for accessing the Grafana database |
grafana.dbPassword | Grafana database password | Password for the Grafana database user |
grafana.admin.existingSecret | Grafana admin default credentials (secret) | Existing secret name with authentication credentials |
grafana.adminUser | Grafana username | Override the Run:ai default user name for accessing Grafana |
grafana.adminPassword | Grafana password | Override the Run:ai default password for accessing Grafana |
Redis¶
Key | Change | Description |
---|---|---|
redisCache.auth.password | Redis (Runai internal cache mechanism) applicative password | Override the default password |
redisCache.auth.existingSecret | Redis credentials (secret) | Existing secret name with authentication credentials |
Next steps¶
Connect to Run:ai user interface¶
- Run:
oc get routes -n runai-backend
to find the Run:ai Administration User Interface URL. - Log in using the default credentials: User:
[email protected]
, Password:Abcd!234
. - Go to the Users area and change the password.
Enable Forgot Password (optional)¶
To support the Forgot password functionality, follow the steps below.
- Go to
runai.<openshift-cluster-domain>/auth
and Log in. - Under
Realm settings
, select theLogin
tab and enable theForgot password
feature. - Under the
Email
tab, define an SMTP server, as explained here
Install Run:ai Cluster¶
Continue with installing a Run:ai Cluster.