vllm-setup.md 5.62 KB
Newer Older
Ryan Olson's avatar
Ryan Olson committed
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
<!--
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.
-->

# Running KVBM in vLLM

20
This guide explains how to leverage KVBM (KV Block Manager) to manage KV cache and do KV offloading in vLLM.
Ryan Olson's avatar
Ryan Olson committed
21

22
To learn what KVBM is, please check [here](kvbm_architecture.md)
Ryan Olson's avatar
Ryan Olson committed
23
24
25
26
27

## Quick Start

To use KVBM in vLLM, you can follow the steps below:

28
### Docker Setup
Ryan Olson's avatar
Ryan Olson committed
29
30
```bash
# start up etcd for KVBM leader/worker registration and discovery
ZichengMa's avatar
ZichengMa committed
31
docker compose -f deploy/docker-compose.yml up -d
Ryan Olson's avatar
Ryan Olson committed
32
33

# build a container containing vllm and kvbm
jthomson04's avatar
jthomson04 committed
34
./container/build.sh --framework vllm --enable-kvbm
Ryan Olson's avatar
Ryan Olson committed
35
36

# launch the container
jthomson04's avatar
jthomson04 committed
37
./container/run.sh --framework vllm -it --mount-workspace --use-nixl-gds
38
```
Ryan Olson's avatar
Ryan Olson committed
39

40
41
42
43
44
### Aggregated Serving with KVBM
```bash
cd $DYNAMO_HOME/components/backends/vllm
./launch/agg_kvbm.sh
```
Ryan Olson's avatar
Ryan Olson committed
45

46
### Disaggregated Serving with KVBM
47
```bash
48
# 1P1D - one prefill worker and one decode worker
49
50
51
# NOTE: need at least 2 GPUs
cd $DYNAMO_HOME/components/backends/vllm
./launch/disagg_kvbm.sh
52
53
54
55
56

# 2P2D - two prefill workers and two decode workers
# NOTE: need at least 4 GPUs
cd $DYNAMO_HOME/components/backends/vllm
./launch/disagg_kvbm_2p2d.sh
57
58
59
```
> [!NOTE]
> To tune the size of CPU or disk cache, set `DYN_KVBM_CPU_CACHE_GB` and `DYN_KVBM_DISK_CACHE_GB` accordingly. We only set `DYN_KVBM_CPU_CACHE_GB=20` in both scripts above.
60

61
62
> [!NOTE]
> `DYN_KVBM_CPU_CACHE_GB` must be set and `DYN_KVBM_DISK_CACHE_GB` is optional.
Ryan Olson's avatar
Ryan Olson committed
63

64
65
66
67
68
> [!NOTE]
> When disk offloading is enabled, to extend SSD lifespan, disk offload filtering would be enabled by default. The current policy is only offloading KV blocks from CPU to disk if the blocks have frequency equal or more than `2`. Frequency is determined via doubling on cache hit (init with 1) and decrement by 1 on each time decay step.
>
> To disable disk offload filtering, set `DYN_KVBM_DISABLE_DISK_OFFLOAD_FILTER` to true or 1.

69
70
71
72
### Sample Request
```bash
# make a request to verify vLLM with KVBM is started up correctly
# NOTE: change the model name if served with a different one
Ryan Olson's avatar
Ryan Olson committed
73
curl localhost:8000/v1/chat/completions   -H "Content-Type: application/json"   -d '{
74
    "model": "Qwen/Qwen3-0.6B",
Ryan Olson's avatar
Ryan Olson committed
75
76
77
78
79
80
81
    "messages": [
    {
        "role": "user",
        "content": "In the heart of Eldoria, an ancient land of boundless magic and mysterious creatures, lies the long-forgotten city of Aeloria. Once a beacon of knowledge and power, Aeloria was buried beneath the shifting sands of time, lost to the world for centuries. You are an intrepid explorer, known for your unparalleled curiosity and courage, who has stumbled upon an ancient map hinting at ests that Aeloria holds a secret so profound that it has the potential to reshape the very fabric of reality. Your journey will take you through treacherous deserts, enchanted forests, and across perilous mountain ranges. Your Task: Character Background: Develop a detailed background for your character. Describe their motivations for seeking out Aeloria, their skills and weaknesses, and any personal connections to the ancient city or its legends. Are they driven by a quest for knowledge, a search for lost familt clue is hidden."
    }
    ],
    "stream":false,
82
    "max_tokens": 10
Ryan Olson's avatar
Ryan Olson committed
83
84
  }'
```
85

86
Alternatively, can use `vllm serve` directly to use KVBM for aggregated serving:
87
```bash
88
vllm serve --kv-transfer-config '{"kv_connector":"DynamoConnector","kv_role":"kv_both", "kv_connector_module_path": "dynamo.llm.vllm_integration.connector"}' Qwen/Qwen3-0.6B
89
90
```

91
92
93
94
95
96
97
## Enable and View KVBM Metrics

Follow below steps to enable metrics collection and view via Grafana dashboard:
```bash
# Start the basic services (etcd & natsd), along with Prometheus and Grafana
docker compose -f deploy/docker-compose.yml --profile metrics up -d

98
99
# set env var DYN_KVBM_METRICS to true, when launch via dynamo
# Optionally set DYN_KVBM_METRICS_PORT to choose the /metrics port (default: 6880).
100
# NOTE: update launch/disagg_kvbm.sh or launch/disagg_kvbm_2p2d.sh as needed
101
DYN_KVBM_METRICS=true \
102
python -m dynamo.vllm \
103
104
    --model Qwen/Qwen3-0.6B \
    --enforce-eager \
105
    --connector kvbm
106
107

# optional if firewall blocks KVBM metrics ports to send prometheus metrics
108
sudo ufw allow 6880/tcp
109
110
111
```

View grafana metrics via http://localhost:3001 (default login: dynamo/dynamo) and look for KVBM Dashboard
112
113
114

## Benchmark KVBM

115
Once the model is loaded ready, follow below steps to use LMBenchmark to benchmark KVBM performance:
116
117
118
119
120
121
122
```bash
git clone https://github.com/LMCache/LMBenchmark.git

# show case of running the synthetic multi-turn chat dataset.
# we are passing model, endpoint, output file prefix and qps to the sh script.
cd LMBenchmark/synthetic-multi-round-qa
./long_input_short_output_run.sh \
123
    "Qwen/Qwen3-0.6B" \
124
125
126
127
128
129
130
131
132
133
    "http://localhost:8000" \
    "benchmark_kvbm" \
    1

# Average TTFT and other perf numbers would be in the output from above cmd
```
More details about how to use LMBenchmark could be found [here](https://github.com/LMCache/LMBenchmark).

`NOTE`: if metrics are enabled as mentioned in the above section, you can observe KV offloading, and KV onboarding in the grafana dashboard.

134
To compare, you can run `vllm serve Qwen/Qwen3-0.6B` to turn KVBM off as the baseline.