DGDR Reference

View as Markdown

A DynamoGraphDeploymentRequest (DGDR) is Dynamo’s deploy-by-intent generator for DynamoGraphDeployment (DGD) resources. You describe what you want to run and your performance targets; the profiler determines a configuration and produces the DGD that serves traffic.

For the full deployment mental model — including DGD, DCD, DGDR, recipes, strategy selection, model caching, planner setup, and common pitfalls — see the Deployment Overview.

DGDR, DGD, and Recipes

Dynamo provides two Custom Resources for deploying inference graphs:

DGD (canonical live deployment)DGDR (generator/profiler)
You provideFull deployment spec (services, parallelism, replicas, resource limits, etc.)Model, backend, workload, hardware, and optional SLA targets
What happensThe operator reconciles the DGD into DynamoComponentDeployment resources and podsThe profiler generates a DGD; with autoApply: true, the operator creates it
Best forKnown-good configs, tuned recipes, or full manual controlNew model/hardware combinations, SLA-driven sizing, or generated DGD YAML
PersistencePersists and serves trafficReaches a terminal state after generation/deploy

Use DGD directly when you have a hand-crafted configuration for a specific model/hardware combination. Most recipes are tuned DGD manifests. Use DGDR when you want Dynamo to generate the DGD for you.

For DGD deployment details, see Creating Deployments.

Spec Reference

Minimal Example

1apiVersion: nvidia.com/v1beta1
2kind: DynamoGraphDeploymentRequest
3metadata:
4 name: my-model
5spec:
6 model: Qwen/Qwen3-0.6B
7 image: "nvcr.io/nvidia/ai-dynamo/dynamo-planner:1.2.1" # dynamo-frontend for Dynamo < 1.1.0

Field Reference

FieldRequiredDefaultPurpose
modelYesHuggingFace model ID (e.g. Qwen/Qwen3-0.6B)
imageNoContainer image for the profiling job. Dynamo >= 1.1.0: use dynamo-planner; earlier versions: use dynamo-frontend.
backendNoautoInference engine: auto, vllm, sglang, trtllm
searchStrategyNorapidProfiling depth: rapid (AIC-backed DynoSim-style modeling, ~30s) or thorough (real GPU, 2–4h)
autoApplyNotrueAutomatically deploy the profiler’s recommended config
sla.ttftNoTarget time to first token (ms)
sla.itlNoTarget inter-token latency (ms)
sla.e2eLatencyNoTarget end-to-end latency (ms). Cannot be combined with explicit ttft/itl.
workload.islNo4000Expected average input sequence length
workload.oslNo1000Expected average output sequence length
workload.requestRateNoTarget requests per second
workload.concurrencyNoTarget concurrent requests
hardware.gpuSkuNoauto-detectedGPU SKU (see SKU Format)
hardware.vramMbNoauto-detectedGPU VRAM in MB
hardware.totalGpusNoauto-detected (capped at 32)Total GPUs available to the deployment
hardware.numGpusPerNodeNoauto-detectedGPUs per node
hardware.interconnectNoauto-detectedInterconnect type
hardware.rdmaNoauto-detectedWhether RDMA is available
modelCache.pvcNameNoName of a ReadWriteMany PVC containing cached model weights
modelCache.pvcModelPathNoPath to the model directory inside the PVC
modelCache.pvcMountPathNo/opt/model-cacheMount path inside containers
features.plannerNodisabledEnable the SLA-aware Planner; the generated DGD includes Planner service/configuration
features.mockerNodisabledEnable mocker mode for testing
overrides.profilingJobNobatchv1.JobSpec overrides for the profiling job (e.g., tolerations)
overrides.dgdNoRaw DGD override base applied to the generated deployment

For the complete CRD spec, see the API Reference.

DGDR does not currently expose a features.kvRouter field. To configure router mode or KV-aware routing details, use a direct DGD, a tuned recipe, or overrides.dgd when you still want DGDR to generate the base deployment.

Generated DGD Overrides

Use spec.overrides.dgd when the generated DynamoGraphDeployment needs a field that DGDR does not expose directly. The value is a partial nvidia.com/v1alpha1 DGD object that is merged into the profiler-generated deployment after Dynamo selects a configuration.

For example, to inject an environment variable into every generated service:

1apiVersion: nvidia.com/v1beta1
2kind: DynamoGraphDeploymentRequest
3metadata:
4 name: qwen3-sglang
5spec:
6 model: Qwen/Qwen3-30B-A3B
7 backend: sglang
8 image: "nvcr.io/nvidia/ai-dynamo/dynamo-planner:1.2.1" # dynamo-frontend for Dynamo < 1.1.0
9 overrides:
10 dgd:
11 apiVersion: nvidia.com/v1alpha1
12 kind: DynamoGraphDeployment
13 spec:
14 envs:
15 - name: TRITON_PTXAS_PATH
16 value: /usr/local/cuda/bin/ptxas

