Skip to content
This repository was archived by the owner on Sep 4, 2025. It is now read-only.

Commit d4a2ac8

Browse files
authored
[build] enable existing pytorch (for GH200, aarch64, nightly) (vllm-project#8713)
1 parent c6bd70d commit d4a2ac8

File tree

3 files changed

+42
-1
lines changed

3 files changed

+42
-1
lines changed

docs/source/getting_started/installation.rst

Lines changed: 23 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -72,6 +72,29 @@ You can also build and install vLLM from source:
7272
$ cd vllm
7373
$ pip install -e . # This may take 5-10 minutes.
7474
75+
.. note::
76+
77+
This will uninstall existing PyTorch, and install the version required by vLLM. If you want to use an existing PyTorch installation, there need to be some changes:
78+
79+
.. code-block:: console
80+
81+
$ git clone https://github.com/vllm-project/vllm.git
82+
$ cd vllm
83+
$ python use_existing_torch.py
84+
$ pip install -r requirements-build.txt
85+
$ pip install -e . --no-build-isolation
86+
87+
The differences are:
88+
89+
- ``python use_existing_torch.py``: This script will remove all the PyTorch versions in the requirements files, so that the existing PyTorch installation will be used.
90+
- ``pip install -r requirements-build.txt``: You need to manually install the requirements for building vLLM.
91+
- ``pip install -e . --no-build-isolation``: You need to disable build isolation, so that the build system can use the existing PyTorch installation.
92+
93+
This is especially useful when the PyTorch dependency cannot be easily installed via pip, e.g.:
94+
95+
- build vLLM with PyTorch nightly or a custom PyTorch build.
96+
- build vLLM with aarch64 and cuda (GH200), where the PyTorch wheels are not available on PyPI. Currently, only PyTorch nightly has wheels for aarch64 with CUDA. You can run ``pip3 install --pre torch torchvision torchaudio --index-url https://download.pytorch.org/whl/nightly/cu124`` to install PyTorch nightly, and then build vLLM on top of it.
97+
7598
.. note::
7699

77100
vLLM can fully run only on Linux, but you can still build it on other systems (for example, macOS). This build is only for development purposes, allowing for imports and a more convenient dev environment. The binaries will not be compiled and not work on non-Linux systems. You can create such a build with the following commands:

requirements-common.txt

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -18,7 +18,7 @@ prometheus_client >= 0.18.0
1818
prometheus-fastapi-instrumentator >= 7.0.0
1919
tiktoken >= 0.6.0 # Required for DBRX tokenizer
2020
lm-format-enforcer == 0.10.6
21-
outlines >= 0.0.43, < 0.1 # Requires torch >= 2.1.0
21+
outlines >= 0.0.43, < 0.1
2222
typing_extensions >= 4.10
2323
filelock >= 3.10.4 # filelock starts to support `mode` argument from 3.10.4
2424
partial-json-parser # used for parsing partial JSON outputs

use_existing_torch.py

Lines changed: 18 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,18 @@
1+
import glob
2+
3+
requires_files = glob.glob('requirements*.txt')
4+
requires_files += ["pyproject.toml"]
5+
for file in requires_files:
6+
print(f">>> cleaning {file}")
7+
with open(file, 'r') as f:
8+
lines = f.readlines()
9+
if "torch" in "".join(lines).lower():
10+
print("removed:")
11+
with open(file, 'w') as f:
12+
for line in lines:
13+
if 'torch' not in line.lower():
14+
f.write(line)
15+
else:
16+
print(line.strip())
17+
print(f"<<< done cleaning {file}")
18+
print()

0 commit comments

Comments
 (0)