Incident Agent
A Python FastMCP server for incident management and analysis, providing tools for greeting, echo, and server information retrieval.
README
Incident Agent
A Python FastMCP (Model Context Protocol) server for incident management and analysis.
This project provides a complete MCP server implementation with tools for greeting, echo functionality, and server information retrieval. It demonstrates the FastMCP framework capabilities and serves as a foundation for building more complex incident management tools.
Prerequisites
- Python 3.13+
- uv package manager
Setup
-
Clone the repository
git clone https://github.com/JayLiuMLP/incident-agent.git cd incident-agent -
Install dependencies
uv sync -
Verify installation
uv run python -c "import fastmcp; print('FastMCP installed successfully!')"
MCP Server Usage
Available Tools
The server provides the following MCP tools:
- hello - Greet a person or the world
- echo - Echo back a message
- server_info - Get server information and status
Available Resources
- config://server/info - Server configuration information
Starting the MCP Server
-
Standard MCP Server (stdio transport)
uv run fastmcp run main.py -
HTTP Server (for API access)
uv run fastmcp run main.py --transport http --port 8000 -
Inspect Server Configuration
uv run fastmcp inspect main.py
Testing the MCP Server
Method 1: Python Client (Recommended)
Use the built-in Python client utilities for easy testing:
# Run complete test suite (recommended)
uv run python mcp_client_utils.py
# Run comprehensive HTTP client test
uv run python http_client_test.py
Method 2: Using in Your Python Code
import asyncio
from mcp_client_utils import MCPClient, say_hello, echo_message
# Using utility functions
async def example():
greeting = await say_hello("Developer")
echo_result = await echo_message("Test message")
print(f"Greeting: {greeting}")
print(f"Echo: {echo_result}")
# Using client class
async def advanced_example():
client = MCPClient("http://localhost:8000/mcp")
tools = await client.list_tools()
server_info = await client.get_server_info()
print(f"Available tools: {tools}")
print(f"Server version: {server_info['version']}")
# Run the examples
asyncio.run(example())
asyncio.run(advanced_example())
Method 3: Integration with MCP Clients
The server can be integrated with MCP-compatible clients like Claude Desktop by adding to your configuration:
{
"mcpServers": {
"incident-agent": {
"command": "uv",
"args": ["run", "fastmcp", "run", "main.py"],
"cwd": "/path/to/incident-agent"
}
}
}
Method 4: HTTP API (curl)
ā ļø Note: HTTP API requires proper session management and is more complex. Python client is recommended.
For advanced users, you can use curl with the HTTP server:
# Start HTTP server first
uv run fastmcp run main.py --transport http --port 8000
# Test with Python client (much easier)
uv run python mcp_client_utils.py
Server Output Example
When running the test client, you should see:
š MCP Client Tools Demo
Hello: Hello, Developer! š Welcome to the Incident Agent MCP Server!
Echo: Echo: This is a test message
Server status: running
Server version: 0.1.0
Available tools: ['hello', 'echo', 'server_info']
Development
-
Run the application
uv run python main.py -
Run tests
uv run pytest -
Setup pre-commit hooks
uv run pre-commit install -
Test MCP functionality
# Quick test uv run python mcp_client_utils.py
Quick Start
Want to test the MCP server right away? Follow these steps:
-
Install and setup (if not done already)
git clone https://github.com/JayLiuMLP/incident-agent.git cd incident-agent uv sync -
Start the HTTP server (in one terminal)
uv run fastmcp run main.py --transport http --port 8000 -
Test with Python client (in another terminal)
uv run python mcp_client_utils.py -
Expected output
š MCP Client Tools Demo Hello: Hello, Developer! š Welcome to the Incident Agent MCP Server! Echo: Echo: This is a test message Server status: running Server version: 0.1.0 Available tools: ['hello', 'echo', 'server_info']
That's it! Your MCP server is working. š
Project Structure
incident-agent/
āāā main.py # Main MCP server entry point
āāā run_server.py # Server demo script
āāā mcp_client_utils.py # Primary Python client for testing (RECOMMENDED)
āāā simple_client.py # Simple Python client example
āāā http_client_test.py # Comprehensive HTTP client test
āāā PYTHON_CLIENT_GUIDE.md # Detailed Python client usage guide
āāā HELLO_WORLD_MCP.md # MCP server documentation
āāā pyproject.toml # Project configuration and dependencies
āāā .cursorrules # Development guidelines and best practices
āāā src/incident_agent/ # Main application source
āāā __init__.py # Package initialization
āāā server/ # MCP server implementation
ā āāā __init__.py
ā āāā server.py # FastMCP server definition
āāā tools/ # MCP tools implementation
āāā __init__.py
āāā hello_tools.py # Hello world tools
Key Files
main.py- MCP server entry point, use withfastmcp runmcp_client_utils.py- RECOMMENDED Python client with utility functions and classes for testingsimple_client.py- Minimal client example for referencesrc/incident_agent/server/server.py- Core server implementationsrc/incident_agent/tools/hello_tools.py- Tool implementations
Troubleshooting
Common Issues
-
"Failed to connect to localhost" error
- Make sure the server is running:
uv run fastmcp run main.py --transport http --port 8000 - Check if port 8000 is available:
lsof -i :8000
- Make sure the server is running:
-
curl requests don't work
- Use Python client instead (recommended):
uv run python mcp_client_utils.py - HTTP API with curl requires complex session management
- Use Python client instead (recommended):
-
"No such file or directory" error
- Make sure you're in the project directory
- Run
uv syncto install dependencies
-
Import errors
- Ensure virtual environment is activated by using
uv runprefix - Check that FastMCP is installed:
uv run python -c "import fastmcp; print('OK')"
- Ensure virtual environment is activated by using
Getting Help
- Check
PYTHON_CLIENT_GUIDE.mdfor detailed client usage - Check
HELLO_WORLD_MCP.mdfor server implementation details - See
.cursorrulesfor development guidelines
Contributing
This project follows FastMCP development best practices. See .cursorrules for detailed development guidelines.
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.