mcp-server-python
A Python MCP server providing AI agents with tools for local knowledge base search, business context retrieval, and text summarization prompt generation.
README
mcp-server-python
MCP server em Python com tools customizadas para agentes IA — knowledge base local, contexto de negócio e sumarização de texto.
O que é MCP?
MCP (Model Context Protocol) é um protocolo aberto criado pela Anthropic que permite que agentes IA (como o Claude) se conectem a servidores externos para acessar dados, executar ações e usar ferramentas customizadas.
Com um MCP server, você pode:
- Dar ao Claude acesso à sua base de conhecimento interna
- Expor dados de negócio sem precisar colocá-los no prompt manualmente
- Criar pipelines de processamento de texto reutilizáveis
- Integrar qualquer sistema externo como uma "tool" para o agente
Este servidor expõe 3 tools prontas:
| Tool | O que faz |
|---|---|
search_knowledge_base |
Busca documentos relevantes numa SQLite local via cosine similarity |
summarize_text |
Formata um prompt de sumarização (sem chamar API — retorna o prompt pronto) |
get_business_context |
Retorna contexto de negócio de um JSON local |
Instalação
Pré-requisitos
- Python 3.12+
- pip
Passos
# Clone o repositório
git clone https://github.com/dimitrearaujo/mcp-server-python.git
cd mcp-server-python
# Crie e ative o ambiente virtual
python -m venv .venv
source .venv/bin/activate # Linux/Mac
# ou
.venv\Scripts\activate # Windows
# Instale as dependências
pip install -r requirements.txt
# Configure as variáveis de ambiente
cp .env.example .env
# Edite o .env conforme necessário
Configuração
Edite o arquivo .env:
BUSINESS_CONTEXT_PATH=./business_context.json
KB_DATABASE_PATH=./data/knowledge_base.db
KB_MAX_RESULTS=5
Edite o business_context.json com os dados da sua empresa.
Como rodar
python server.py
O servidor inicia via stdio e aguarda chamadas de tools. A saída de log vai para stderr.
Integração com Claude Desktop
Adicione ao seu claude_desktop_config.json:
{
"mcpServers": {
"mcp-server-python": {
"command": "python",
"args": ["/caminho/para/mcp-server-python/server.py"],
"env": {
"BUSINESS_CONTEXT_PATH": "/caminho/para/mcp-server-python/business_context.json",
"KB_DATABASE_PATH": "/caminho/para/mcp-server-python/data/knowledge_base.db"
}
}
}
}
Localização do arquivo de configuração:
- macOS:
~/Library/Application Support/Claude/claude_desktop_config.json - Windows:
%APPDATA%\Claude\claude_desktop_config.json - Linux:
~/.config/Claude/claude_desktop_config.json
Após reiniciar o Claude Desktop, as tools aparecerão disponíveis no chat.
Populando a Knowledge Base
Use o Python interativo ou um script para inserir documentos:
from mcp_server.knowledge_base import KnowledgeBase
kb = KnowledgeBase(db_path="./data/knowledge_base.db")
# Inserir documentos
kb.insert(
title="Política de Atendimento",
content="Atendemos de segunda a sexta, das 8h às 18h. Urgências via WhatsApp.",
category="atendimento"
)
kb.insert(
title="Tabela de Preços",
content="Consulta simples: R$ 150. Consulta especializada: R$ 250. Retorno em 30 dias: gratuito.",
category="precos"
)
# Buscar
results = kb.search("qual o preço da consulta?")
for r in results:
print(f"[{r['score']:.2f}] {r['title']}: {r['content'][:80]}...")
Como adicionar novas tools
- Defina a tool em
mcp_server/tools.py, adicionando um item aTOOL_DEFINITIONS:
{
"name": "minha_nova_tool",
"description": "Descrição clara do que a tool faz.",
"input_schema": {
"type": "object",
"properties": {
"parametro": {"type": "string", "description": "..."},
},
"required": ["parametro"],
},
}
- Implemente o handler assíncrono:
async def handle_minha_nova_tool(arguments: Dict[str, Any]) -> List[TextContent]:
resultado = faz_algo(arguments["parametro"])
return [TextContent(type="text", text=json.dumps(resultado, ensure_ascii=False))]
- Registre o handler no dicionário
TOOL_HANDLERS:
TOOL_HANDLERS = {
# ... tools existentes ...
"minha_nova_tool": handle_minha_nova_tool,
}
- Pronto. A tool já aparece automaticamente via
list_tools.
Estrutura do projeto
mcp-server-python/
├── .env.example # Variáveis de ambiente necessárias
├── .gitignore
├── .github/workflows/ci.yml # CI: syntax check + unit tests
├── README.md
├── requirements.txt
├── server.py # Entry point — inicia o MCP server via stdio
├── mcp_server/
│ ├── __init__.py
│ ├── tools.py # Definição e registro das 3 tools
│ ├── knowledge_base.py # SQLite + busca vetorial TF cosine
│ ├── context.py # Carrega business_context.json
│ └── prompts.py # Templates de prompt
├── business_context.json # Contexto de negócio (edite com seus dados)
└── data/ # Pasta para arquivos da KB (SQLite)
└── .gitkeep
Tecnologias
- MCP SDK — protocolo de comunicação com agentes IA
- SQLite — armazenamento local da knowledge base (sem servidor externo)
- TF Cosine Similarity — busca vetorial simples sem embeddings externos
- python-dotenv — gerenciamento de variáveis de ambiente
Desenvolvido por
CD Tech — Automação e Agentes IA para Pequenos Negócios
Fortaleza, CE — Brasil
cd-tech-lp.pages.dev
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.