mcp-system-monitor
Enables Claude to monitor CPU, memory, disk, processes, network connections, Docker containers, and system logs for system diagnostics and troubleshooting.
README
MCP System Monitor
A production-grade Model Context Protocol (MCP) server that provides Claude with comprehensive system monitoring and diagnostics capabilities.
What It Does
This MCP server gives Claude direct access to system metrics and diagnostics, enabling it to:
- Monitor CPU, memory, and disk usage in real-time
- Analyze running processes and resource consumption
- Inspect network connections and listening ports
- Monitor Docker containers and images
- Access system logs via journalctl (Linux)
Perfect for system diagnostics, performance troubleshooting, DevOps automation, and infrastructure monitoring.
Features
Available Tools
-
get_system_resources - Real-time system resource monitoring
- CPU usage, cores, and load
- Memory usage and swap statistics
- Disk usage and filesystem info
- System uptime and OS details
-
list_processes - Process monitoring and analysis
- Top processes by CPU or memory usage
- Process state and resource consumption
- Command line and user information
- Sortable and filterable results
-
get_network_connections - Network connection analysis
- Active network connections
- Listening ports and services
- Connection states (ESTABLISHED, LISTEN, etc.)
- Process-to-port mapping
-
get_docker_status - Docker container monitoring
- Running and stopped containers
- Container status and health
- Image inventory
- Port mappings and resource usage
-
get_system_logs - System log analysis (Linux only)
- Recent journalctl entries
- Filterable by priority level
- Filterable by systemd unit
- Structured log output
Installation
cd mcp-system-monitor
npm install
npm run build
Configuration
Claude Code Configuration
Add to your Claude Code MCP settings (~/Library/Application Support/Claude/claude_desktop_config.json on macOS):
{
"mcpServers": {
"system-monitor": {
"command": "node",
"args": ["/absolute/path/to/mcp-system-monitor/dist/index.js"]
}
}
}
Permissions
Some features require elevated permissions:
- Docker status: User must be in the
dockergroup - System logs: May require sudo access to journalctl (depending on system configuration)
- Process details: Full process info may require elevated privileges
Example Usage with Claude Code
Once configured, you can ask Claude:
"What's my current CPU and memory usage?"
"Show me the top 10 processes by CPU usage"
"List all listening ports and which processes are using them"
"What Docker containers are running right now?"
"Show me the last 100 error-level system logs"
"Which process is using port 8080?"
"Is my disk usage getting high?"
Platform Support
- CPU/Memory/Disk/Processes: All platforms (Linux, macOS, Windows)
- Network connections: All platforms
- Docker status: Requires Docker installation
- System logs: Linux only (requires systemd/journalctl)
Gracefully degrades on platforms where features aren't available.
Development
# Watch mode for development
npm run dev
# Build for production
npm run build
# Start the server
npm start
Security Considerations
This server provides read-only access to system information. It does not:
- Modify system configuration
- Kill or start processes
- Change permissions
- Execute arbitrary commands
However, it does expose system information including:
- Running processes and their arguments
- Network connections
- System logs
Only use in trusted environments and be mindful of what information you share.
Error Handling
The server includes comprehensive error handling for:
- Missing system utilities (docker, journalctl)
- Permission denied errors
- Platform-specific features
- Malformed data
- Schema validation errors
Features that aren't available will return clear messages instead of errors.
Tech Stack
- TypeScript for type safety
- @modelcontextprotocol/sdk for MCP protocol
- systeminformation for cross-platform system metrics
- Zod for runtime schema validation
- Native child_process for Docker and journalctl integration
Use Cases
- DevOps: Automated system health checks
- Troubleshooting: Quick diagnostics without leaving Claude
- Monitoring: Resource usage tracking and alerting
- Documentation: Generate system reports and inventories
- Development: Debug resource leaks and performance issues
License
MIT
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.