We use cookies to help us improve gimlet.ioLearn moreOK

Deploy Ollama and Open WebUI to Remote Kubernetes Cluster with Nvidia GPU

Gergely Mate
Gergely Mate
2024-08-20
NaN

Using a remote Nvidia GPU with Kubernetes is a convenient way to run LLMs from anywhere while being able to keep costs as low as possible. Here's how you can get started with remote GPUs and Kubernetes.

By default, Kubernetes requires some setup to be able to run GPU workloads. We'll guide you through the entire process from setting up the cluster to deploying Ollama and Open WebUI to try a model.

Our Provider of Choice

For reference, we're listing a couple of cloud GPU providers here, but it's worth to note that outside of Civo, only Google Cloud Provider offers clusters with Nvidia A100s, the rest are VMs with the GPUs.

Our provider of choice is Civo, and this blog post describes how to launch a Kubernetes GPU with their CLI.

Check out the pricing and configuration comparison for A100 VMs and clusters in the table below:

ProviderConnectionCPURAMStoragePriceKubernetes
CivoPCIe8 cores64 GB200 GB NVMe$1.78/hrYes
Lambda LabsPCIe30 vCPU200 GB512 GB SSD$1.29/hrNo
DataCrunchSXM22 vCPU120 GBNot included$1.75/hrNo
GCP-GKEPCIe12 vCPU85 GBNot included$3.77/hrYes

Pre-Requirements

Moving forward, a couple of things you'll need to complete the steps described:

Launch Cluster

First, let's install the CLI of CIVO. We'll use this to make changes on the cluster. Use either of the commands below:

brew install civo

Or:

curl -sL https://civo.com/get | sh

Now run the command below to launch a cluster with an Nvidia A100-40 GPU:

civo kubernetes create gpu-cluster \
  --size g4g.40.kube.small \
  --nodes 1 \
  --save --merge --wait \
  --create-firewall \
  --firewall-rules "default" \
  --region LON1 \
  --cluster-type talos

If you can't launch the g4g.kube.small cluster, you can check out the available Nvidia GPU resources if you run this command:

civo sizes ls --region=LON1 | grep Nvidia | grep Kubernetes

The output should be something like this:

| an.g1.l40s.kube.x1 | Small - Nvidia L40S 40GB       | Kubernetes |  12 |  131072 | 200 |
| g4g.kube.small     | Small - Nvidia A100 80GB       | Kubernetes |  12 |  131072 | 100 |

Before moving forward, verify that the cluster is up:

civo kubernetes config gpu-cluster --region LON1 --save

kubectl get nodes
kubectl get pods

If you run kubectl describe node, you'll see that the node doesn't know about the GPU.

kubectl describe node didn't list GPU resources

You'll need to install the Nvidia device plugin.

Device Plugin Installation

In order to be able to utilize the GPU with a Kubernetes runtime, you'll need to install the device plugin with the command below:

kubectl apply ds.yml -f

Deploy Ollama and Open WebUI

Ollama is a framework for deploying and managing LLMs, which you can now deploy to your cluster. In this repository, you can find the Helm chart you can configure for your needs.

helm repo add ollama-helm https://otwld.github.io/ollama-helm/
helm repo update
helm upgrade -i ollama ollama-helm/ollama --create-namespace --namespace ollama -f ollama.yaml
kubectl logs -f deploy/ollama

Take a look at the settings we used in ollama.yaml to set up Ollama for GPU usage below.

ollama:
  gpu:
    enabled: true
    number: 1
  models: 
    - llama2
    - gemma

persistentVolume:
  enabled: true
  size: 250Gi

Deploy the Model

To interact with models, you can deploy Open WebUI. Open WebUI has similar looks to ChatGPT, and you can add models to it easily by entering its name.

Run the command below to install Open WebUI:

kubectl create namespace open-webui
kubectl apply -f https://raw.githubusercontent.com/open-webui/open-webui/main/kubernetes/manifest/base/webui-pvc.yaml
kubectl apply -f https://raw.githubusercontent.com/open-webui/open-webui/main/kubernetes/manifest/base/webui-service.yaml
kubectl apply -f https://raw.githubusercontent.com/open-webui/open-webui/main/kubernetes/manifest/base/webui-deployment.yaml

To access Open WebUI, port-forward with the command below.

kubectl port-forward svc/open-webui-service 8888:8080 -n open-webui

Now enter http://localhost:8888 in your browser, and enter an email address and a password to get credentials for the Open WebUI instance you're running.

After you're done, you can already try the available models, but you're also able to change the source of Ollama models. To do so, navigate to the settings and change Ollama's URL to http://ollama.ollama.svc.cluster.local:11434, as you can see in the screenshot below. This way you'll be able to add models available on ollama.com, such as Llama 3, which was published a few days before this blog post was published.

remote-nvidia-gpu-ollama-Open-WebUI-url-config.png

Cleanup

In case you're done experimenting, it's suggessted to clean things up to avoid unnecessary costs from piling up. In order to do so, just delete the cluster and the volumes.

Run these commands to delete the cluster and the volumes that belong to them:

Delete Cluster

civo kubernetes delete gpu-cluster --region lon1

Delete Volumes

civo volumes list

civo volumes delete <VOLUME-NAME> --region lon1

More from our blog

Clickops over gitops

Doing cloud operations by clicking on a dashboard that generates a stream of infrastructure as code changes.

The how and why we built our SaaS platform on Hetzner and Kubernetes

Hetzner is 5 times cheaper for us than the hyperscalers. This blog posts enumerates the how and why we built our SaaS on a discount bare metal provider. Gotchas included.

Announcing the Gimlet SaaS Early Access

We have something really exciting to share with you: Gimlet is going SaaS. In other words, you will be able to use Gimlet's unparalleled Kubernetes deploy experience with even fewer clicks than before.

How Flux broke the CI/CD feedback loop, and how we pieced it back together

A green build used to mean a successful deploy. But then gitops came and broke this heuristic.

Are you sure none of your containers run as root?

The Kyverno policy engine just arrived in Gimlet Stack. Let's see how you can be certain that none of the containers run as root in your Kubernetes cluster.