Use spec.envs for variables that should apply to all generated services. To target a single service, override that service’s envs entry instead:

1spec:
2 overrides:
3 dgd:
4 apiVersion: nvidia.com/v1alpha1
5 kind: DynamoGraphDeployment
6 spec:
7 services:
8 decode: # replace with the generated service name
9 envs:
10 - name: CUSTOM_WORKER_ENV
11 value: "enabled"

overrides.profilingJob only customizes the profiling Job. Use overrides.dgd for settings that must appear on the deployed worker pods.

Routing

DGDR-generated deployments include a standalone Frontend service. That frontend runs Dynamo’s embedded router and defaults to round-robin routing, which is often not optimal. Because DGDR does not yet expose a first-class router feature, configure the generated frontend with spec.overrides.dgd.

For the full router mode and environment variable reference, see Router Guide and Router Configuration.

For example, enable KV-aware routing on the generated frontend:

1apiVersion: nvidia.com/v1beta1
2kind: DynamoGraphDeploymentRequest
3metadata:
4 name: qwen3-kv-router
5spec:
6 model: Qwen/Qwen3-0.6B
7 backend: vllm
8 overrides:
9 dgd:
10 apiVersion: nvidia.com/v1alpha1 # v1beta1 not yet supported for overrides
11 kind: DynamoGraphDeployment
12 spec:
13 services:
14 Frontend:
15 envs:
16 - name: DYN_ROUTER_MODE
17 value: kv

Use the same Frontend override for other frontend router modes, such as random, least-loaded, or device-aware-weighted. For normal DGDR deployments, use kv when you want prefix-cache-aware routing and round-robin or least-loaded when you only want load balancing. Use direct only when an external router supplies explicit worker IDs in the request routing hints. For detailed mode definitions, see Router Guide.

KV-aware routing can use event-driven prefix-cache state or approximate prefix matching. The frontend still runs in kv mode in both cases. If you do not configure worker KV-event publication, set DYN_ROUTER_USE_KV_EVENTS=false to use approximate KV mode:

1spec:
2 overrides:
3 dgd:
4 apiVersion: nvidia.com/v1alpha1 # v1beta1 not yet supported for overrides
5 kind: DynamoGraphDeployment
6 spec:
7 services:
8 Frontend:
9 envs:
10 - name: DYN_ROUTER_MODE
11 value: kv
12 - name: DYN_ROUTER_USE_KV_EVENTS
13 value: "false"

For event-driven prefix-cache state, enable worker event publication only where prefill happens: the single worker in aggregated serving, or prefill workers in disaggregated serving. Decode workers are scored by load (dyn-decode-scorer), not prefix overlap (dyn-prefill-scorer), so vLLM decode workers omit both --enable-prefix-caching and --kv-events-config. Service names depend on the selected backend and topology, so inspect the generated DGD first, especially when autoApply: false.

For example, a generated vLLM disaggregated deployment may contain a VllmPrefillWorker service. This override appends the vLLM KV-event publishing arguments to that service while enabling the frontend KV router:

1spec:
2 overrides:
3 dgd:
4 apiVersion: nvidia.com/v1alpha1 # v1beta1 not yet supported for overrides
5 kind: DynamoGraphDeployment
6 spec:
7 services:
8 Frontend:
9 envs:
10 - name: DYN_ROUTER_MODE
11 value: kv
12 VllmPrefillWorker:
13 extraPodSpec:
14 mainContainer:
15 args:
16 - --enable-prefix-caching
17 - --kv-events-config
18 - '{"publisher":"zmq","topic":"kv-events","endpoint":"tcp://*:20080","enable_kv_cache_events":true}'

Worker KV-event flags are backend-specific. For cross-backend behavior, see Router Operations.

BackendDetailed docsWorker-side event publishing
vLLMvLLM Reference Guide, vLLM Examples--enable-prefix-caching and --kv-events-config '{"publisher":"zmq","topic":"kv-events","endpoint":"tcp://*:20080","enable_kv_cache_events":true}' on the aggregated worker or disaggregated prefill worker
SGLangSGLang KV Events, SGLang Examples--kv-events-config with the SGLang event endpoint
TRT-LLMTRT-LLM DP Rank Routing, TRT-LLM Observability--publish-events-and-metrics

In Kubernetes deployments the Dynamo runtime normally uses Kubernetes discovery and the NATS event plane. Some backends, such as vLLM and SGLang, emit raw KV events over ZMQ; the Dynamo worker consumes those backend events and republishes router events through the Dynamo event plane. For the event plane model, see Event Plane.

