sysinfo

sysinfo

Rust编写的多系统资源监控库

sysinfo是一个Rust编写的系统信息获取库,支持多种主流操作系统。该库提供简洁的API,用于获取CPU、内存、磁盘、网络和硬件组件等系统资源信息。sysinfo具有多线程支持,提供性能优化建议,并可通过C接口使用。这使其成为开发系统监控和资源管理应用的理想选择。

sysinfo系统信息跨平台Rust性能监控Github开源项目

sysinfo

sysinfo 是一个用于获取系统信息的 crate。

支持的操作系统

目前支持以下操作系统(按字母顺序排列):

  • 安卓
  • FreeBSD
  • iOS
  • Linux
  • macOS
  • 树莓派
  • Windows

你仍然可以在不支持的操作系统上使用 sysinfo,它只会什么都不做并始终返回空值。你可以通过检查 [IS_SUPPORTED_SYSTEM] 常量直接在程序中检查是否支持某个操作系统。

支持的最低 rustc 版本是 1.74

使用方法

如果你想从旧版本迁移,不妨查看 CHANGELOG迁移指南

⚠️ 在尝试读取不同结构体的信息之前,你需要更新它们以获取最新信息,因为对于大多数情况,它是基于当前值和旧值之间的差异工作的。

这就是为什么保留同一个 [System] 实例比多次重新创建它要好得多。

你可以在 examples 文件夹中找到一个示例。你可以通过 cargo run --example simple 运行它。

否则,这里有一个简短的代码示例:

use sysinfo::{ Components, Disks, Networks, System, }; // 请注意,我们使用 "new_all" 来确保填充所有 CPU 和进程列表! let mut sys = System::new_all(); // 首先我们更新 `System` 结构体的所有信息。 sys.refresh_all(); println!("=> 系统:"); // RAM 和交换分区信息: println!("总内存:{} 字节", sys.total_memory()); println!("已用内存:{} 字节", sys.used_memory()); println!("总交换分区:{} 字节", sys.total_swap()); println!("已用交换分区:{} 字节", sys.used_swap()); // 显示系统信息: println!("系统名称:{:?}", System::name()); println!("系统内核版本:{:?}", System::kernel_version()); println!("系统操作系统版本:{:?}", System::os_version()); println!("系统主机名:{:?}", System::host_name()); // CPU 数量: println!("CPU 数量:{}", sys.cpus().len()); // 显示进程 ID、名称和磁盘使用情况: for (pid, process) in sys.processes() { println!("[{pid}] {:?} {:?}", process.name(), process.disk_usage()); } // 我们显示所有磁盘的信息: println!("=> 磁盘:"); let disks = Disks::new_with_refreshed_list(); for disk in &disks { println!("{disk:?}"); } // 网络接口名称、总接收数据和总发送数据: let networks = Networks::new_with_refreshed_list(); println!("=> 网络:"); for (interface_name, data) in &networks { println!( "{interface_name}:{} B(下载)/ {} B(上传)", data.total_received(), data.total_transmitted(), ); // 如果你想要自上次调用 `Networks::refresh` 以来接收/发送的数据量, // 使用 `received`/`transmitted`。 } // 组件温度: let components = Components::new_with_refreshed_list(); println!("=> 组件:"); for component in &components { println!("{component:?}"); }

请记住,要获取一些最新信息,你需要调用相应的 refresh 方法。例如,对于 CPU 使用率:

