Python MCP Custom Server

Python MCP Custom Server

Extends Claude Desktop with custom tools for file management, system operations, and command execution. Supports creating/reading/deleting files, directory listing, system information retrieval, and file searching capabilities.

Category
访问服务器

README

# 🐍 Servidor MCP Personalizado en Python

Un servidor MCP (Model Context Protocol) completo desarrollado en Python que extiende las capacidades de Claude Desktop con herramientas personalizadas para gestión de archivos, sistema operativo y más.

## 📖 Sobre este Proyecto

Este proyecto nació de mi curiosidad por explorar el Model Context Protocol y crear herramientas personalizadas que hicieran a Claude más útil en mi flujo de trabajo diario. Después de investigar la documentación oficial y experimentar con diferentes enfoques, logré implementar un servidor robusto con múltiples funcionalidades.

Lo que comenzó como un simple script para crear archivos se convirtió en un conjunto completo de herramientas que utilizo regularmente. He documentado todo el proceso aquí para que otros puedan aprender y construir sobre este trabajo.

## ✨ Características

-**Gestión de Archivos**: Crear, leer, eliminar y buscar archivos
- 📁 **Organización**: Crear carpetas y listar directorios
- 💻 **Info del Sistema**: Obtener detalles del hardware y SO
- ⚙️ **Ejecución de Comandos**: Ejecutar comandos de terminal de forma segura
- 📊 **Análisis de Archivos**: Obtener tamaños y estadísticas
- 🔍 **Búsqueda Avanzada**: Buscar archivos por patrones

## 🛠️ Stack Tecnológico

- **Python 3.10+**: Lenguaje principal
- **MCP SDK**: Framework para el servidor
- **VS Code**: Entorno de desarrollo
- **Claude Desktop**: Cliente para las herramientas
- **psutil**: Información del sistema
- **aiofiles**: Operaciones de archivos asíncronas

## 📋 Requisitos Previos

Antes de comenzar, asegúrate de tener instalado:

- Python 3.10 o superior
- pip (gestor de paquetes de Python)
- VS Code (opcional, pero recomendado)
- Claude Desktop

## 🚀 Instalación

### 1. Clonar o Descargar el Proyecto

```bash
git clone https://github.com/tu-usuario/MCP.git
cd MCP/servidor-mcp-python
```

### 2. Crear Entorno Virtual

Es importante trabajar con un entorno virtual para evitar conflictos de dependencias:

```bash
# Crear el entorno virtual
python -m venv venv

# Activar el entorno virtual
# En Windows:
venv\Scripts\activate

# En macOS/Linux:
source venv/bin/activate
```

Deberías ver `(venv)` al inicio de tu línea de comandos.

### 3. Instalar Dependencias

```bash
pip install -r requirements.txt
```

### 4. Verificar la Instalación

Prueba que el servidor arranca correctamente:

```bash
python src/server.py
```

Si ves el mensaje "🚀 Servidor MCP Python iniciado correctamente", ¡todo está listo!

Presiona `Ctrl+C` para detener el servidor.

## ⚙️ Configuración con Claude Desktop

Para que Claude Desktop pueda usar este servidor, necesitas editar su archivo de configuración.

### Paso 1: Abrir el Directorio de Configuración

1. Presiona `Windows + R`
2. Pega esto: `%APPDATA%\Claude`
3. Presiona Enter

### Paso 2: Editar el Archivo de Configuración

Abre el archivo `claude_desktop_config.json` con tu editor de texto favorito (yo uso VS Code).

### Paso 3: Añadir la Configuración del Servidor

Añade esta configuración (ajusta las rutas según tu instalación):

```json
{
	"mcpServers": {
		"mi-servidor-python": {
			"command": "C:\\ruta\\al\\proyecto\\venv\\Scripts\\python.exe",
			"args": [
				"C:\\ruta\\al\\proyecto\\src\\server.py"
			]
		}
	}
}
```

**Nota:** Reemplaza `C:\\ruta\\al\\proyecto` con la ruta absoluta donde hayas clonado este repositorio.

### Paso 4: Reiniciar Claude Desktop

1. Cierra completamente Claude Desktop
2. Vuelve a abrirlo
3. Abre una conversación nueva

## 🎯 Uso

Una vez configurado, puedes usar las herramientas directamente en Claude Desktop:

### Ejemplos de Uso

```
Crea un archivo en mi escritorio llamado "notas.txt" con el contenido "Lista de tareas: ..."
```

```
Lista todos los archivos en mi escritorio
```

```
Dame información sobre mi sistema operativo
```

```
Busca todos los archivos .py en mi carpeta de documentos
```

## 🔧 Herramientas Disponibles

| Herramienta | Descripción |
|-------------|-------------|
| `crear_archivo_escritorio` | Crea archivos de texto en el escritorio |
| `leer_archivo` | Lee el contenido de cualquier archivo |
| `listar_archivos` | Lista el contenido de un directorio |
| `eliminar_archivo` | Elimina archivos del sistema |
| `crear_carpeta` | Crea nuevas carpetas |
| `info_sistema` | Muestra información del hardware y SO |
| `ejecutar_comando` | Ejecuta comandos de terminal |
| `buscar_archivos` | Busca archivos por patrón |
| `obtener_tamano_archivo` | Obtiene el tamaño de archivos |

## 📁 Estructura del Proyecto

