# 创建一个工程
cargo new my-project
在 Rust 中,工作空间(Workspace) 是一个包含多个 Rust 项目的共享环境,用于管理多个 crate(库或可执行文件)。它允许多个 Rust 项目共享 Cargo.lock
、依赖项和 target/
目录,提高编译效率,并且适用于多包管理、模块化开发。
Rust 工作空间适用于以下场景:
管理多个相关的 crate(类似于 monorepo)
app
,但 app
依赖于 lib1
和 lib2
,可以用工作空间管理它们。共享依赖,减少重复构建,提高编译速度。
app
和 lib1
都依赖 serde
,Rust 只会编译一次。统一管理 Cargo.lock
,保证所有 crate 依赖版本一致。
mkdir my_workspace
cd my_workspace
cargo new --lib lib1
cargo new --lib lib2
cargo new --bin app
你会得到如下目录结构:
my_workspace/
├── Cargo.toml # 工作空间的根 Cargo.toml
├── lib1/
│ ├── Cargo.toml
│ ├── src/
│ │ └── lib.rs
├── lib2/
│ ├── Cargo.toml
│ ├── src/
│ │ └── lib.rs
├── app/
│ ├── Cargo.toml
│ ├── src/
│ │ └── main.rs
Cargo.toml
在 my_workspace/Cargo.toml
(根目录)中添加:
[workspace]
members = ["lib1", "lib2", "app"]
resolver = "2" # 使用 Cargo v2 依赖解析
这样,Rust 知道这 3 个项目属于同一个工作空间。
app
依赖 lib1
和 lib2
修改 app/Cargo.toml
:
[dependencies]
lib1 = { path = "../lib1" }
lib2 = { path = "../lib2" }
在 app/src/main.rs
:
use lib1::hello;
use lib2::world;
fn main() {
hello();
world();
}
在 lib1/src/lib.rs
:
pub fn hello() {
println!("Hello from lib1!");
}
在 lib2/src/lib.rs
:
pub fn world() {
println!("World from lib2!");
}
你可以在 my_workspace/
目录下直接运行:
cargo run -p app
输出:
Hello from lib1!
World from lib2!
你也可以一次性编译所有 crate:
cargo build
Cargo.lock
所有 crate 共享 Cargo.lock
,保证相同的依赖版本:
my_workspace/
├── Cargo.lock # 统一管理所有 crate 的依赖
├── ...
workspace.dependencies
如果多个 crate 需要相同的依赖项,可以在根 Cargo.toml
统一声明:
[workspace.dependencies]
serde = "1.0"
然后,在 lib1/Cargo.toml
和 lib2/Cargo.toml
这样写:
[dependencies]
serde = { workspace = true }
这样可以确保 lib1
和 lib2
使用相同版本的 serde
,避免版本冲突。
✅ Rust 工作空间 适用于管理多个 crate,优点包括:
target/
)Cargo.lock
和 workspace.dependencies
)适用于:
你有具体的 Rust 项目需求吗?我可以帮你优化工作空间结构!