Skip to main content
Glama

PsUtil MCP Server

by BenedatLLC
Apache 2.0
2

Agent with MCP Example

This project provides a simple example of an Agent and a local MCP server.

The MCP Server provides a collection of tools for obtaining system CPU and memory statistics. It is built on the psutil library. The tools are implemented as FastAPI enpoints and then exposed via MCP using fastapi-mcp.

The Agent is part of a simple Gradio chat application. The agent uses the Pydantic.ai agent framework. The agent is provided the MCP Server's URL and a system prompt indicating that it should answer system resource usage. The Gradio Chat component maintains a conversation history so that you can ask follow-up questions.

Setup

Prerequisites

First make sure you have the following tools installed on your machine:

  1. uv, a package and environment manager for Python
  2. direnv, a tool for managing environment variables in your projects
  3. mcptools (optional), a command line utility for interacting with MCP servers. This program is only needed if you want to test/debug the MCP server without the chat application. It is really helpful for debugging your tools and making sure that the expected metadata is being published by the MCP server. Note that the name of the program is mcpt if you install via Homebrew on Mac and mcptools otherwise.
  4. These examples use OpenAI models for the Agent, so you will need an actve account and key from here. Alternatively, you can use one of the other models supported by Pydantic.ai. In that case, you will have to set the model and key appropriately.

Setup steps

Once you have the prerequisites installed, do the following steps:

  1. Copy envrc.template to .envrc and edit the value of OPENAI_API_KEY to your Open AI token.
  2. Run direnv allow to put the changed environment variables into your environment.
  3. Run uv sync to create/update your virtual environment.
  4. You can start the MCP Server with uv run psutil_mcp.py. By default it will server on port 8000.

Testing

If you have installed mcptools, you can connect to your MCP server and test it as follows:

$ mcptools shell http://localhost:8000/mcp # use the command "mcpt" if you installed via Homebrew mcp> tools cpu_times Get Cpu Times Return system CPU time as a total across all cpus. Every attribute represents the ... mcp> call cpu_times { "user": 119528.44, "nice": 0.0, "system": 67114.2, "idle": 2692773.55 } mcp> exit

Running

To run the full application:

  1. If you have not already stared your MCP Server, you can run it as uv run psutil_mcp.py
  2. In another terminal window, start the chat server with uv run chat.py
  3. Point your browser to http://127.0.0.1:7860

Extras

The psutil_mcp.py and chat.py programs have some command line options to enable debugging, change the model, change the ports, etc. Run them with the --help option to see the available options.

There is a configuration for VSCode to use the MCP server at .vscode/mcp.json

-
security - not tested
A
license - permissive license
-
quality - not tested

Provides tools for obtaining system CPU and memory statistics through FastAPI endpoints exposed via MCP.

  1. Setup
    1. Prerequisites
    2. Setup steps
    3. Testing
  2. Running
    1. Extras

      Related MCP Servers

      • A
        security
        A
        license
        A
        quality
        An MCP server providing access to college football statistics sourced from the College Football Data API within Claude Desktop.
        Last updated -
        9
        9
        Python
        MIT License
        • Apple
      • -
        security
        F
        license
        -
        quality
        Provides access to PyTorch CI/CD analytics data including workflows, jobs, test runs, and log analysis through an MCP interface.
        Last updated -
        Python
      • A
        security
        A
        license
        A
        quality
        MCP Server for the CoinStats API. Provides access to cryptocurrency market data, portfolio tracking, and news.
        Last updated -
        30
        17
        3
        TypeScript
        MIT License
      • A
        security
        F
        license
        A
        quality
        A FastMCP-based tool for monitoring server statistics that retrieves CPU, memory, and uptime information from both local and remote servers via SSH.
        Last updated -
        2
        9
        JavaScript

      View all related MCP servers

      MCP directory API

      We provide all the information about MCP servers via our MCP API.

      curl -X GET 'https://glama.ai/api/mcp/v1/servers/BenedatLLC/agent-with-mcp-example'

      If you have feedback or need assistance with the MCP directory API, please join our Discord server