构建缓存
Cargo 将构建的输出存储在“target”目录中。默认情况下,这是位于 工作空间 根目录下名为 target
的目录。要更改位置,您可以设置 CARGO_TARGET_DIR
环境变量、build.target-dir
配置值或 --target-dir
命令行标志。
目录布局取决于您是否使用 --target
标志为特定平台构建。如果未指定 --target
,Cargo 将以为主机架构构建的模式运行。输出将进入目标目录的根目录,每个 配置文件 都存储在单独的子目录中。
目录 | 描述 |
---|---|
target/debug/ | 包含 dev 配置文件的输出。 |
target/release/ | 包含 release 配置文件的输出(使用 --release 选项)。 |
target/foo/ | 包含 foo 配置文件的构建输出(使用 --profile=foo 选项)。 |
出于历史原因,dev
和 test
配置文件存储在 debug
目录中,而 release
和 bench
配置文件存储在 release
目录中。用户定义的配置文件存储在与其名称相同的目录中。
使用 --target
为另一个目标构建时,输出将放置在以 目标 命名的目录中。
目录 | 示例 |
---|---|
target/<triple>/debug/ | target/thumbv7em-none-eabihf/debug/ |
target/<triple>/release/ | target/thumbv7em-none-eabihf/release/ |
**注意**:如果不使用
--target
,则会导致 Cargo 与构建脚本和过程宏共享您的依赖项。RUSTFLAGS
将与每次rustc
调用共享。使用--target
标志时,构建脚本和过程宏将单独构建(针对主机架构),并且不共享RUSTFLAGS
。
在配置文件目录(例如 debug
或 release
)中,工件将放置在以下目录中:
某些命令将其输出放置在 target
目录顶层的专用目录中。
目录 | 描述 |
---|---|
target/doc/ | 包含 rustdoc 文档(cargo doc )。 |
target/package/ | 包含 cargo package 和 cargo publish 命令的输出。 |
Cargo 还会创建构建过程所需的几个其他目录和文件。它们的布局被认为是 Cargo 的内部结构,可能会发生变化。其中一些目录包括:
目录 | 描述 |
---|---|
target/debug/deps/ | 依赖项和其他工件。 |
target/debug/incremental/ | rustc 增量输出,用于加速后续构建的缓存。 |
target/debug/build/ | 构建脚本 的输出。 |
依赖信息文件
每个编译后的工件旁边都有一个名为“依赖信息”的文件,后缀为 .d
。该文件采用类似 Makefile 的语法,指示重建工件所需的所有文件依赖项。它们旨在与外部构建系统一起使用,以便它们可以检测是否需要重新执行 Cargo。默认情况下,文件中的路径是绝对路径。请参阅 build.dep-info-basedir
配置选项以使用相对路径。
# Example dep-info file found in target/debug/foo.d
/path/to/myproj/target/debug/foo: /path/to/myproj/src/lib.rs /path/to/myproj/src/main.rs
共享缓存
可以使用第三方工具 sccache 在不同的工作空间之间共享构建的依赖项。
要设置 sccache
,请使用 cargo install sccache
安装它,并在调用 Cargo 之前将 RUSTC_WRAPPER
环境变量设置为 sccache
。如果您使用 bash,则将 export RUSTC_WRAPPER=sccache
添加到 .bashrc
中是有意义的。或者,您可以在 Cargo 配置 中设置 build.rustc-wrapper
。有关更多详细信息,请参阅 sccache 文档。