use sysinfo::System; let mut sys = System::new(); loop { sys.refresh_cpu_usage(); // 刷新 CPU 使用率。 for cpu in sys.cpus() { print!("{}% ", cpu.cpu_usage()); } // 休眠一段时间,让系统运行足够长的时间以获得有用的信息。 std::thread::sleep(sysinfo::MINIMUM_CPU_UPDATE_INTERVAL); }

默认情况下,sysinfo 使用多线程。但是,这可能会增加某些平台(如 macOS)的内存使用。可以通过在 Cargo.toml 中设置 default-features = false(这会禁用 multithread cargo 特性)来禁用此行为。

最佳实践 / 性能提示

大多数情况下,你不需要 sysinfo 提供的所有信息,而只需要其中的一部分。在这种情况下,建议只使用 refresh_specifics(...) 方法获取你需要的内容,以获得更好的性能。

另一个经常遇到的问题:除非你知道自己在做什么,否则几乎总是最好实例化 System 结构体一次,并在整个程序中使用这个实例。原因是因为许多信息需要之前的测量才能计算(例如 CPU 使用率)。另一个例子说明为什么这样做更好:如果你想列出所有正在运行的进程,sysinfo 需要为 Process 结构体列表分配所有内存,这在第一次运行时需要相当长的时间。

如果你的程序需要使用大量文件描述符,最好使用:

sysinfo::set_open_files_limit(0);

因为 sysinfo 保持一定数量的文件描述符打开,以在某些目标上刷新进程时获得更好的性能。

在树莓派上运行

在树莓派上构建可能会有困难。一个好的解决方法是交叉编译,然后将可执行文件发送到你的树莓派。

首先安装 arm 工具链,例如在 Ubuntu 上:

> sudo apt-get install gcc-multilib-arm-linux-gnueabihf

然后配置 cargo 使用相应的工具链:

cat << EOF > ~/.cargo/config [target.armv7-unknown-linux-gnueabihf] linker = "arm-linux-gnueabihf-gcc" EOF

最后,进行交叉编译:

rustup target add armv7-unknown-linux-gnueabihf cargo build --target=armv7-unknown-linux-gnueabihf

Docker 上的 Linux 和 Windows 子系统 Linux(WSL)

虚拟 Linux 系统,如通过 Docker 和 Windows 子系统 Linux(WSL)运行的系统,不会通过 /sys/class/hwmon/sys/class/thermal 接收主机硬件信息。因此,在虚拟系统上使用此库查询组件可能会返回无结果(或意外结果)。

在 macOS 或 iOS 沙盒/应用商店内运行的二进制文件中使用

苹果对通过应用商店分发的二进制文件可以链接的 API 有限制。默认情况下,sysinfo 与这些限制不兼容。你可以使用 apple-app-store 特性标志来禁用 Apple 禁止的功能。这也会启用 apple-sandbox 特性。对于在应用商店之外使用沙盒的应用程序,可以单独使用 apple-sandbox 特性来避免在运行时造成策略违反。

工作原理

我写了一篇博客文章,你可以在这里找到,解释了 sysinfo 如何在不同系统上提取信息。

C 接口

可以直接从 C 语言使用这个 crate。查看 Makefileexamples/simple.c 文件。

要构建 C 示例,只需运行:

> make > ./simple # 如果需要: > LD_LIBRARY_PATH=target/debug/ ./simple

基准测试

你可以通过以下方式在本地运行基准测试(需要 rust nightly 版本):

> cargo bench

捐赠

如果你欣赏我的工作并想支持我,你可以通过 github sponsorspatreon 进行捐赠。

编辑推荐精选

商汤小浣熊

商汤小浣熊

最强AI数据分析助手

小浣熊家族Raccoon,您的AI智能助手,致力于通过先进的人工智能技术,为用户提供高效、便捷的智能服务。无论是日常咨询还是专业问题解答,小浣熊都能以快速、准确的响应满足您的需求,让您的生活更加智能便捷。

imini AI

imini AI

像人一样思考的AI智能体

imini 是一款超级AI智能体,能根据人类指令,自主思考、自主完成、并且交付结果的AI智能体。

Keevx

Keevx

AI数字人视频创作平台

Keevx 一款开箱即用的AI数字人视频创作平台,广泛适用于电商广告、企业培训与社媒宣传,让全球企业与个人创作者无需拍摄剪辑,就能快速生成多语言、高质量的专业视频。

即梦AI

即梦AI

一站式AI创作平台

提供 AI 驱动的图片、视频生成及数字人等功能,助力创意创作

扣子-AI办公

扣子-AI办公

AI办公助手,复杂任务高效处理

AI办公助手,复杂任务高效处理。办公效率低?扣子空间AI助手支持播客生成、PPT制作、网页开发及报告写作,覆盖科研、商业、舆情等领域的专家Agent 7x24小时响应,生活工作无缝切换,提升50%效率!

TRAE编程

TRAE编程

AI辅助编程,代码自动修复

Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。

AI工具TraeAI IDE协作生产力转型热门
蛙蛙写作

蛙蛙写作

AI小说写作助手,一站式润色、改写、扩写

蛙蛙写作—国内先进的AI写作平台,涵盖小说、学术、社交媒体等多场景。提供续写、改写、润色等功能,助力创作者高效优化写作流程。界面简洁,功能全面,适合各类写作者提升内容品质和工作效率。

AI辅助写作AI工具蛙蛙写作AI写作工具学术助手办公助手营销助手AI助手
问小白

问小白

全能AI智能助手,随时解答生活与工作的多样问题

问小白,由元石科技研发的AI智能助手,快速准确地解答各种生活和工作问题,包括但不限于搜索、规划和社交互动,帮助用户在日常生活中提高效率,轻松管理个人事务。

热门AI助手AI对话AI工具聊天机器人
Transly

Transly

实时语音翻译/同声传译工具

Transly是一个多场景的AI大语言模型驱动的同声传译、专业翻译助手,它拥有超精准的音频识别翻译能力,几乎零延迟的使用体验和支持多国语言可以让你带它走遍全球,无论你是留学生、商务人士、韩剧美剧爱好者,还是出国游玩、多国会议、跨国追星等等,都可以满足你所有需要同传的场景需求,线上线下通用,扫除语言障碍,让全世界的语言交流不再有国界。

讯飞智文

讯飞智文

一键生成PPT和Word,让学习生活更轻松

讯飞智文是一个利用 AI 技术的项目,能够帮助用户生成 PPT 以及各类文档。无论是商业领域的市场分析报告、年度目标制定,还是学生群体的职业生涯规划、实习避坑指南,亦或是活动策划、旅游攻略等内容,它都能提供支持,帮助用户精准表达,轻松呈现各种信息。

AI办公办公工具AI工具讯飞智文AI在线生成PPTAI撰写助手多语种文档生成AI自动配图热门
下拉加载更多