🧠 Servidor MCP com Python – Tutorial Prático
ryanbrito
README
<!-- <div align="left" style="margin-top: -1%"> <a href="https://www.python.org/"> <image src="https://img.shields.io/badge/Python-FFD43B?style=for-the-badge&logo=python&logoColor=blue"> </a> <a href="https://modelcontextprotocol.io/introduction"> <image src="README/mcp-badge.png" width="140"> </a> <a href="https://openwebui.com"> <image src="README/open-web-ui-badge.png" width="120"> </a> </div> -->
🧠 Servidor MCP com Python – Tutorial Prático
Este repositório demonstra como criar um servidor MCP (Model Context Protocol) usando o SDK oficial da Microsoft em Python. O projeto mostra como definir ferramentas (@tool
) que podem ser consumidas por LLMs, como ChatGPT ou modelos em ambientes como o Open WebUI.
🚀 Tecnologias utilizadas
- Python 3.10+
- uv – gerenciamento de ambientes e pacotes
- mcp – SDK oficial MCP
- mcpo – Middleware HTTP + documentação OpenAPI
⚙️ Instalação
# 1. Crie o ambiente virtual com uv
uv venv .venv
source .venv/bin/activate
# 2. Instale o SDK MCP, CLI e mcpo
uv add mcp mcp[cli] mcpo
🧩 Estrutura do Projeto
📁 projeto/
├── main.py # Arquivo principal com o servidor MCP
├── README.md # Este arquivo
└── .venv/ # Ambiente virtual (não versionar)
🛠️ Exemplo de Código – main.py
from mcp.server.fastmcp import FastMCP
mcp = FastMCP("Tutorial MCP")
@mcp.tool()
def get_tutorial_summary():
"""
Returns the summary of an MCP Server Tutorial
:return: Um resumo textual sobre como construir um servidor MCP.
"""
return (
"Configure o ambiente com uv.\n"
"Instale com: uv add mcp mcp[cli] mcpo\n"
"Implemente funções com @tool\n"
"Execute com mcpo\n"
"Consuma via cliente MCP ou Open WebUI."
)
@mcp.tool()
def somar(a: int, b: int) -> int:
"""
Soma dois números inteiros e retorna o resultado.
:param a: O primeiro número.
:param b: O segundo número.
:return: O resultado da soma entre a e b.
"""
return a + b
if __name__ == "__main__":
mcp.run(transport="stdio") # Execução local
▶️ Como Executar
🔹 1. Modo Local (stdio)
.venv/bin/python main.py
ou
mcp run main.py # Para executar o servidor de forma padrão
mcp dev main.py # Para Testar o servidor em modo desenvolvedor
mcp install main.py # Para instalar localmente no Claude Desktop
Esse modo é ideal para testes locais com a CLI do MCP.
🔹 2. Modo HTTP com mcpo
para documentação OpenAPI e integração ao OpenWebUI
mcpo --port 8000 -- .venv/bin/python main.py
-
Acesse a documentação interativa em:
👉 http://localhost:8000/docs -
Agora o servidor está disponível como uma API RESTful.
🤖 Integração com Open WebUI
Após iniciar o servidor com mcpo
, você pode conectá-lo ao Open WebUI ou outras ferramentas LLM que suportam o protocolo MCP.
- Vá para sua instância Open WebUI
- Vá para configurações
- Clique em
Tools
- Insira a URL do novo servidor MCP:
http://localhost:8000
Para mais informações, clique aqui.
📘 Sobre docstrings nas funções
Cada @mcp.tool()
deve conter uma docstring clara e completa, pois:
- Aparece automaticamente na documentação OpenAPI.
- É usada pela IA para decidir qual função usar, com base na consulta/query do usuário a IA.
🔥 Docstrings bem escritas melhoram muito a usabilidade com LLMs.
📢 Contribuições
Pull requests são bem-vindos! Fique à vontade para sugerir novas tools, melhorar exemplos ou expandir o tutorial.
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.
MCP Package Docs Server
Facilitates LLMs to efficiently access and fetch structured documentation for packages in Go, Python, and NPM, enhancing software development with multi-language support and performance optimization.
Claude Code MCP
An implementation of Claude Code as a Model Context Protocol server that enables using Claude's software engineering capabilities (code generation, editing, reviewing, and file operations) through the standardized MCP interface.
@kazuph/mcp-taskmanager
Model Context Protocol server for Task Management. This allows Claude Desktop (or any MCP client) to manage and execute tasks in a queue-based system.
Linear MCP Server
Enables interaction with Linear's API for managing issues, teams, and projects programmatically through the Model Context Protocol.
mermaid-mcp-server
A Model Context Protocol (MCP) server that converts Mermaid diagrams to PNG images.
Jira-Context-MCP
MCP server to provide Jira Tickets information to AI coding agents like Cursor

Linear MCP Server
A Model Context Protocol server that integrates with Linear's issue tracking system, allowing LLMs to create, update, search, and comment on Linear issues through natural language interactions.

Sequential Thinking MCP Server
This server facilitates structured problem-solving by breaking down complex issues into sequential steps, supporting revisions, and enabling multiple solution paths through full MCP integration.