disagg_planner.yaml 4.58 KB
Newer Older
1
# SPDX-FileCopyrightText: Copyright (c) 2025-2026 NVIDIA CORPORATION & AFFILIATES. All rights reserved.
2
# SPDX-License-Identifier: Apache-2.0
Alec's avatar
Alec committed
3

4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
# ──────────────────────────────────────────────────────────────────────────────
# Planner profiling data ConfigMap
#
# The planner requires pre-deployment profiling data (prefill & decode
# interpolation curves) for throughput-based scaling.  The values below are
# PLACEHOLDERS for Qwen/Qwen3-0.6B — replace them with real measurements
# before deploying to production.
#
# How to obtain real data:
#   • Run the Dynamo Profiler against your target GPU/model combination.
#     See docs/components/profiler/profiler-guide.md for instructions.
#   • Or run manual benchmarks and fill in the arrays below.
#
# Key format (JSON files mounted into the planner container):
#   prefill_raw_data.json — prefill_isl (input sequence lengths),
#       prefill_ttft (time-to-first-token in ms), prefill_thpt_per_gpu
#       (tokens/s per GPU) — all 1-D arrays of equal length.
#   decode_raw_data.json  — x_kv_usage (KV-cache utilisation fractions),
#       y_context_length (context lengths), z_itl (inter-token latency in ms,
#       shape [len(x_kv_usage), len(y_context_length)]), z_thpt_per_gpu
#       (tokens/s per GPU, same shape), max_kv_tokens (scalar).
# ──────────────────────────────────────────────────────────────────────────────
apiVersion: v1
kind: ConfigMap
metadata:
  name: planner-profile-data
data:
  prefill_raw_data.json: |
    {
      "prefill_isl":          [128, 256, 512, 1024, 2048],
      "prefill_ttft":         [12,  18,  30,  55,   105],
      "prefill_thpt_per_gpu": [9800, 8500, 6200, 3800, 2000]
    }
  decode_raw_data.json: |
    {
      "x_kv_usage":       [0.1, 0.3, 0.5, 0.7, 0.9],
      "y_context_length":  [128, 512, 1024, 2048],
      "z_itl": [
        [5,  6,  7,  9 ],
        [6,  7,  8,  10],
        [7,  8,  10, 12],
        [8,  10, 12, 15],
        [10, 12, 15, 20]
      ],
      "z_thpt_per_gpu": [
        [4500, 4000, 3500, 2800],
        [4200, 3700, 3200, 2500],
        [3800, 3300, 2800, 2200],
        [3400, 2900, 2400, 1800],
        [2800, 2400, 1900, 1400]
      ],
      "max_kv_tokens": 32768
    }
---
58
59
60
apiVersion: nvidia.com/v1alpha1
kind: DynamoGraphDeployment
metadata:
61
  name: vllm-disagg-planner
62
63
64
spec:
  services:
    Frontend:
65
      componentType: frontend
66
      replicas: 1
67
68
      extraPodSpec:
        mainContainer:
69
          image: nvcr.io/nvidia/ai-dynamo/vllm-runtime:my-tag
70
71
72
    Planner:
      componentType: planner
      replicas: 1
73
74
      extraPodSpec:
        mainContainer:
75
          image: nvcr.io/nvidia/ai-dynamo/vllm-runtime:my-tag
julienmancuso's avatar
julienmancuso committed
76
          command:
77
78
          - python3
          - -m
79
          - dynamo.planner
80
          args:
81
82
            - --config
            - '{"environment": "kubernetes", "backend": "vllm", "throughput_adjustment_interval": 60, "profile_results_dir": "/workspace/profiling_results"}'
83
84
85
86
87
88
89
90
          volumeMounts:
            - name: planner-profile-data
              mountPath: /workspace/profiling_results
              readOnly: true
        volumes:
          - name: planner-profile-data
            configMap:
              name: planner-profile-data
91
    VllmDecodeWorker:
92
      envFromSecret: hf-token-secret
93
      componentType: worker
94
      subComponentType: decode
95
      replicas: 1
96
97
      resources:
        limits:
98
          gpu: "1"
99
100
      extraPodSpec:
        mainContainer:
101
          image: nvcr.io/nvidia/ai-dynamo/vllm-runtime:my-tag
102
          workingDir: /workspace/examples/backends/vllm
103
          command:
104
            - python3
105
          args:
106
107
108
109
            - -m
            - dynamo.vllm
            - --model
            - Qwen/Qwen3-0.6B
110
    VllmPrefillWorker:
111
      envFromSecret: hf-token-secret
112
      componentType: worker
113
      subComponentType: prefill
114
      replicas: 1
115
116
      resources:
        limits:
117
          gpu: "1"
118
119
      extraPodSpec:
        mainContainer:
120
          image: nvcr.io/nvidia/ai-dynamo/vllm-runtime:my-tag
121
          workingDir: /workspace/examples/backends/vllm
122
          command:
123
            - python3
124
          args:
125
126
127
128
            - -m
            - dynamo.vllm
            - --model
            - Qwen/Qwen3-0.6B
129
130
            - --disaggregation-mode
            - prefill
131
132
            - --kv-transfer-config
            - '{"kv_connector":"NixlConnector","kv_role":"kv_both"}'