MCP Hub
Back to servers

OpenSearch Logs MCP Server

Enables querying OpenTelemetry logs stored in OpenSearch across development and production environments. Provides tools for searching logs by various criteria including free-text Lucene queries, trace IDs, service names, error levels, and specific fields.

glama
Updated
Apr 20, 2026

OpenSearch Logs MCP Server

MCP (Model Context Protocol) server para consultar logs de OpenTelemetry en OpenSearch. Soporta ambientes de desarrollo (dev) y producción (prod).

Arquitectura

El servidor sigue los principios SOLID y Clean Architecture:

src/
├── index.ts                     # Entry point
├── server.ts                    # MCP Server setup
├── config/
│   └── environments.ts          # Environment configuration
├── types/
│   └── index.ts                 # Type definitions
├── services/
│   ├── opensearch-client.ts     # HTTP client for OpenSearch
│   └── log-search.service.ts    # Business logic
├── tools/
│   ├── tool-definitions.ts      # Tool schemas
│   └── tool-handlers.ts         # Tool execution
└── utils/
    ├── query-builder.ts         # Query construction (Builder pattern)
    └── time-range.ts            # Time utilities

Principios Aplicados

  • Single Responsibility (SRP): Cada módulo tiene una única responsabilidad
  • Open/Closed (OCP): Fácil agregar nuevas herramientas sin modificar código existente
  • Dependency Inversion (DIP): Los servicios dependen de abstracciones (interfaces)
  • Builder Pattern: QueryBuilder para construcción fluida de queries

Instalación

cd Tools/mcp-opensearch-logs
npm install
npm run build

Configuración en Cursor

Agrega esto a tu configuración de Cursor (~/.cursor/mcp.json):

{
  "mcpServers": {
    "opensearch-logs": {
      "command": "node",
      "args": ["/ruta/al/proyecto/Tools/mcp-opensearch-logs/dist/index.js"],
      "env": {
        "OPENSEARCH_DEV_USERNAME": "tu-usuario-dev",
        "OPENSEARCH_DEV_PASSWORD": "tu-password-dev",
        "OPENSEARCH_PROD_USERNAME": "tu-usuario-prod",
        "OPENSEARCH_PROD_PASSWORD": "tu-password-prod"
      }
    }
  }
}

Herramientas Disponibles

search_logs

Búsqueda libre con sintaxis Lucene.

ParámetroTipoRequeridoDescripción
environmentdev | prodAmbiente a consultar
querystringQuery en sintaxis Lucene
timeRange15m | 1h | 6h | 24h | 7dRango de tiempo (default: 1h)
sizenumberMáximo de resultados (default: 50, max: 200)

Ejemplos:

  • "Busca logs que contengan 'error' en dev de la última hora"
  • "Busca logs con status 500 en prod de las últimas 6 horas"

search_by_trace

Busca todos los logs de un trace de OpenTelemetry.

ParámetroTipoRequeridoDescripción
environmentdev | prodAmbiente a consultar
traceIdstringID del trace
sizenumberMáximo de resultados (default: 100)

Ejemplo:

  • "Dame todos los logs del trace abc123 en dev"

search_by_service

Filtra logs por nombre de servicio.

ParámetroTipoRequeridoDescripción
environmentdev | prodAmbiente a consultar
serviceNamestringNombre del servicio
levelDEBUG | INFO | WARN | ERROR | FATALNivel de log
querystringQuery adicional
timeRangestringRango de tiempo
sizenumberMáximo de resultados

Ejemplos:

  • "Busca logs del servicio stori-ios en prod"
  • "Dame los errores del servicio stori-ios en dev"

search_errors

Busca logs de nivel ERROR o superior (severityNumber >= 17).

ParámetroTipoRequeridoDescripción
environmentdev | prodAmbiente a consultar
serviceNamestringFiltrar por servicio
querystringQuery adicional
timeRangestringRango de tiempo
sizenumberMáximo de resultados

Ejemplos:

  • "Dame los errores de la última hora en prod"
  • "Busca errores relacionados con KYC en dev"

get_field_values

Obtiene los valores más comunes de un campo (agregación).

ParámetroTipoRequeridoDescripción
environmentdev | prodAmbiente a consultar
fieldstringCampo a agregar
sizenumberMáximo de valores únicos (default: 20)

Ejemplos:

  • "Qué valores tiene el campo 'event' en prod?"
  • "Dame los tipos de error más comunes en dev"

search_by_field

Busca por un campo y valor específico.

ParámetroTipoRequeridoDescripción
environmentdev | prodAmbiente a consultar
fieldstringNombre del campo
valuestringValor a buscar
timeRangestringRango de tiempo
sizenumberMáximo de resultados

Ejemplo:

  • "Busca logs con transactionId=abc123 en prod"

get_mapping

Obtiene el mapeo de campos del índice.

ParámetroTipoRequeridoDescripción
environmentdev | prodAmbiente a consultar

Ejemplo:

  • "Qué campos están disponibles en los logs de prod?"

get_sample_log

Obtiene un log de ejemplo para ver la estructura.

ParámetroTipoRequeridoDescripción
environmentdev | prodAmbiente a consultar

Ejemplo:

  • "Dame un ejemplo de log de prod para ver la estructura"

Sintaxis de Búsqueda Lucene

El campo query soporta sintaxis Lucene completa:

SintaxisDescripciónEjemplo
términoBusca en cualquier campoerror
campo:valorBusca en campo específicoevent:kyc_error
campo:*valor*WildcarderrorMessage:*timeout*
ANDAmbos términoserror AND authentication
ORCualquier términoerror OR warning
NOTExcluye términoNOT debug
[a TO b]RangostatusCode:[400 TO 499]
"frase exacta"Match exacto"connection refused"

Rangos de Tiempo

ValorDescripción
15mÚltimos 15 minutos
1hÚltima hora (default)
6hÚltimas 6 horas
24hÚltimas 24 horas
7dÚltimos 7 días

Desarrollo

# Desarrollo con watch mode
npm run dev

# Build
npm run build

# Lint
npm run lint

Estructura de Logs OpenTelemetry

Los logs siguen el esquema OpenTelemetry:

{
  "time": "2024-01-15T10:30:00.000Z",
  "severityText": "ERROR",
  "severityNumber": 17,
  "body": "Error message",
  "attributes": {
    "event": "kyc_error",
    "kycFlow": "creditL1",
    "transactionId": "abc123"
  },
  "resource": {
    "service.name": "stori-ios",
    "service.version": "1.0.0"
  }
}

Reviews

No reviews yet

Sign in to write a review