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

4
5
6
apiVersion: nvidia.com/v1alpha1
kind: DynamoGraphDeployment
metadata:
7
  name: vllm-disagg-planner
8
9
  annotations:
    nvidia.com/enable-grove: "false" # temporarily disable grove because current k8s connector does not work with grove
10
spec:
11
12
13
14
15
  envs:
    - name: DYNAMO_SERVICE_CONFIG
      value: '{"Prometheus":{"global":{"scrape_interval":"5s"},"scrape_configs":[{"job_name":"prometheus","static_configs":[{"targets":["localhost:9090"]}]},{"job_name":"frontend","static_configs":[{"targets":["vllm-disagg-planner-frontend:8000"]}]}]}}'
    - name: DYNAMO_NAMESPACE
      value: "vllm-disagg-planner"
16
17
  services:
    Frontend:
18
      dynamoNamespace: vllm-disagg-planner
19
      componentType: frontend
20
      replicas: 1
21
22
      extraPodSpec:
        mainContainer:
23
          image: nvcr.io/nvidian/nim-llm-dev/vllm-runtime:hzhou-0814-02
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
    Planner:
      dynamoNamespace: vllm-disagg-planner
      envFromSecret: hf-token-secret
      componentType: planner
      replicas: 1
      livenessProbe:
        exec:
          command:
            - /bin/sh
            - -c
            - "exit 0"
        periodSeconds: 60
        timeoutSeconds: 30
        failureThreshold: 10
      readinessProbe:
        exec:
          command:
            - /bin/sh
            - -c
            - "exit 0"
        initialDelaySeconds: 60
        periodSeconds: 60
        timeoutSeconds: 30
        failureThreshold: 10
      pvc:
        create: false
        name: profiling-pvc # Must be pre-created before deployment and SLA profiler must have been run
        mountPoint: /workspace/profiling_results
52
53
      extraPodSpec:
        mainContainer:
54
          image: nvcr.io/nvidian/nim-llm-dev/vllm-runtime:hzhou-0814-02
55
          workingDir: /workspace/components/planner/src/dynamo/planner
56
57
58
          ports:
            - name: metrics
              containerPort: 9085
julienmancuso's avatar
julienmancuso committed
59
60
61
          command:
            - /bin/sh
            - -c
62
          args:
julienmancuso's avatar
julienmancuso committed
63
64
65
66
67
68
            - >-
              python3 -m planner_sla
              --environment=kubernetes
              --backend=vllm
              --adjustment-interval=60
              --profile-results-dir=/workspace/profiling_results
69
              --prometheus-port=9085
70
    Prometheus: # NOTE: this is set on Prometheus to ensure a service is created for the Prometheus component. This is a workaround and should be managed differently.
71
      dynamoNamespace: vllm-disagg-planner
72
      componentType: frontend
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
      replicas: 1
      envs:
        - name: PYTHONPATH
          value: "/workspace/components/planner/src"
      livenessProbe:
        exec:
          command:
            - /bin/sh
            - -c
            - "exit 0"
        periodSeconds: 60
        timeoutSeconds: 30
        failureThreshold: 10
      readinessProbe:
        exec:
          command:
            - /bin/sh
            - -c
            - "exit 0"
        initialDelaySeconds: 30
        periodSeconds: 60
        timeoutSeconds: 30
        failureThreshold: 10
      extraPodSpec:
        mainContainer:
98
          image: nvcr.io/nvidian/nim-llm-dev/vllm-runtime:hzhou-0814-02
Alec's avatar
Alec committed
99
          workingDir: /workspace/components/backends/vllm
100
101
102
          command:
            - /bin/sh
            - -c
103
          args:
104
            - "python3 -m dynamo.planner.prometheus"
105
    VllmDecodeWorker:
106
      dynamoNamespace: vllm-disagg-planner
107
      envFromSecret: hf-token-secret
108
      componentType: worker
109
      replicas: 2
110
111
      resources:
        limits:
112
          gpu: "1"
113
114
      extraPodSpec:
        mainContainer:
115
116
117
118
119
120
          startupProbe:
            httpGet:
              path: /health
              port: 9090
            periodSeconds: 10
            failureThreshold: 60
121
          image: nvcr.io/nvidian/nim-llm-dev/vllm-runtime:hzhou-0814-02
Alec's avatar
Alec committed
122
          workingDir: /workspace/components/backends/vllm
123
124
125
          command:
            - /bin/sh
            - -c
126
          args:
127
            - "python3 -m dynamo.vllm --model Qwen/Qwen3-0.6B --migration-limit=3"
128
    VllmPrefillWorker:
129
      dynamoNamespace: vllm-disagg-planner
130
      envFromSecret: hf-token-secret
131
      componentType: worker
132
      replicas: 2
133
134
      resources:
        limits:
135
          gpu: "1"
136
137
      extraPodSpec:
        mainContainer:
138
139
140
141
142
143
          startupProbe:
            httpGet:
              path: /health
              port: 9090
            periodSeconds: 10
            failureThreshold: 60
144
          image: nvcr.io/nvidian/nim-llm-dev/vllm-runtime:hzhou-0814-02
Alec's avatar
Alec committed
145
          workingDir: /workspace/components/backends/vllm
146
147
148
          command:
            - /bin/sh
            - -c
149
          args:
150
            - python3 -m dynamo.vllm --model Qwen/Qwen3-0.6B --is-prefill-worker --migration-limit=3