disagg.yaml 3.91 KB
Newer Older
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
# SPDX-FileCopyrightText: Copyright (c) 2025 NVIDIA CORPORATION & AFFILIATES. All rights reserved.
# SPDX-License-Identifier: Apache-2.0
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
apiVersion: nvidia.com/v1alpha1
kind: DynamoGraphDeployment
metadata:
18
  name: vllm-v1-disagg
19
20
21
22
23
24
spec:
  services:
    Frontend:
      dynamoNamespace: vllm-v1-disagg
      componentType: main
      replicas: 1
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
      livenessProbe:
        httpGet:
          path: /health
          port: 8000
        initialDelaySeconds: 60
        periodSeconds: 60
        timeoutSeconds: 30
        failureThreshold: 10
      readinessProbe:
        exec:
          command:
            - /bin/sh
            - -c
            - 'curl -s http://localhost:8000/health | jq -e ".status == \"healthy\""'
        initialDelaySeconds: 60
        periodSeconds: 60
        timeoutSeconds: 30
        failureThreshold: 10
43
44
45
46
47
48
49
50
51
      resources:
        requests:
          cpu: "1"
          memory: "2Gi"
        limits:
          cpu: "1"
          memory: "2Gi"
      extraPodSpec:
        mainContainer:
52
53
          image: nvcr.io/nvidian/nim-llm-dev/vllm_v1-runtime:dep-216.4
          workingDir: /workspace/examples/vllm
54
55
          args:
            - dynamo
56
57
58
59
60
            - run
            - in=http
            - out=dyn
            - --http-port
            - "8000"
61
62
63
    VllmDecodeWorker:
      dynamoNamespace: vllm-v1-disagg
      envFromSecret: hf-token-secret
64
      componentType: worker
65
      replicas: 1
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
      livenessProbe:
        exec:
          command:
            - /bin/sh
            - -c
            - "exit 0"
        periodSeconds: 60
        timeoutSeconds: 30
        failureThreshold: 10
      readinessProbe:
        exec:
          command:
            - /bin/sh
            - -c
            - 'grep "VllmWorker.*has been initialized" /tmp/vllm.log'
        initialDelaySeconds: 60
        periodSeconds: 60
        timeoutSeconds: 30
        failureThreshold: 10
85
86
87
88
      resources:
        requests:
          cpu: "10"
          memory: "20Gi"
89
          gpu: "1"
90
91
92
        limits:
          cpu: "10"
          memory: "20Gi"
93
          gpu: "1"
94
95
      extraPodSpec:
        mainContainer:
96
97
          image: nvcr.io/nvidian/nim-llm-dev/vllm_v1-runtime:dep-216.4
          workingDir: /workspace/examples/vllm
98
          args:
99
            - "python3 components/main.py --model Qwen/Qwen3-0.6B --enforce-eager 2>&1 | tee /tmp/vllm.log"
100
101
102
    VllmPrefillWorker:
      dynamoNamespace: vllm-v1-disagg
      envFromSecret: hf-token-secret
103
      componentType: worker
104
      replicas: 1
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
      livenessProbe:
        exec:
          command:
            - /bin/sh
            - -c
            - "exit 0"
        periodSeconds: 60
        timeoutSeconds: 30
        failureThreshold: 10
      readinessProbe:
        exec:
          command:
            - /bin/sh
            - -c
            - 'grep "VllmWorker.*has been initialized" /tmp/vllm.log'
        initialDelaySeconds: 60
        periodSeconds: 60
        timeoutSeconds: 30
        failureThreshold: 10
124
125
126
127
      resources:
        requests:
          cpu: "10"
          memory: "20Gi"
128
          gpu: "1"
129
130
131
        limits:
          cpu: "10"
          memory: "20Gi"
132
          gpu: "1"
133
134
      extraPodSpec:
        mainContainer:
135
136
          image: nvcr.io/nvidian/nim-llm-dev/vllm_v1-runtime:dep-216.4
          workingDir: /workspace/examples/vllm
137
          args:
138
            - "python3 components/main.py --model Qwen/Qwen3-0.6B --enforce-eager --is-prefill-worker 2>&1 | tee /tmp/vllm.log"