disagg_router.yaml 3.9 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
7
8
9
10
11
12
13
14
15
16
17
apiVersion: nvidia.com/v1alpha1
kind: DynamoGraphDeployment
metadata:
  name: vllm-v1-disagg-router
spec:
  services:
    Frontend:
      dynamoNamespace: vllm-v1-disagg-router
      componentType: main
      replicas: 1
      livenessProbe:
        httpGet:
          path: /health
          port: 8000
18
19
20
21
        initialDelaySeconds: 20
        periodSeconds: 5
        timeoutSeconds: 5
        failureThreshold: 3
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
      readinessProbe:
        exec:
          command:
            - /bin/sh
            - -c
            - 'curl -s http://localhost:8000/health | jq -e ".status == \"healthy\""'
        initialDelaySeconds: 60
        periodSeconds: 60
        timeoutSeconds: 30
        failureThreshold: 10
      resources:
        requests:
          cpu: "1"
          memory: "2Gi"
        limits:
          cpu: "1"
          memory: "2Gi"
      extraPodSpec:
        mainContainer:
41
          image: nvcr.io/nvidian/nim-llm-dev/vllm-runtime:dep-233.17
Alec's avatar
Alec committed
42
          workingDir: /workspace/components/backends/vllm
43
44
45
          command:
            - /bin/sh
            - -c
46
          args:
47
            - "python3 -m dynamo.frontend --http-port 8000 --router-mode kv"
48
49
50
51
52
53
    VllmDecodeWorker:
      dynamoNamespace: vllm-v1-disagg-router
      envFromSecret: hf-token-secret
      componentType: worker
      replicas: 2
      livenessProbe:
54
55
56
57
        httpGet:
          path: /live
          port: 9090
        periodSeconds: 5
58
        timeoutSeconds: 30
59
        failureThreshold: 1
60
      readinessProbe:
61
62
63
64
        httpGet:
          path: /health
          port: 9090
        periodSeconds: 10
65
        timeoutSeconds: 30
66
        failureThreshold: 60
67
68
69
70
71
72
73
74
75
      resources:
        requests:
          cpu: "10"
          memory: "20Gi"
          gpu: "1"
        limits:
          cpu: "10"
          memory: "20Gi"
          gpu: "1"
76
77
78
79
80
      envs:
        - name: DYN_SYSTEM_ENABLED
          value: "true"
        - name: DYN_SYSTEM_USE_ENDPOINT_HEALTH_STATUS
          value: "[\"generate\"]"
81
82
      extraPodSpec:
        mainContainer:
83
84
85
86
87
88
          startupProbe:
            httpGet:
              path: /health
              port: 9090
            periodSeconds: 10
            failureThreshold: 60
89
          image: nvcr.io/nvidian/nim-llm-dev/vllm-runtime:dep-233.17
Alec's avatar
Alec committed
90
          workingDir: /workspace/components/backends/vllm
91
92
93
          command:
            - /bin/sh
            - -c
94
          args:
95
            - python3 -m dynamo.vllm --model Qwen/Qwen3-0.6B  2>&1 | tee /tmp/vllm.log
96
97
98
99
100
101
    VllmPrefillWorker:
      dynamoNamespace: vllm-v1-disagg-router
      envFromSecret: hf-token-secret
      componentType: worker
      replicas: 1
      livenessProbe:
102
103
104
105
        httpGet:
          path: /live
          port: 9090
        periodSeconds: 5
106
        timeoutSeconds: 30
107
        failureThreshold: 1
108
      readinessProbe:
109
110
111
112
        httpGet:
          path: /health
          port: 9090
        periodSeconds: 10
113
        timeoutSeconds: 30
114
        failureThreshold: 60
115
116
117
118
119
120
121
122
123
      resources:
        requests:
          cpu: "10"
          memory: "20Gi"
          gpu: "1"
        limits:
          cpu: "10"
          memory: "20Gi"
          gpu: "1"
124
125
126
127
128
129
130
      envs:
        - name: DYN_SYSTEM_ENABLED
          value: "true"
        - name: DYN_SYSTEM_USE_ENDPOINT_HEALTH_STATUS
          value: "[\"generate\"]"
        - name: DYN_SYSTEM_PORT
          value: "9090"
131
132
      extraPodSpec:
        mainContainer:
133
134
135
136
137
138
          startupProbe:
            httpGet:
              path: /health
              port: 9090
            periodSeconds: 10
            failureThreshold: 60
139
          image: nvcr.io/nvidian/nim-llm-dev/vllm-runtime:dep-233.17
Alec's avatar
Alec committed
140
          workingDir: /workspace/components/backends/vllm
141
142
143
          command:
            - /bin/sh
            - -c
144
          args:
145
            - python3 -m dynamo.vllm --model Qwen/Qwen3-0.6B  --is-prefill-worker 2>&1 | tee /tmp/vllm.log