Skip to content

Files

Latest commit

2d7f9ae · Mar 18, 2025

History

History
115 lines (80 loc) · 3.77 KB

README.md

File metadata and controls

115 lines (80 loc) · 3.77 KB

Dynamo Runtime

A Datacenter Scale Distributed Inference Serving Framework

License

Rust implementation of the Dynamo runtime system, enabling distributed computing capabilities for machine learning workloads.

🛠️ Prerequisites

Install Rust and Cargo using rustup:

curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh

Build

cargo build
cargo test

Start Dependencies

Docker Compose

The simplest way to deploy the pre-requisite services is using docker-compose, defined in deploy/docker-compose.yml.

docker-compose up -d

This will deploy a NATS.io server and an etcd server used to communicate between and discover components at runtime.

Local (alternate)

To deploy the pre-requisite services locally instead of using docker-compose above, you can manually launch each:

Run Examples

When developing or running examples, any process or user that shared your core-services (etcd and nats.io) will be operating within your distributed runtime.

The current examples use a hard-coded namespace. We will address the namespace collisions later.

All examples require the etcd and nats.io pre-requisites to be running and available.

Rust hello_world

With two terminals open, in one window:

cd examples/hello_world
cargo run --bin server

In the second terminal, execute:

cd examples/hello_world
cargo run --bin client

which should yield some output similar to:

    Finished `dev` profile [unoptimized + debuginfo] target(s) in 6.25s
     Running `target/debug/client`
Annotated { data: Some("h"), id: None, event: None, comment: None }
Annotated { data: Some("e"), id: None, event: None, comment: None }
Annotated { data: Some("l"), id: None, event: None, comment: None }
Annotated { data: Some("l"), id: None, event: None, comment: None }
Annotated { data: Some("o"), id: None, event: None, comment: None }
Annotated { data: Some(" "), id: None, event: None, comment: None }
Annotated { data: Some("w"), id: None, event: None, comment: None }
Annotated { data: Some("o"), id: None, event: None, comment: None }
Annotated { data: Some("r"), id: None, event: None, comment: None }
Annotated { data: Some("l"), id: None, event: None, comment: None }
Annotated { data: Some("d"), id: None, event: None, comment: None }

Python

See the README.md for details

The Python and Rust hello_world client and server examples are interchangeable, so you can start the Python server.py and talk to it from the Rust client.