disagg_multimodal_llama.sh 3.89 KB
Newer Older
1
#!/bin/bash
2
# SPDX-FileCopyrightText: Copyright (c) 2025-2026 NVIDIA CORPORATION & AFFILIATES. All rights reserved.
3
4
5
# SPDX-License-Identifier: Apache-2.0
set -ex

6
7
8
SCRIPT_DIR="$(dirname "$(readlink -f "$0")")"
source "$SCRIPT_DIR/../../../common/launch_utils.sh"

9
10
# Default values
HEAD_NODE=0
11
12
MODEL_NAME="meta-llama/Llama-4-Maverick-17B-128E-Instruct-FP8"
EXTRA_ARGS=()
13
14
15
16
17
18
19
20

# Parse command line arguments
while [[ $# -gt 0 ]]; do
    case $1 in
        --head-node)
            HEAD_NODE=1
            shift 1
            ;;
21
22
23
24
        --model)
            MODEL_NAME=$2
            shift 2
            ;;
25
26
        -h|--help)
            echo "Usage: $0 [OPTIONS]"
27
28
29
            echo ""
            echo "Disaggregated multimodal serving with separate Prefill/Decode workers for Llama 4"
            echo ""
30
31
            echo "Options:"
            echo "  --head-node          Run as head node. Head node will run the HTTP server, processor and prefill worker."
32
            echo "  --model <model_name> Specify the VLM model to use (default: $MODEL_NAME)"
33
            echo "  -h, --help           Show this help message"
34
35
36
37
38
39
40
41
            echo ""
            echo "Examples:"
            echo "  # On head node:"
            echo "  $0 --head-node"
            echo ""
            echo "  # On worker node (requires NATS_SERVER and ETCD_ENDPOINTS pointing to head node):"
            echo "  $0"
            echo ""
42
43
44
            exit 0
            ;;
        *)
45
46
            EXTRA_ARGS+=("$1")
            shift
47
48
49
50
51
52
            ;;
    esac
done

trap 'echo Cleaning up...; kill 0' EXIT

53
54
HTTP_PORT="${DYN_HTTP_PORT:-8000}"
if [[ $HEAD_NODE -eq 1 ]]; then
55
56
57
    print_launch_banner --multimodal "Launching Disaggregated Multimodal Llama 4 (Multi-Node)" "$MODEL_NAME" "$HTTP_PORT"
else
    print_launch_banner --no-curl "Launching Disaggregated Multimodal Llama 4 (Multi-Node)" "$MODEL_NAME" "$HTTP_PORT"
58
59
fi

60
61
62
63
# Use TCP transport to avoid NATS payload limits for multimodal
export DYN_REQUEST_PLANE=tcp

# Configure model-specific args
64
65
66
67
68
69
70
GPU_MEM="0.80"
KV_BYTES="${_PROFILE_OVERRIDE_VLLM_KV_CACHE_BYTES:-}"
if [[ -n "$KV_BYTES" ]]; then
    GPU_MEM_ARGS="--kv-cache-memory-bytes $KV_BYTES --gpu-memory-utilization 0.01"
else
    GPU_MEM_ARGS="--gpu-memory-utilization $GPU_MEM"
fi
71
72
MODEL_SPECIFIC_ARGS=""
if [[ "$MODEL_NAME" == "meta-llama/Llama-4-Maverick-17B-128E-Instruct-FP8" ]]; then
73
    MODEL_SPECIFIC_ARGS="--tensor-parallel-size=8 --max-model-len=208960 $GPU_MEM_ARGS"
74
fi
75
76
77

if [[ $HEAD_NODE -eq 1 ]]; then
    # run ingress
78
79
    # dynamo.frontend accepts either --http-port flag or DYN_HTTP_PORT env var (defaults to 8000)
    python -m dynamo.frontend &
80

81
82
    # run processor (CPU-only to avoid competing for GPU memory with workers)
    CUDA_VISIBLE_DEVICES="" \
83
    python -m dynamo.vllm --route-to-encoder --enable-multimodal --model $MODEL_NAME &
84

85
86
87
88
89
90
91
    # Prefill worker handles prompt processing and image encoding
    # Uses all 8 GPUs for tensor-parallel
    CUDA_VISIBLE_DEVICES=0,1,2,3,4,5,6,7 \
    VLLM_NIXL_SIDE_CHANNEL_PORT=20097 \
    python -m dynamo.vllm \
        --enable-multimodal \
        --model $MODEL_NAME \
92
        --disaggregation-mode prefill \
93
        --kv-transfer-config '{"kv_connector":"NixlConnector","kv_role":"kv_both"}' \
94
95
96
        $MODEL_SPECIFIC_ARGS \
        --kv-events-config '{"publisher":"zmq","topic":"kv-events","endpoint":"tcp://*:20080"}' \
        "${EXTRA_ARGS[@]}" &
97
98
else
    # run decode worker on non-head node
99
100
101
102
103
104
    # Uses all 8 GPUs for tensor-parallel
    CUDA_VISIBLE_DEVICES=0,1,2,3,4,5,6,7 \
    VLLM_NIXL_SIDE_CHANNEL_PORT=20098 \
    python -m dynamo.vllm \
        --enable-multimodal \
        --model $MODEL_NAME \
105
        --kv-transfer-config '{"kv_connector":"NixlConnector","kv_role":"kv_both"}' \
106
107
108
        $MODEL_SPECIFIC_ARGS \
        --kv-events-config '{"publisher":"zmq","topic":"kv-events","endpoint":"tcp://*:20081"}' \
        "${EXTRA_ARGS[@]}" &
109
110
fi

111
112
# Exit on first worker failure; kill 0 in the EXIT trap tears down the rest
wait_any_exit