EPP and Gateway Routing

EPP/Gateway routing is a different topology from the standalone frontend that DGDR generates:

client -> Gateway -> EPP selects worker -> worker frontend sidecar -> engine

In this mode the EPP owns worker selection. The worker-local frontend sidecar must run with --router-mode direct so it honors the worker IDs selected by EPP. In the normal Gateway path, the selected endpoint and the frontend sidecar are the same worker pod; if they differ, direct mode can still forward to the worker ID supplied by EPP.

DGDR does not currently generate EPP components or frontend sidecars. Also, overrides.dgd only patches services that already exist in the generated DGD, so it cannot be used to add a missing Epp service to a DGDR-generated deployment. Use a direct DGD manifest or a GAIE recipe for EPP deployments. For manifests, frontendSidecar configuration, direct routing, EPP routing variables such as DYN_USE_KV_EVENTS, and route setup, see Gateway API Inference Extension. The same guide also documents the optional Rust EPP, which is currently experimental.

SKU Format

When providing hardware configuration manually, use lowercase underscore format:

CorrectIncorrect
h100_sxmH100-SXM5-80GB
h200_sxmH200-SXM-141GB
a100_sxmA100-SXM4-80GB
a30A30
l40sL40S

All supported values: gb200_sxm, b200_sxm, h200_sxm, h100_sxm, h100_pcie, a100_sxm, a100_pcie, a30, l40s, l40, l4, v100_sxm, v100_pcie, t4, mi200, mi300.

Not all SKUs are supported by the AIC profiler for rapid mode. See AIC Support Matrix for details.

PCIe variants not yet supported by profiler. The CRD admits PCIe SKUs (h100_pcie, a100_pcie, v100_pcie), but the profiler does not currently ship training data for them. You can submit a DGDR with a PCIe value; the operator will accept it but profiler-assisted sizing will fall back to defaults. Profiler support for PCIe SKUs is tracked as an engineering follow-up.

Lifecycle

When you create a DGDR, it progresses through these phases:

PhaseWhat is happening
PendingSpec validated; operator is discovering GPU hardware and preparing the profiling job
ProfilingProfiling job running — sub-phases: Initializing, SweepingPrefill, SweepingDecode, SelectingConfig, BuildingCurves, GeneratingDGD, Done
ReadyProfiling complete; optimal config stored in .status.profilingResults.selectedConfig. Terminal state when autoApply: false.
DeployingCreating the DynamoGraphDeployment (only when autoApply: true)
DeployedDGD is running and healthy
FailedUnrecoverable error — profiling failures are not retried (backoffLimit: 0); check events and conditions for details

Conditions

The operator maintains these conditions on the DGDR status:

ConditionMeaning
ValidationSpec validation passed or failed
ProfilingProfiling job is running, succeeded, or failed
SpecGeneratedGenerated DGD spec is available
DeploymentReadyDGD is deployed and healthy
SucceededAggregate condition — true when the DGDR has reached its target state

Monitoring

$# Watch phase transitions
$kubectl get dgdr my-model -n $NAMESPACE -w
$
$# Detailed status, conditions, and events
$kubectl describe dgdr my-model -n $NAMESPACE
$
$# Profiling sub-phase
$kubectl get dgdr my-model -n $NAMESPACE -o jsonpath='{.status.profilingPhase}'
$
$# Profiling job logs
$kubectl get pods -n $NAMESPACE -l nvidia.com/dgdr-name=my-model
$kubectl logs -f <profiling-pod-name> -n $NAMESPACE
$
$# View generated DGD spec (when autoApply: false)
$kubectl get dgdr my-model -n $NAMESPACE \
> -o jsonpath='{.status.profilingResults.selectedConfig}' | python3 -m json.tool
$
$# View Pareto-optimal configs from profiling
$kubectl get dgdr my-model -n $NAMESPACE \
> -o jsonpath='{.status.profilingResults.pareto}'

Resource Ownership

  • The DGDR does not set an owner reference on the DGD it creates. Deleting a DGDR does not delete the DGD — it persists independently so it can continue serving traffic.
  • The relationship is tracked via labels: dgdr.nvidia.com/name and dgdr.nvidia.com/namespace.
  • Additional resources (planner ConfigMaps) are created in the same namespace and labeled with dgdr.nvidia.com/name.

Known Issues

  • pareto_analysis.py produces NaN for some configurations. Tracked as an engineering follow-up. Workaround: re-run with a narrower sweep; narrow sweeps bypass the NaN path in practice.
  • PCIe profiler data not yet available. See the PCIe callout under SKU Format.

Further Reading