Deploy and manage Dynamo inference graphs on Kubernetes with automated orchestration and scaling, using the Dynamo Kubernetes Platform.
Determine your cluster environment:
Shared/Multi-Tenant Cluster (K8s cluster with existing Dynamo artifacts):
Dedicated Cluster (full cluster admin access):
Local Development (Minikube, testing):
To check if CRDs already exist:
To check if a cluster-wide operator already exists:
Platform is installed using Dynamo Kubernetes Platform helm chart.
Path A: Pre-built Artifacts
Path B: Custom Build from Source
All helm install commands could be overridden by either setting the values.yaml file or by passing in your own values.yaml:
and/or setting values as flags to the helm install command, as follows:
Before installing the Dynamo Kubernetes Platform, ensure you have the following tools and access:
Run the following to confirm your tools are correctly installed:
Before proceeding, run the pre-deployment check script to verify your cluster meets all requirements:
This script validates kubectl connectivity, default StorageClass configuration, and GPU node availability. See Pre-Deployment Checks for details.
No cluster? See Minikube Setup for local development.
Estimated installation time: 5-30 minutes depending on path
Install from NGC published artifacts.
v0.9.0 Helm Chart Issue: The initial v0.9.0 dynamo-platform Helm chart sets the operator image to v0.7.1 instead of v0.9.0. Use RELEASE_VERSION=0.9.0-post1 or add --set dynamo-operator.controllerManager.manager.image.tag=0.9.0 to your helm install command.
For Shared/Multi-Tenant Clusters:
If your cluster has namespace-restricted Dynamo operators, you MUST add namespace restriction to your installation:
Note: Use the full path dynamo-operator.namespaceRestriction.enabled=true (not just namespaceRestriction.enabled=true).
If you see this validation error, you need namespace restriction:
For multinode deployments, you need to install multinode orchestration components:
Option 1 (Recommended): Grove + KAI Scheduler
For production environments, Grove and KAI Scheduler should be installed separately from the dynamo-platform chart. This allows independent lifecycle management, version pinning, and upgrade control.
Compatibility Matrix:
After installing them separately, enable Dynamo integration:
For development/testing only, you can install them as bundled subcharts:
Note: global.kai-scheduler.install / global.grove.install control whether the bundled subcharts are deployed. When set, integration is automatically enabled. global.kai-scheduler.enabled / global.grove.enabled can be set independently when using externally-managed installations.
Option 2: LeaderWorkerSet (LWS) + Volcano
See the Multinode Deployment Guide for details on orchestrator selection.
By default, Model Express Server is not used. If you wish to use an existing Model Express Server, you can set the modelExpressURL to the existing server’s URL in the helm install command:
By default, Dynamo Operator is installed cluster-wide and will monitor all namespaces. If you wish to restrict the operator to monitor only a specific namespace (the helm release namespace by default), you can set the namespaceRestriction.enabled to true. You can also change the restricted namespace by setting the targetNamespace property.
GPU discovery is enabled by default for namespace-scoped operators. The Helm chart automatically provisions a ClusterRole/ClusterRoleBinding granting the operator read-only access to node GPU labels.
To disable GPU discovery (if your installer lacks ClusterRole creation permissions):
When GPU discovery is disabled, you must provide hardware configuration manually in each DynamoGraphDeploymentRequest:
Note: If GPU discovery is disabled and no hardware config is provided, the DGDR will be rejected at admission time with a clear error message.
Build and deploy from source for customization, contributing to Dynamo, or using the latest features from the main branch.
Note: This gives you access to the latest unreleased features and fixes on the main branch.
Deploy Model/Workflow
Explore Backend Guides
Optional:
“VALIDATION ERROR: Cannot install cluster-wide Dynamo operator”
Cause: Attempting cluster-wide install on a shared cluster with existing namespace-restricted operators.
Solution: Add namespace restriction to your installation:
Note: Use the full path dynamo-operator.namespaceRestriction.enabled=true (not just namespaceRestriction.enabled=true).
CRDs already exist
Cause: Installing CRDs on a cluster where they’re already present (common on shared clusters).
Solution: Skip step 2 (CRD installation), proceed directly to platform installation.
To check if CRDs exist:
Pods not starting?
HuggingFace model access?
Bitnami etcd “unrecognized” image?
This error that you might encounter during helm install is due to bitnami changing their docker repository to a secure one.
just add the following to the helm install command:
Clean uninstall?
To uninstall the platform, you can run the following command:
To uninstall the CRDs, follow these steps:
Get all of the dynamo CRDs installed in your cluster:
You should see something like this:
Delete each CRD one by one: