"pcdet/ops/vscode:/vscode.git/clone" did not exist on "8447a4754000cd9fb3018d8fd5b1c117bc5754b1"
README.md 4.27 KB
Newer Older
Neelay Shah's avatar
Neelay Shah committed
1
<!--
Neelay Shah's avatar
Neelay Shah committed
2
SPDX-FileCopyrightText: Copyright (c) 2024-2025 NVIDIA CORPORATION & AFFILIATES. All rights reserved.
Neelay Shah's avatar
Neelay Shah committed
3
SPDX-License-Identifier: Apache-2.0
4
5
6
7
8
9
10
11
12
13
14
15

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.
Neelay Shah's avatar
Neelay Shah committed
16
17
18
19
20
21
22
-->

# Triton Distributed

<h4> A Datacenter Scale Distributed Inference Serving Framework </h4>

[![License](https://img.shields.io/badge/License-Apache_2.0-blue.svg)](https://opensource.org/licenses/Apache-2.0)
23
24
[![GitHub Release](https://img.shields.io/github/v/release/triton-inference-server/triton_distributed)](https://github.com/triton-inference-server/triton_distributed/releases/latest)

Neelay Shah's avatar
Neelay Shah committed
25
26
27
28
29
30
31
32
33

Triton Distributed is a flexible, component based, data center scale
inference serving framework designed to leverage the strengths of the
standalone Triton Inference Server while expanding its capabilities
to meet the demands of complex use cases including those of Generative
AI. It is designed to enable developers to implement and customize
routing, load balancing, scaling and workflow definitions at the data
center scale without sacrificing performance or ease of use.

34
> [!NOTE]
Neelay Shah's avatar
Neelay Shah committed
35
36
37
38
> This project is currently in the alpha / experimental /
> rapid-prototyping stage and we are actively looking for feedback and
> collaborators.

39
40
## Building Triton Distributed

41
### Requirements
42
43
Triton Distributed development and examples are container based.

44
45
46
47
48
* [Docker](https://docs.docker.com/get-started/get-docker/)
* [buildx](https://github.com/docker/buildx)

### Development

49
50
You can build the Triton Distributed container using the build scripts
in `container/` (or directly with `docker build`).
51

52
We provide 3 types of builds:
53
54
55
56
57

1. `STANDARD` which includes our default set of backends (onnx, openvino...)
2. `TENSORRTLLM` which includes our TRT-LLM backend
3. `VLLM` which includes our VLLM backend

Neelay Shah's avatar
Neelay Shah committed
58
For example, if you want to build a container for the `STANDARD` backends you can run
59

Neelay Shah's avatar
Neelay Shah committed
60
`./container/build.sh`
61
62
63

Please see the instructions in the corresponding example for specific build instructions.

64
65
66
67
68
69
70
71
72
73
## Running Triton Distributed for Local Testing and Development

You can run the Triton Distributed container using the run scripts in
`container/` (or directly with `docker run`).

The run script offers a few common workflows:

1. Running a command in a container and exiting.

```
74
./container/run.sh -- python3 -c "import triton_distributed.runtime; help(triton_distributed.runtime)"
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
```

2. Starting an interactive shell.
```
./container/run.sh -it
```

3. Mounting the local workspace and Starting an interactive shell.

```
./container/run.sh -it --mount-workspace
```

The last command also passes common environment variables ( ```-e
HF_TOKEN```) and mounts common directories such as ```/tmp:/tmp```,
```/mnt:/mnt```.

Please see the instructions in the corresponding example for specific
deployment instructions.
Neelay Shah's avatar
Neelay Shah committed
94

Neelay Shah's avatar
Neelay Shah committed
95
## Rust Based Distributed Runtime
Neelay Shah's avatar
Neelay Shah committed
96

Neelay Shah's avatar
Neelay Shah committed
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
Triton distributed has a new rust based distributed runtime with
implementation under development. The rust based runtime enables
serving arbitrary python code as well as native rust. Please note the
APIs are subject to change.

### Hello World

[Hello World](./runtime/rust/python-wheel/examples/hello_world)

A basic example demonstrating the rust based runtime and python
bindings.

### LLM

[VLLM](./examples/python_rs/llm/vllm)

An intermediate example expanding further on the concepts introduced
in the Hello World example. In this example, we demonstrate
[Disaggregated Serving](https://arxiv.org/abs/2401.09670) as an
application of the components defined in Triton Distributed.

Neelay Shah's avatar
Neelay Shah committed
118
119
120
121
122
123
124
125
126
127
128
# Disclaimers

> [!NOTE]
> This project is currently in the alpha / experimental /
> rapid-prototyping stage and we will be adding new features incrementally.

1. The `TENSORRTLLM` and `VLLM` containers are WIP and not expected to
   work out of the box.

2. Testing has primarily been on single node systems with processes
   launched within a single container.