Elasticsearch MCP Server

Elasticsearch MCP Server

An MCP server that enables AI assistants to directly interact with Elasticsearch for searching, aggregating, and retrieving documents from indices, supporting full-text search, semantic search, and various query modes.

Category
Visit Server

README

Elasticsearch MCP Server

An MCP (Model Context Protocol) server that gives AI assistants like Claude direct access to Elasticsearch. Search, aggregate, and retrieve documents from any index — all exposed as MCP tools over a Streamable HTTP transport.

Quickstart

With Docker (recommended)

docker build -t elasticsearch-mcp .
docker run -e ES_URL=http://host.docker.internal:9200 -p 3100:3100 elasticsearch-mcp

Without Docker

Requires Node.js 22+.

npm install
npm run build
ES_URL=http://localhost:9200 npm start

Connect to Claude Code

Add to your .mcp.json:

{
  "mcpServers": {
    "elasticsearch": {
      "type": "streamable-http",
      "url": "http://localhost:3100/mcp"
    }
  }
}

Sample prompts

Once connected, try asking Claude things like:

  • "What indices do I have? Pick the most interesting one and tell me what fields are available."
  • "Search the logs index for timeout errors in the last 24 hours and summarize what's going wrong."
  • "Which users have the most failed login attempts? Break it down by country."
  • "Find all documents mentioning 'rate limit' and show me the top 5 with highlights."
  • "How many orders were placed each month this year? Plot the trend."
  • "Compare how often these product names appear across the catalog: 'widget', 'gadget', 'gizmo', 'doohickey'."
  • "Pull up document abc-123 and give me a plain-English summary."
  • "What are the most common values in the status field? Are any of them suspicious?"

Tools

list_indices

List all Elasticsearch indices with doc counts, storage size, health, and status. Accepts an optional glob pattern to filter index names.

get_mapping

Get field names and types for an index.

search

Full-text search with query modes: match, match_phrase, multi_match, query_string. Supports filters, sorting, pagination, highlighting, field selection, and minimum score thresholds.

count

Count documents matching a query with optional filters.

multi_count

Count multiple phrases in one call using msearch. Useful for co-occurrence analysis — can require an additional term to co-occur with each phrase.

get_document

Retrieve a single document by _id or document_id field value. Long text fields are truncated by default.

aggregate

Run aggregations on an index:

  • terms — Top values by frequency
  • stats — min/max/avg/sum/count for numeric fields
  • date_histogram — Monthly bucketing for date fields
  • top_hits — Sample documents per bucket
  • cardinality — Distinct value count
  • filter — Filtered document count

Supports sub-aggregations for nested analysis (e.g., terms + stats).

Configuration

Variable Default Description
ES_URL http://localhost:9200 Elasticsearch URL
ES_API_KEY API key for Elasticsearch authentication (optional)
PORT 3100 HTTP port the server listens on

Endpoints

Path Method Description
/mcp POST MCP protocol (Streamable HTTP transport)
/health GET Health check (returns ok)

Semantic & Hybrid Search

The search tool also supports two additional modes for indices with dense_vector fields:

  • semantic — kNN vector search using a built-in all-MiniLM-L6-v2 embedding model (384 dimensions). No external embedding API needed.
  • hybrid — Runs keyword + semantic in parallel and fuses results with Reciprocal Rank Fusion (k=60).

Set search_mode to semantic or hybrid and specify the embedding_field (defaults to text_embedding).

The embedding model is downloaded on first use and cached locally. The Docker image pre-downloads it at build time. Use TRANSFORMERS_CACHE to control where the model is stored.

Variable Default Description
TRANSFORMERS_CACHE (system default) Directory to cache the embedding model

Recommended Servers

playwright-mcp

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.

Official
Featured
TypeScript
Magic Component Platform (MCP)

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.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

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.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

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.

Official
Featured
TypeScript
Kagi MCP Server

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.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

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.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured