disagg-multinode.yaml 3.15 KB
Newer Older
1
2
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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
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
98
99
100
101
102
103
104
105
106
107
108
109
# SPDX-FileCopyrightText: Copyright (c) 2025 NVIDIA CORPORATION & AFFILIATES. All rights reserved.
# SPDX-License-Identifier: Apache-2.0

apiVersion: nvidia.com/v1alpha1
kind: DynamoGraphDeployment
metadata:
  name: sglang-disagg-multinode
spec:
  envs:
  - name: HF_TOKEN
    valueFrom:
      secretKeyRef:
        name: hf-token-secret
        key: HF_TOKEN
  - name: GLOO_SOCKET_IFNAME
    value: "eth0"
  backendFramework: sglang
  services:
    Frontend:
      dynamoNamespace: sglang-disagg-multinode
      componentType: main
      replicas: 1
      extraPodSpec:
        mainContainer:
          image: my-registry/sglang-runtime:my-tag
          workingDir: /workspace/components/backends/sglang
          command: ["sh", "-c"]
          args:
            - "python3 -m dynamo.sglang.utils.clear_namespace --namespace sglang-disagg-multinode && python3 -m dynamo.frontend --http-port=8000"
    decode:
      multinode:
        nodeCount: 2
      envFromSecret: hf-token-secret
      dynamoNamespace: sglang-disagg-multinode
      componentType: worker
      replicas: 1
      resources:
        requests:
          cpu: "10"
          memory: "40Gi"
        limits:
          cpu: "10"
          memory: "40Gi"
          gpu: "4"
      extraPodSpec:
        mainContainer:
          image: my-registry/sglang-runtime:my-tag
          workingDir: /workspace/components/backends/sglang
          command: ["sh", "-c"]
          args:
            - "python3"
            - "-m"
            - "dynamo.sglang.decode_worker"
            - "--model-path"
            - "meta-llama/Llama-3.3-70B-Instruct"
            - "--served-model-name"
            - "meta-llama/Llama-3.3-70B-Instruct"
            - "--tp-size"
            - "8"
            - "--trust-remote-code"
            - "--skip-tokenizer-init"
            - "--disaggregation-mode"
            - "decode"
            - "--disaggregation-transfer-backend"
            - "nixl"
            - "--disaggregation-bootstrap-port"
            - "30001"
            - "--mem-fraction-static"
            - "0.82"
    prefill:
      multinode:
        nodeCount: 2
      envFromSecret: hf-token-secret
      dynamoNamespace: sglang-disagg
      componentType: worker
      replicas: 1
      resources:
        requests:
          cpu: "10"
          memory: "40Gi"
        limits:
          cpu: "10"
          memory: "40Gi"
          gpu: "4"
      extraPodSpec:
        mainContainer:
          image: my-registry/sglang-runtime:my-tag
          workingDir: /workspace/components/backends/sglang
          command: ["sh", "-c"]
          args:
            - "python3"
            - "-m"
            - "dynamo.sglang.worker"
            - "--model-path"
            - "meta-llama/Llama-3.3-70B-Instruct"
            - "--served-model-name"
            - "meta-llama/Llama-3.3-70B-Instruct"
            - "--tp-size"
            - "8"
            - "--trust-remote-code"
            - "--skip-tokenizer-init"
            - "--disaggregation-mode"
            - "prefill"
            - "--disaggregation-transfer-backend"
            - "nixl"
            - "--disaggregation-bootstrap-port"
            - "30001"
            - "--mem-fraction-static"
            - "0.82"