Install Lumigator on Kubernetes

This guide will walk you through the process of installing Lumigator on a Kubernetes cluster. The official way to deploy the Lumigator application in cloud environments with Kubernetes is to use the Helm package manager.

At this moment this Helm chart only deploys the Lumigator core REST API. We don’t provide support for Ray, S3-compatible storage, or the database which are required for the full application to run. In the near future, a new version of this chart will be released, which will be able to deploy a minimal version of all the required tools.

Warning

Lumigator needs an existing: S3 bucket, relational database and a Ray cluster in order to work as expected.

Prerequisites

To install Lumigator on a Kubernetes cluster, you need to have the following prerequisites:

  • A Kubernetes cluster running.

  • Helm installed in your Kubernetes cluster.

  • A S3-compatible storage bucket.

  • A relational database.

  • A Ray cluster.

Installation

To install Lumigator on a Kubernetes cluster, follow these steps:

  1. Clone the Lumigator repository:

    user@host:~$ git clone git@github.com:mozilla-ai/lumigator.git
    
  2. Change to the Lumigator directory:

    user@host:~$ cd lumigator
    
  3. Install the Lumigator Helm chart:

    user@host:~/lumigator$ helm install lumigator ./lumigator/infra/mzai/helm/lumigator
    

Configuration

The following table lists the configurable parameters of the Lumigator chart and their default values. On top of these, If the Mistral and/or the OpenAI API is used, there are two ways to provide it to Lumigator:

  • Using an existing Secret, whose name will be specified in property existingMistralAPISecret and/or existingOpenaiAPISecret

  • Using an explicit Mistral and/or OpenAI key in property mistralAPIKey and/or openaiAPIKey, which will be added in a new Secret.

Key

Default

Description

affinity

{}

Kubernetes rules for scheduling Pods on specific nodes

fullnameOverride

""

-

image.pullPolicy

"IfNotPresent"

The Kubernetes imagePullPolicy value

image.repository

""

Repository where the Lumigator image is located

image.tag

"1"

The Lumigator Docker image tag

imagePullSecrets

[]

Configuration for imagePullSecrets so that you can use a private registry for your image

nameOverride

""

-

nodeSelector

{}

Configurable nodeSelector so that you can target specific nodes

podAnnotations

{}

Configurable annotations applied to all pods

podSecurityContext

{}

Security settings applied to the pod

existingMistralAPISecret

``

Name of an existing Secret that contains the Mistral key

mistralAPIKey

``

Mistral key to be added as a Secret

existingOpenaiAPISecret

``

Name of an existing Secret that contains the OpenAI key

openaiAPIKey

``

OpenAI key to be added as a Secret

rayAddress

""

URL of the Ray cluster

rayPort

""

Port of the Ray cluster

rayWorkerGPUs

""

Amount of GPUs that each Ray worker is going to use

replicaCount

1

Lumigator API replicas

resources

{}

Resources assigned to the Lumigator pod

s3Bucket

""

URL of the S3-compatible storage system

securityContext

{}

Security settings applied to the Lumigator container

service.annotations

{}

LoadBalancer annotations that Kubernetes will use for the service. This will configure load balancer if service.type is LoadBalancer

service.https

false

Enables https traffic for the service on port 443

service.port

80

Port for the HTTP service

service.type

"ClusterIP"

Type of the Kubernetes service to use

serviceAccountName

""

ServiceAccount that the Pod will use to access the Kubernetes API and other resources

tolerations

[]

Configurable Kubernetes tolerations

Next Steps

Congratulations! You have successfully installed Lumigator on your Kubernetes cluster. Now you can start using it to evaluate your language models. Head over to the user guides to learn how to interact with the Lumigator API to create new evaluation jobs.