disagg_planner.yaml 3.28 KB
Newer Older
1
# SPDX-FileCopyrightText: Copyright (c) 2025-2026 NVIDIA CORPORATION & AFFILIATES. All rights reserved.
2
3
4
5
6
7
8
9
10
11
# SPDX-License-Identifier: Apache-2.0

apiVersion: nvidia.com/v1alpha1
kind: DynamoGraphDeployment
metadata:
  name: sglang-disagg-planner
spec:
  services:
    Frontend:
      dynamoNamespace: dynamo
12
      componentType: frontend
13
14
15
      replicas: 1
      extraPodSpec:
        mainContainer:
16
          image: my-registry/sglang-runtime:my-tag
17
18
19
20
21
22
23
    Planner:
      dynamoNamespace: dynamo
      envFromSecret: hf-token-secret
      componentType: planner
      replicas: 1
      extraPodSpec:
        mainContainer:
24
          image: my-registry/sglang-runtime:my-tag
25
          workingDir: /workspace/components/src/dynamo/planner
julienmancuso's avatar
julienmancuso committed
26
          command:
27
28
29
          - python3
          - -m
          - planner_sla
30
          args:
31
32
33
            - --environment=kubernetes
            - --backend=sglang
            - --adjustment-interval=60
34
35
36
37
38
39
40
41
42
43
44
            - --profile-results-dir=/workspace/profiling_results
          volumeMounts:
            - name: planner-profile-data
              mountPath: /workspace/profiling_results
              readOnly: true
        volumes:
          - name: planner-profile-data
            configMap:
              # Must be pre-created before deployment by the profiler
              # See docs/planner/sla_planner_quickstart.md for more details
              name: planner-profile-data
45
    decode:
46
47
48
      dynamoNamespace: dynamo
      envFromSecret: hf-token-secret
      componentType: worker
49
      subComponentType: decode
50
51
52
53
54
55
      replicas: 2
      resources:
        limits:
          gpu: "1"
      extraPodSpec:
        mainContainer:
56
          image: my-registry/sglang-runtime:my-tag
57
          workingDir: /workspace/examples/backends/sglang
julienmancuso's avatar
julienmancuso committed
58
          command:
59
            - python3
60
          args:
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
            - -m
            - dynamo.sglang
            - --model-path
            - Qwen/Qwen3-0.6B
            - --served-model-name
            - Qwen/Qwen3-0.6B
            - --page-size
            - "16"
            - --tp
            - "1"
            - --trust-remote-code
            - --skip-tokenizer-init
            - --disaggregation-mode
            - decode
            - --disaggregation-transfer-backend
            - nixl
77
78
79
80
            - --disaggregation-bootstrap-port
            - "12345"
            - --host
            - "0.0.0.0"
81
    prefill:
82
83
84
      dynamoNamespace: dynamo
      envFromSecret: hf-token-secret
      componentType: worker
85
      subComponentType: prefill
86
87
88
89
90
91
      replicas: 2
      resources:
        limits:
          gpu: "1"
      extraPodSpec:
        mainContainer:
92
          image: my-registry/sglang-runtime:my-tag
93
          workingDir: /workspace/examples/backends/sglang
julienmancuso's avatar
julienmancuso committed
94
          command:
95
            - python3
96
          args:
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
            - -m
            - dynamo.sglang
            - --model-path
            - Qwen/Qwen3-0.6B
            - --served-model-name
            - Qwen/Qwen3-0.6B
            - --page-size
            - "16"
            - --tp
            - "1"
            - --trust-remote-code
            - --skip-tokenizer-init
            - --disaggregation-mode
            - prefill
            - --disaggregation-transfer-backend
            - nixl
113
114
115
116
            - --disaggregation-bootstrap-port
            - "12345"
            - --host
            - "0.0.0.0"