```
servidor-mcp-python/
├── venv/                    # Entorno virtual (no incluido en Git)
├── src/
│   └── server.py           # Código principal del servidor
├── requirements.txt         # Dependencias del proyecto
├── README.md               # Este archivo
└── .gitignore              # Archivos ignorados por Git
```

## 🐛 Solución de Problemas

### El servidor no arranca

**Problema:** Al ejecutar `python src/server.py` no pasa nada o da error.

**Solución:** 
- Verifica que el entorno virtual esté activado (debes ver `(venv)`)
- Reinstala las dependencias: `pip install -r requirements.txt`

### Claude no ve las herramientas

**Problema:** Claude Desktop no muestra las herramientas del servidor.

**Solución:**
- Verifica que las rutas en `claude_desktop_config.json` sean correctas
- Usa barras invertidas dobles `\\` en Windows
- Asegúrate de usar la ruta del Python del entorno virtual, no del sistema
- Reinicia Claude Desktop completamente

### Errores de permisos

**Problema:** El servidor no puede crear o modificar archivos.

**Solución:**
- Ejecuta Claude Desktop con permisos de administrador (solo si es necesario)
- Verifica que tengas permisos de escritura en los directorios que usas

## 🎓 Lo que Aprendí

Durante el desarrollo de este proyecto, enfrenté varios desafíos interesantes:

1. **Manejo de rutas en Windows**: Aprendí la importancia de usar `Path` de `pathlib` en lugar de concatenar strings para rutas.

2. **Programación asíncrona**: Fue mi primera vez trabajando seriamente con `async/await` en Python. La curva de aprendizaje fue empinada, pero valió la pena.

3. **Seguridad**: Implementar la herramienta de ejecución de comandos me hizo consciente de los riesgos de seguridad. Añadí timeouts y validaciones para mitigar problemas.

4. **Debugging de servidores MCP**: Los logs de Claude Desktop fueron cruciales. Aprendí a usar `sys.stderr` para debug sin interferir con el protocolo.

## 🔮 Futuras Mejoras

Tengo varias ideas para expandir este proyecto:

- [ ] Integración con bases de datos (SQLite, PostgreSQL)
- [ ] Soporte para operaciones con imágenes
- [ ] Herramientas para trabajar con APIs REST
- [ ] Análisis de datos con pandas
- [ ] Sistema de plugins para añadir herramientas fácilmente
- [ ] Tests unitarios completos

## 📚 Recursos que Usé

- [Documentación oficial de MCP](https://modelcontextprotocol.io)
- [Python SDK de MCP](https://github.com/modelcontextprotocol/python-sdk)
- [Documentación de asyncio](https://docs.python.org/3/library/asyncio.html)
- [Claude Desktop Docs](https://support.claude.com)

## 🤝 Contribuciones

Este es un proyecto personal de aprendizaje, pero si encuentras bugs o tienes sugerencias, ¡son bienvenidas! Abre un issue o envía un pull request.

## 📝 Licencia

Este proyecto está bajo la Licencia MIT. Siéntete libre de usarlo, modificarlo y distribuirlo.

## 👤 Autor

Desarrollado con ☕ y mucha experimentación.

Si este proyecto te fue útil, considera darle una ⭐ en GitHub.

---

**Nota:** Este README asume conocimientos básicos de Python y línea de comandos. Si encuentras algo confuso, no dudes en abrir un issue para que pueda mejorar la documentación.

推荐服务器

Baidu Map

Baidu Map

百度地图核心API现已全面兼容MCP协议,是国内首家兼容MCP协议的地图服务商。

官方
精选
JavaScript
Playwright MCP Server

Playwright MCP Server

一个模型上下文协议服务器,它使大型语言模型能够通过结构化的可访问性快照与网页进行交互,而无需视觉模型或屏幕截图。

官方
精选
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

一个由人工智能驱动的工具,可以从自然语言描述生成现代化的用户界面组件,并与流行的集成开发环境(IDE)集成,从而简化用户界面开发流程。

官方
精选
本地
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

通过模型上下文协议启用与 Audiense Insights 账户的交互,从而促进营销洞察和受众数据的提取和分析,包括人口统计信息、行为和影响者互动。

官方
精选
本地
TypeScript
VeyraX

VeyraX

一个单一的 MCP 工具,连接你所有喜爱的工具:Gmail、日历以及其他 40 多个工具。

官方
精选
本地
graphlit-mcp-server

graphlit-mcp-server

模型上下文协议 (MCP) 服务器实现了 MCP 客户端与 Graphlit 服务之间的集成。 除了网络爬取之外,还可以将任何内容(从 Slack 到 Gmail 再到播客订阅源)导入到 Graphlit 项目中,然后从 MCP 客户端检索相关内容。

官方
精选
TypeScript
Kagi MCP Server

Kagi MCP Server

一个 MCP 服务器,集成了 Kagi 搜索功能和 Claude AI,使 Claude 能够在回答需要最新信息的问题时执行实时网络搜索。

官方
精选
Python
e2b-mcp-server

e2b-mcp-server

使用 MCP 通过 e2b 运行代码。

官方
精选
Neon MCP Server

Neon MCP Server

用于与 Neon 管理 API 和数据库交互的 MCP 服务器

官方
精选
Exa MCP Server

Exa MCP Server

模型上下文协议(MCP)服务器允许像 Claude 这样的 AI 助手使用 Exa AI 搜索 API 进行网络搜索。这种设置允许 AI 模型以安全和受控的方式获取实时的网络信息。

官方
精选