EasyPanel MCP Server
Enables full management of Docker infrastructure, including creating and updating services, managing isolated networks, and retrieving container logs.
Supports the deployment and configuration of Flask-based API services within the managed infrastructure.
Allows for automated deployment triggers and infrastructure updates directly from GitHub Actions workflows.
Integrates infrastructure management and service orchestration tools directly into n8n workflows.
Facilitates the deployment and management of PostgreSQL database services as part of application stacks.
Provides capabilities to deploy, monitor, and diagnose Redis cache services, including log analysis for connection troubleshooting.
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., "@EasyPanel MCP ServerDeploy a new Flask API service with a PostgreSQL database"
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.
EasyPanel MCP Server
Servidor de Model Context Protocol (MCP) para EasyPanel. Este conector permite a clientes de inteligencia artificial y entornos de automatización gestionar infraestructura, desplegar servicios, configurar redes y monitorear recursos mediante la API tRPC de EasyPanel en lenguaje natural.
Descripción General
Este servidor implementa el estándar abierto Model Context Protocol (MCP) desarrollado por Anthropic para ofrecer herramientas de DevOps automatizadas. Permite a agentes de IA interactuar directamente con tu instancia de EasyPanel de forma local y segura, automatizando tareas complejas de administración de servidores, despliegues y diagnósticos.
Características Principales
Gestión Completa de Servicios: Listado, inspección, creación, actualización, detención y reinicio de aplicaciones y bases de datos.
Manejo Inteligente de Recursos: Detección automática y ruteo de namespaces tRPC según el tipo de servicio (
app,postgres,redis,mysql,mongodb,mariadb).Auto-Scaling Automatizado: Escalado vertical de CPU y memoria basado en métricas y límites definidos.
Análisis y Debugging: Recuperación de logs estructurados e información de despliegue para auditoría y diagnóstico de fallos en tiempo real.
Descubrimiento de Redes: Análisis automático de topologías de comunicación interna y pública de Docker.
Soporte Multicliente: Diseñado tanto para transporte local de flujo estándar (
stdio) como para conexión remota vía Server-Sent Events (sse/http).
Related MCP server: Docker Manager MCP
Instalación y Configuración
1. Clonar el repositorio
git clone https://github.com/dannymaaz/easypanel-mcp
cd easypanel-mcp2. Configurar el entorno virtual e instalar
Recomendamos usar un entorno virtual para aislar las dependencias:
En Windows (PowerShell):
python -m venv venv
.\venv\Scripts\Activate.ps1
pip install -r requirements.txtEn macOS / Linux:
python3 -m venv venv
source venv/bin/activate
pip install -r requirements.txt3. Configurar variables de entorno
Crea un archivo .env en la raíz del proyecto basándote en el ejemplo provisto:
cp .env.example .envEdita el archivo .env configurando los accesos a tu EasyPanel:
# URL de acceso a tu instancia (ej. https://panel.tudominio.com)
EASYPANEL_URL=https://tu-easypanel.com
# Token de API o credenciales en formato email:password
EASYPANEL_API_KEY=tu_api_key_aqui
# Parámetros adicionales
EASYPANEL_TIMEOUT=30
EASYPANEL_VERIFY_SSL=true
# Configuración del servidor MCP
MCP_HOST=127.0.0.1
MCP_PORT=8080
MCP_LOG_LEVEL=INFOConfiguración en Clientes MCP
1. Antigravity IDE
Para integrar el servidor en Antigravity, añade la ruta del script en la configuración del gestor de plugins de MCP.
Asegúrate de apuntar al ejecutable de Python de tu entorno virtual (venv) para que localice las dependencias instaladas:
{
"mcpServers": {
"easypanel-mcp": {
"command": "C:\\ruta\\a\\easypanel-mcp\\venv\\Scripts\\python.exe",
"args": ["C:\\ruta\\a\\easypanel-mcp\\src\\server.py"],
"env": {
"EASYPANEL_URL": "https://tu-easypanel.com",
"EASYPANEL_API_KEY": "tu_api_key"
}
}
}
}2. Cursor / VS Code (Extensiones Cline & Roo Code)
En editores compatibles con OpenCode o extensiones de agentes inteligentes:
Abre el panel de configuración de la extensión (ej. en Roo Code, ve a Settings > MCP Servers).
Añade una nueva configuración de servidor:
Name:
easypanelType:
commandCommand:
python(o la ruta al ejecutable de tuvenv)Args:
["/ruta/absoluta/a/easypanel-mcp/src/server.py"]Environment Variables:
EASYPANEL_URL:https://tu-easypanel.comEASYPANEL_API_KEY:tu_api_key
3. Claude Desktop
Añade el servidor al archivo de configuración de Claude Desktop (claude_desktop_config.json):
En Windows: %APPDATA%\Claude\claude_desktop_config.json
En macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
{
"mcpServers": {
"easypanel-mcp": {
"command": "python",
"args": ["/ruta/absoluta/a/easypanel-mcp/src/server.py"],
"env": {
"EASYPANEL_URL": "https://tu-easypanel.com",
"EASYPANEL_API_KEY": "tu_api_key"
}
}
}
}4. n8n (Integración remota vía SSE)
Si deseas desplegarlo de forma dedicada como servicio remoto, inicia el servidor en modo HTTP:
python src/server.py httpEsto levantará el servidor en http://127.0.0.1:8080 utilizando Server-Sent Events (SSE). Puedes integrarlo en nodos HTTP de n8n o sistemas externos realizando peticiones estructuradas al endpoint de herramientas:
Endpoint:
http://localhost:8080/mcpFormato de petición:
{ "method": "tools/call", "params": { "name": "list_services", "arguments": { "project_id": "mi-proyecto" } } }
Ejemplos Prácticos de Uso
Una vez conectado, puedes interactuar directamente con tu agente haciéndole peticiones de infraestructura basadas en la vida real:
Despliegue de Aplicaciones
Usuario: "Despliega un servicio frontend usando la imagen nginx:alpine en el proyecto principal."
IA (Interno): Invocacreate_service(name="frontend", project_id="principal", image="nginx:alpine")y posteriormentedeploy_service.
IA (Respuesta): "He creado y desplegado el servicio 'frontend' exitosamente en tu proyecto. Está listo para recibir configuración de dominio."
Diagnóstico de Caídas
Usuario: "¿Por qué el servicio backend está fallando?"
IA (Interno): Invocaget_service_logs(service_id="backend").
IA (Respuesta): "El servicio backend reporta un estado 'crashed' debido al siguiente error en consola: 'ConnectionRefusedError: No se pudo establecer conexión con redis-cache en el puerto 6379'. ¿Deseas que verifique si el contenedor de Redis está detenido?"
Monitoreo y Escalado
Usuario: "Verifica las estadísticas del sistema y escala el servicio backend si el uso de CPU es alto."
IA (Interno): Invocaget_system_stats()seguido descale_service(service_id="backend", cpu=2, memory=4096).
Herramientas Disponibles
Categoría | Herramienta | Parámetros | Descripción |
Servicios |
|
| Lista todos los servicios y sus estados. |
|
| Obtiene la configuración detallada de un servicio. | |
|
| Crea un nuevo servicio (soporta apps y DBs). | |
|
| Modifica configuraciones de entorno, puertos y recursos. | |
|
| Remueve un servicio de EasyPanel. | |
|
| Reinicia de inmediato el contenedor de la aplicación. | |
|
| Obtiene los últimos logs de consola del contenedor. | |
Despliegues |
|
| Lista el historial de despliegues. |
|
| Lanza un nuevo despliegue actualizando la imagen. | |
Redes |
| - | Descubre la topología de red Docker pública/interna. |
Proyectos |
| - | Lista los proyectos creados en la instancia. |
|
| Crea un nuevo proyecto organizador. | |
Monitoreo |
| - | Obtiene estadísticas en tiempo real de CPU, RAM y disco. |
Escalado |
|
| Escala verticalmente los recursos asignados. |
|
| Escala dinámicamente según la carga actual. | |
Seguridad |
| - | Lista los dominios asignados en la instancia. |
| - | Obtiene la clave SSH pública para despliegues Git. |
Verificación del Entorno
Para verificar la conectividad de la API y el estado de la configuración sin arrancar el servidor MCP completo, puedes ejecutar la suite de pruebas unitarias:
python -m pytest tests/test_basic.py -vAutor
Licencia
Este proyecto está bajo la Licencia MIT. Consulta el archivo LICENSE para más detalles.
This server cannot be installed
Maintenance
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/dannymaaz/easypanel-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server