InstallationDeployDeploy to OpenShift

Deploy MOSTLY AI to an OpenShift cluster

You can install MOSTLY AI in an OpenShift cluster. This page covers the list of prerequisites you need and the steps for a successful installation.

Prerequisites

  • An OpenShift (4.2 or higher) cluster
  • Install helm.
  • Install OpenShift CLI tools.
  • Log in to your cluster. See Logging in to the OpenShift CLI.
  • Internet connectivity to pull the Docker images from the MOSTLY AI repository.
  • Fully-qualified domain name (FQDN) for the MOSTLY AI application. A TLS certificate is optional.
  • Obtain deployment details from your Customer Experience Engineer.
    • MOSTLY AI Helm chart
    • Secret key to access the MOSTLY AI image repository
    • First-time log in credentials for the MOSTLY AI application

Steps

  1. Create the mostly-ai namespace in your OpenShift cluster.
    oc new-project mostly-ai
  2. Unarchive the MOSTLY AI Helm chart and from a terminal or a command line, change directory to the one that contains your MOSTLY_AI_helm_charts.
    cd MOSTLY_AI_helm_charts
  3. Open the ocp-values.yaml file in an editor. You set the configurations required to deploy MOSTLI AI in an OpenShift cluster in this file.
  4. Set the fully-qualified domain name (FQDN) of your organization.
    1. Set your FQDN for the fqdn:, host: and hostname: keys accordingly.

      The excerpt below shows mostlyai.your-organization.com as the configured FQDN. Replace it with your FQDN.
      ocp-values.yaml
      ...
      fqdn: mostlyai.your-organization.com
      ...
      host: loki.mostlyai.your-organization.com
      ...
      hostname: minio.mostlyai.your-organization.com
      ...
    2. (Optional) Apply one of the configurations below depending on whether you intend to use SSL-encrypted access to the MOSTLY AI application.

      ➡️ You use an SSL certificate. Replace your-tls-secret with the TLS secret name as defined in your cluster configuration.
      💡

      Your IT department or Kubernetes administrator creates the FQDN and its SSL certificate and adds it to the configuration of your cluster. When added, it comes with a TLS secret name that you can define in the ocp-values.yaml file. For details, see Configure your domain SSL certificate.

      ocp-values.yaml
      _customerInstallation:
      ...
        deploymentSettings:
          tlsSecretName: &tlsSecretName your-tls-secret
      ...
      ➡️ You do not use an SSL certificate. Replace the your-tls-secret with an empty string and, for global.tls, set enabled to false.
      ocp-values.yaml
      _customerInstallation:
      ...
        deploymentSettings:
          tlsSecretName: &tlsSecretName [] # your-tls-secret
      ...
      global:
        ...
        tls:
          enabled: false
      ...
  5. Set your Docker pull image secret key in the _customerInstallation.deploymentSettings.mostlyRegistryDockerConfigJson key. The secret key is your authentication for the MOSTLY AI Helm repository.
    ocp-values.yaml
    _customerInstallation:
    ...
      deploymentSettings:
    ...
        mostlyRegistryDockerConfigJson: &mostlyRegistryDockerConfigJson eyJh...
    ...
    Replace the default value after &mostlyRegistryDockerConfigJson (in the example above, this is eyJh...) with the Docker pull image secret key provided by your Customer Experience Engineer.

    The value must not be wrapped in quotation marks and the line should look similar to the following, where the ellipsis (…) indicates the remaining characters of the complete secret key.
    ocp-values.yaml
    ...
    mostlyRegistryDockerConfigJson: &mostlyRegistryDockerConfigJson exJhdXRocyI6eyJuZX...
    ...
  6. (Optional) Configure the image repository.
    1. If you have all of the necessary images to deploy MOSTLY AI in your internal repository, leave the URL of your repository under _customerInstallation.deploymentSettings.mostlyRegistry, replacing the existing value:
      ocp-values.yaml
      _customerInstallation:
      ...
        deploymentSettings:
      ...
          mostlyRegistry: &mostlyRegistry harbor.env.mostlylab.com/mostlyai
      ...
    2. If you are using an internal repository, you need to complete the following 2 steps.
      1. Set mostly-configuration.secrets.dockerConfig.create to false to prevent the creation of a Docker pull secret.
        ocp-values.yaml
        ...
        mostly-configurations:
          secrets:
            dockerConfig:
              create: false
      2. Map the name of the secret for your repository under global.image.mostlyPullSecret.
        ocp-values.yaml
        ...
        global:
           ...
           image:
             mostlyRegistry: *mostlyRegistry
             mostlyPullSecret: mostly-ai-docker-credentials-production
        ...
  7. Save your changes in the ocp-values.yaml file.
  8. Set the taint on the workers node on which MOSTLY AI compute jobs will run.
    Get a list of your worker nodes.
    oc get nodes
    Apply the taint to each node you intend to use as a worker node.
    oc taint nodes <node_name> scheduling.mostly.ai/node=engine-jobs:NoSchedule
    You should see the following:
    node/<node_name> tainted
    In the OpenShift web console, select Compute, then Nodes. Click under Taints to review the list of taints for the node. Taints on OpenShift nodes
  9. Deploy MOSTLY AI with helm from the same directory where you have the ocp-values.yaml file.
    helm upgrade --install mostly-ai ./mostly-combined --values ocp-values.yaml --namespace mostly-ai

What’s next

If all pods run as expected, you can log in for the first time to your MOSTLY AI deployment to set a new password for the superadmin user. Contact MOSTLY AI to obtain the superadmin credentials.

  1. In a web browser, open the FQDN for the deployment. Step result: Your Sign in page for your MOSTLY AI deployment opens. MOSTLY AI Deployment - Log in page
  2. Enter the superadmin credentials and click Sign in.
  3. Provide a new password and click Change password.

Your superadmin password is now changed and you can use it to log in again to your MOSTLY AI deployment.

You can run a quick test by following the Quick start for Model creators and Quick start for Data consumers.

If you run into issues, you can check the Troubleshoot OpenShift deployment issues.