MCP Server Boilerplate
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@MCP Server BoilerplateAdd an echo tool to the server"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
MCP Server Boilerplate
A minimal, well-documented MCP (Model Context Protocol) server implementation designed to serve as a reusable baseline for building custom MCP servers.
What is MCP?
The Model Context Protocol (MCP) is a standardized protocol that enables AI assistants to interact with external servers. MCP servers can provide:
Tools: Functions that the AI can call to perform actions
Resources: Static or dynamic data that the AI can read
Prompts: Reusable prompt templates for consistent AI interactions
Features
This boilerplate provides:
Minimal structure: Clean baseline that can be easily extended
Extensive documentation: Inline comments and separate documentation files
Architecture diagrams: Mermaid diagrams showing component interactions
Scaling guide: Best practices for growing your server
Type hints: Full type annotations for better IDE support
Async/await: Non-blocking I/O for concurrent operations
Reusable Prompt Templates
Prompts are reusable prompt templates that allow you to define structured prompts with placeholders. They enable:
Consistency: Standardized prompt formats across different AI interactions
Parameterization: Dynamic content insertion through arguments
Reusability: Define once, use multiple times with different inputs
Type safety: Defined argument schemas with validation
A prompt template consists of:
Name: Unique identifier for the prompt
Description: What the prompt does
Arguments: Optional parameters that can be filled in when using the prompt
Example use cases:
Code review templates with configurable severity levels
Documentation generation with customizable tone
Analysis prompts with variable focus areas
Report generation with different output formats
Project Structure
windsurf-project-3/
├── mcp_server.py # Main server implementation with extensive comments
├── pyproject.toml # Project configuration for uv
├── ARCHITECTURE.md # Architecture documentation with Mermaid diagrams
├── SCALING_GUIDE.md # Scaling patterns and best practices
├── README.md # This file
├── tools/ # Placeholder for tool modules (create as needed)
├── resources/ # Placeholder for resource modules (create as needed)
├── prompts/ # Placeholder for prompt modules (create as needed)
└── utils/ # Placeholder for utility modules (create as needed)Installation
This project uses uv for fast Python package management.
Install Python 3.10 or higher
Install uv (if not already installed):
curl -LsSf https://astral.sh/uv/install.sh | shInstall dependencies:
uv syncFor SSE (remote HTTP) transport support:
uv sync --extra sseThis installs FastAPI, uvicorn, and SSE-related dependencies for remote deployment.
Transport Modes
This boilerplate supports two transport modes for MCP communication:
stdio Mode (Default)
Use case: Local development, CLI tools, desktop applications
How it works: Server runs as a subprocess, communicates via stdin/stdout
Configuration: Default mode, no configuration needed
Client setup: Configure MCP client to run the server as a command
# Run in stdio mode (default)
uv run python mcp_server.pySSE Mode (Server-Sent Events)
Use case: Web clients, remote deployment, production scenarios
How it works: HTTP server with SSE for streaming responses
Configuration: Set
MCP_TRANSPORT=sseenvironment variableClient setup: Configure MCP client with HTTP endpoint URL
# Install SSE dependencies
uv sync --extra sse
# Run in SSE mode
MCP_TRANSPORT=sse uv run python mcp_server.pySSE Configuration:
MCP_TRANSPORT=sse- Enable SSE transportMCP_HOST=0.0.0.0- Host to bind to (default: 0.0.0.0)MCP_PORT=8000- Port to listen on (default: 8000)
SSE Endpoints:
GET /sse- SSE endpoint for event streamingPOST /messages- POST endpoint for client requestsGET /health- Health check endpoint
Quick Start
1. Add Your First Tool
Edit mcp_server.py and add a tool in the list_tools() function:
@app.list_tools()
async def list_tools() -> list[Tool]:
return [
Tool(
name="echo",
description="Echo back the input text",
inputSchema={
"type": "object",
"properties": {
"text": {"type": "string", "description": "Text to echo"}
},
"required": ["text"]
}
)
]2. Implement the Tool Handler
Add the tool logic in the call_tool() function:
@app.call_tool()
async def call_tool(name: str, arguments: Any) -> str:
if name == "echo":
text = arguments.get("text", "")
return f"Echo: {text}"
raise ValueError(f"Unknown tool: {name}")3. Add a Prompt (Optional)
Add a prompt in the list_prompts() function:
@app.list_prompts()
async def list_prompts() -> list[Prompt]:
return [
Prompt(
name="example_prompt",
description="An example prompt template",
arguments=[
PromptArgument(
name="topic",
description="The topic to write about",
required=True
)
]
)
]Then implement the handler in get_prompt():
@app.get_prompt()
async def get_prompt(name: str, arguments: dict[str, str] | None) -> str:
if name == "example_prompt":
topic = arguments.get("topic") if arguments else None
if not topic:
raise ValueError("Argument 'topic' is required")
return f"Write a detailed explanation about {topic}."
raise ValueError(f"Unknown prompt: {name}")3. Run the Server
uv run python mcp_server.py4. Configure Your MCP Client
For stdio mode (local):
Add this to your MCP client's configuration:
{
"mcpServers": {
"your-server-name": {
"command": "uv",
"args": ["run", "python", "/path/to/mcp_server.py"]
}
}
}For SSE mode (remote):
Add this to your MCP client's configuration:
{
"mcpServers": {
"your-server-name": {
"url": "http://localhost:8000/sse",
"transport": "sse"
}
}
}For production deployment, replace http://localhost:8000 with your actual server URL.
Documentation
ARCHITECTURE.md: Detailed architecture documentation with Mermaid diagrams showing:
Python modules and their purposes
Component interactions
Request flows (tool invocation, resource reading, prompt retrieval)
Transport modes (stdio and SSE)
Design patterns used
SCALING_GUIDE.md: Best practices for scaling your server:
Modularization patterns
State management strategies
Error handling patterns
Logging and monitoring
Configuration management
Testing strategies
Performance optimization
Security considerations
SSE deployment guidance
Production Deployment
SSE Mode Deployment
For production deployment using SSE transport:
Install SSE dependencies:
uv sync --extra sseConfigure environment variables:
export MCP_TRANSPORT=sse
export MCP_HOST=0.0.0.0
export MCP_PORT=8000Run with a production ASGI server:
uv run uvicorn mcp_server:web_app --host 0.0.0.0 --port 8000 --workers 4Containerization (Docker):
FROM python:3.10-slim
WORKDIR /app
COPY . .
RUN pip install uv && uv sync --extra sse
ENV MCP_TRANSPORT=sse
ENV MCP_HOST=0.0.0.0
ENV MCP_PORT=8000
CMD ["uv", "run", "uvicorn", "mcp_server:web_app", "--host", "0.0.0.0", "--port", "8000"]Health checks:
The server provides a
/healthendpoint for monitoringReturns server status and active session count
Use for container orchestration (Kubernetes, Docker health checks)
Security Considerations for Production
Authentication: Add authentication middleware to FastAPI app
CORS: Configure CORS for web client access
Rate limiting: Implement rate limiting to prevent abuse
TLS: Use reverse proxy (nginx, traefik) for HTTPS termination
Secrets: Use environment variables or secret management for API keys
See SCALING_GUIDE.md for detailed security patterns.
Code Structure
The main server file (mcp_server.py) is organized into sections:
Server Initialization: Create the MCP server instance
Tool Registration: Define available tools
Tool Handlers: Implement tool execution logic
Resource Registration: Define available resources
Resource Handlers: Implement resource reading logic
Entry Point: Start the server with stdio communication
Each section includes extensive inline comments explaining the purpose and usage of each component.
Extension Points
Adding Tools
Define the tool in
list_tools()with its schemaImplement the handler in
call_tool()For larger projects, move to separate module in
tools/directory
Adding Prompts
Define the prompt in
list_prompts()with its argumentsImplement the handler in
get_prompt()For larger projects, move to separate module in
prompts/directory
Adding Resources
Define the resource in
list_resources()with its metadataImplement the handler in
read_resource()For larger projects, move to separate module in
resources/directory
Adding Utilities
Extract shared code into the utils/ directory:
Validation functions
Logging helpers
Configuration management
Error handling utilities
Using as a Baseline
This boilerplate is designed to be copied and modified for new projects:
Copy the entire project directory
Rename the project in
pyproject.tomlUpdate the server name in
mcp_server.pyAdd your tools, resources, and prompts
Customize documentation as needed
Python Modules Used
mcp.server.Server: Main MCP server classmcp.types.Tool: Tool type definitionmcp.types.Resource: Resource type definitionmcp.types.Prompt: Prompt type definitionmcp.types.PromptArgument: Prompt argument type definitionmcp.server.stdio: Stdio communication streamsasyncio: Async/await for concurrent operationstyping: Type hints for code clarity
See ARCHITECTURE.md for detailed explanations of each module.
Development
Running Tests
# Run with pytest (add tests first)
uv run pytestCode Style
This project uses Python type hints and follows PEP 8 conventions. Consider using:
rufffor lintingmypyfor type checking
Adding Dependencies
uv add <package-name>Troubleshooting
Import error: Run
uv syncto install dependenciesServer not responding: Check MCP client configuration
Type errors: Ensure Python 3.10+ is installed
uv command not found: Install uv from https://github.com/astral-sh/uv
Resources
License
This boilerplate is provided as-is for educational and development purposes. Feel free to use and modify it for your projects.
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
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/GlenTrudgett/mcp_template'
If you have feedback or need assistance with the MCP directory API, please join our Discord server