sysutils-stdio-rust is a Model Context Protocol (MCP) server written in Rust. It provides system utility tools to MCP clients (like Gemini) using the Stdio transport (Standard Input/Output).
This project allows LLMs to safely query local system information such as CPU usage, memory statistics, and disk space.
- MCP Stdio Transport: Communicates via JSON-RPC messages over stdin/stdout.
- Performance: Built with Rust and Tokio for efficiency.
- Direct CLI Mode: Can be run directly from the command line for quick reports.
- Structured Logging: Logs are sent to
stderrin JSON format to avoid interfering with the JSON-RPC transport onstdout.
The server exposes the following MCP tools:
-
local_system_info: Generates a comprehensive system report.- System Name, Kernel, OS Version, Hostname
- CPU Core Count
- Memory Usage (Total, Used, Swap)
- Network Interface Statistics (RX/TX bytes, MAC addresses)
-
disk_usage: Lists usage statistics for all mounted disks.- Mount Point, File System
- Used/Total Space
- Percentage Used
- Rust (Edition 2024 compatible)
make(optional, for convenience)
Clone the repository and build the project:
cargo build --releaseThis project is configured for use with the Gemini CLI. The configuration is located in .gemini/settings.json:
{
"mcpServers": {
"sysutils-stdio-rust": {
"command": "cargo",
"args": ["run", "--quiet", "--release"],
"env": {
"RUST_LOG": "info,sysutils_stdio_rust=debug"
}
}
}
}When you start a session with Gemini, this server will automatically start, and the tools will be available to the model.
You can run the tools directly without an MCP client for debugging or quick checks:
System Info:
make info
# OR
cargo run --quiet -- infoDisk Usage:
make disk
# OR
cargo run --quiet -- diskTo start the server manually (it will wait for JSON-RPC input on stdin):
make run
# OR
cargo run --release- Check:
make check - Test:
make test - Format:
make fmt - Lint:
make clippy