Cargo.toml 3.47 KB
Newer Older
1
2
3
4
5
# SPDX-FileCopyrightText: Copyright (c) 2025 NVIDIA CORPORATION & AFFILIATES. All rights reserved.
# SPDX-License-Identifier: Apache-2.0

[workspace]
members = [
6
    "components/metrics",
7
8
9
    "launch/*",
    "lib/llm",
    "lib/runtime",
10
    "lib/tokens",
11
    "lib/async-openai",
12
    "lib/parsers",
13
    "lib/bindings/c",
14
    "lib/engines/*",
15
]
16
resolver = "3"
17
18

[workspace.package]
19
version = "0.5.0"
20
edition = "2024"
21
22
description = "Dynamo Inference Framework"
authors = ["NVIDIA Inc. <sw-dl-dynamo@nvidia.com>"]
23
license = "Apache-2.0"
Neelay Shah's avatar
Neelay Shah committed
24
25
homepage = "https://github.com/ai-dynamo/dynamo"
repository = "https://github.com/ai-dynamo/dynamo.git"
26
keywords = ["llm", "genai", "inference", "nvidia", "distributed"]
27
28

[workspace.dependencies]
29
# Local crates
30
31
32
dynamo-runtime = { path = "lib/runtime", version = "0.5.0" }
dynamo-llm = { path = "lib/llm", version = "0.5.0" }
dynamo-tokens = { path = "lib/tokens", version = "0.5.0" }
33
34
35
36
dynamo-async-openai = { path = "lib/async-openai", version = "0.5.0", features = [
    "byot",
    "rustls",
] }
37
dynamo-parsers = { path = "lib/parsers", version = "0.5.0" }
38

39
# External dependencies
40
anyhow = { version = "1" }
41
async-nats = { version = "0.40", features = ["service"] }
42
43
async-stream = { version = "0.3" }
async-trait = { version = "0.1" }
44
45
46
async_zmq = { version = "0.4.0" }
blake3 = { version = "1" }
bytes = { version = "1" }
47
48
49
50
51
52
53
chrono = { version = "0.4", default-features = false, features = [
    "alloc",
    "std",
    "clock",
    "now",
    "serde",
] }
54
55
56
derive_builder = { version = "0.20" }
derive-getters = { version = "0.5" }
either = { version = "1.13", features = ["serde"] }
57
etcd-client = { version = "0.16", features = ["tls"] }
58
futures = { version = "0.3" }
59
60
61
62
63
64
65
66
67
68
hf-hub = { version = "0.4.2", default-features = false, features = [
    "tokio",
    "rustls-tls",
    "ureq",
] }

# ModelExpress for model downloading
modelexpress-client = { git = "https://github.com/ai-dynamo/modelexpress.git", rev = "a232220bf268a475d293914d407f4ae186f443e3", package = "modelexpress-client" }
modelexpress-common = { git = "https://github.com/ai-dynamo/modelexpress.git", rev = "a232220bf268a475d293914d407f4ae186f443e3", package = "modelexpress-common" }

69
humantime = { version = "2.2.0" }
70
libc = { version = "0.2" }
Ryan Olson's avatar
Ryan Olson committed
71
oneshot = { version = "0.1.11", features = ["std", "async"] }
72
prometheus = { version = "0.14" }
73
rand = { version = "0.9.0" }
74
75
76
77
78
reqwest = { version = "0.12.22", default-features = false, features = [
    "json",
    "stream",
    "rustls-tls",
] }
79
80
serde = { version = "1", features = ["derive"] }
serde_json = { version = "1" }
81
strum = { version = "0.27", features = ["derive"] }
82
tempfile = "3"
83
84
85
thiserror = { version = "2.0.11" }
tokio = { version = "1", features = ["full"] }
tokio-stream = { version = "0.1" }
Ryan Olson's avatar
Ryan Olson committed
86
tokio-util = { version = "0.7", features = ["codec", "net", "rt"] }
87
88
tower-http = { version = "0.6", features = ["trace"] }
axum = { version = "0.8", features = ["macros"] }
89
tracing = { version = "0.1" }
90
91
92
93
94
tracing-subscriber = { version = "0.3", features = [
    "env-filter",
    "local-time",
    "json",
] }
95
validator = { version = "0.20.0", features = ["derive"] }
96
uuid = { version = "1.17", features = ["v4", "serde"] }
97
url = { version = "2.5", features = ["serde"] }
98
xxhash-rust = { version = "0.8", features = ["xxh3", "const_xxh3"] }
Graham King's avatar
Graham King committed
99
100
101

[profile.dev.package]
insta.opt-level = 3
102

103
104
105
106
[profile.dev]
# release level optimizations otherwise everything feels slow
opt-level = 3

107
[profile.release]
108
# These make the build much slower but shrink the binary, and could help performance
109
codegen-units = 1
110
lto = true