2411rust,cargo清理缓存

原文

Cargo最近在晚间通道上取得了一个不稳定的功能(从nightly-2023-11-17开始),它可自动清理Cargo主目录中的缓存内容.

总之,请求使用晚间通道的人启用此功能,并在Cargo问题跟踪器上报告问题.要启用它,请在你的一般在~/.cargo/config.toml%USERPROFILE%\.cargo\config.toml(对窗口)的Cargo配置文件中放入以下内容:

cpp 复制代码
[unstable]
gc = true

或设置CARGO_UNSTABLE_GC=true环境变量或使用-ZgcCLI标志来为单个命令打开它.

特别希望使用不寻常的文件系统或环境的人试一下,因为实现的某些部分是相关的,在为所有人启用它前需要通过测试.

该特点是什么

Cargo主目录中,Cargo保存了可无限增长且可能会非常大(很容易达到许多GB)的各种缓存数据.社区成员已开发了管理该缓存的工具,比如cargo-cache,但cargo自身从未公开过管理它的能力.

此缓存包括:

1,如来自crates.io包依赖元数据注册表索引数据.

2,从注册表下载的压缩.crate文件.

3,rustc用来读取源码和编译依赖.crate文件的未压缩内容.

4,git依赖使用的git仓库的克隆.

新的垃集("GC")功能增加了跟踪此缓存数据,这样cargo自动或手动删除未使用的文件.它保存一个跟踪上次使用各种缓存元素时间SQLite数据库.

每次运行读写缓存数据cargo命令时,它都会使用上次使用该数据的时间戳更新数据库.

尚未包括清理目标目录.

自动清理

运行cargo时,它每天检查一次上次使用的缓存跟踪器,并确定在一段时间内是否有不用的缓存元素.如果没有,则自动删除它们.

大多数一般会执行重要工作的命令都会有它,如cargo buildcargo fetch.

默认,如果有1个月未使用,则删除可在本地重建的数据,并删除3个月必须重新下载的数据.

如果cargo离线状态,如使用--离线--frozen函数,以避免删除长时离线可能要用的项目,则禁止自动删除函数.

最初实现公开了各种配置块来控制自动清理的工作方式.但是,稳定下来时,没有公开太多的低级细节,因此在未来可能会改变.

手动清理

如果想手动从缓存删除数据,则在cargo clean gc子命令下加了几个选项.可用此子命令来正常的自动每日清理,或指定要删除的数据不同选项.

几个选项可用来指定要删除的数据期限(如--maxdownloadage=3days)或指定缓存的最大大小(如--maxdownloadsize=1GiB).

注意

启用gc功能后,只需继续使用cargo正常业务即可.可见,在cargo~/.cargo/.globalcache主目录中的SQLite数据库保存数据.

在第一次使用cargo后,它填充数据库,跟踪cargo主目录中已有的所有数据.然后,1个月后,cargo应该开始删除旧数据,3个月删除更多数据.

最终是,在这段时间后,会开始注意到主目录总体上使用的空间更少.

如果遇见问题,可禁止gc功能,cargo应该会恢复到之前的行为.

相关推荐
悟能不能悟5 小时前
redis的红锁
数据库·redis·缓存
Vallelonga6 小时前
Rust 中的数组和数组切片引用
开发语言·rust
Kiri霧6 小时前
Rust模式匹配详解
开发语言·windows·rust
酷ku的森12 小时前
Redis的缓存更新策略
缓存
mit6.82414 小时前
理念导向编程|ts
rust·typescript
野犬寒鸦14 小时前
从零起步学习Redis || 第十一章:主从切换时的哨兵机制如何实现及项目实战
java·服务器·数据库·redis·后端·缓存
callJJ17 小时前
缓存雪崩、击穿、穿透是什么与解决方案
缓存
如竟没有火炬18 小时前
LRU缓存——双向链表+哈希表
数据结构·python·算法·leetcode·链表·缓存
阿湯哥19 小时前
Redis数据库隔离业务缓存对查询性能的影响分析
数据库·redis·缓存
麦兜*19 小时前
Redis 7.2 新特性实战:Client-Side Caching(客户端缓存)如何大幅降低延迟?
数据库·spring boot·redis·spring·spring cloud·缓存·tomcat