The Elasticsearch MCP Server enables interaction with Elasticsearch and OpenSearch clusters for managing indices, documents, and cluster health.
You can:
List indices: Retrieve all indices in the cluster
Create, delete, and manage indices: Perform index operations
Get index mapping and settings: Fetch mappings and configurations
Search documents: Perform custom queries to search documents
Manage documents: Index, retrieve, and delete documents
Get cluster health and stats: Check status and obtain statistics
Manage aliases: Create, update, delete, and list aliases
General operations: Execute any Elasticsearch/OpenSearch API request
Provides Elasticsearch interaction allowing users to search documents, analyze indices, and manage clusters through natural language queries
Mentions that Kibana is accessible as part of the Elasticsearch cluster setup, though interaction is primarily through the Elasticsearch API
Elasticsearch/OpenSearch MCP Server
Overview
A Model Context Protocol (MCP) server implementation that provides Elasticsearch and OpenSearch interaction. This server enables searching documents, analyzing indices, and managing cluster through a set of tools.
Demo
https://github.com/user-attachments/assets/f7409e31-fac4-4321-9c94-b0ff2ea7ff15
Features
General Operations
general_api_request
: Perform a general HTTP API request. Use this tool for any Elasticsearch/OpenSearch API that does not have a dedicated tool.
Index Operations
list_indices
: List all indices.get_index
: Returns information (mappings, settings, aliases) about one or more indices.create_index
: Create a new index.delete_index
: Delete an index.
Document Operations
search_documents
: Search for documents.index_document
: Creates or updates a document in the index.get_document
: Get a document by ID.delete_document
: Delete a document by ID.delete_by_query
: Deletes documents matching the provided query.
Cluster Operations
get_cluster_health
: Returns basic information about the health of the cluster.get_cluster_stats
: Returns high-level overview of cluster statistics.
Alias Operations
list_aliases
: List all aliases.get_alias
: Get alias information for a specific index.put_alias
: Create or update an alias for a specific index.delete_alias
: Delete an alias for a specific index.
Configure Environment Variables
The MCP server supports the following environment variables for authentication:
Basic Authentication (Username/Password)
ELASTICSEARCH_USERNAME
: Username for basic authenticationELASTICSEARCH_PASSWORD
: Password for basic authenticationOPENSEARCH_USERNAME
: Username for OpenSearch basic authenticationOPENSEARCH_PASSWORD
: Password for OpenSearch basic authentication
API Key Authentication (Elasticsearch only) - Recommended
ELASTICSEARCH_API_KEY
: API key for Elasticsearch or Elastic Cloud Authentication.
Other Configuration
ELASTICSEARCH_HOSTS
/OPENSEARCH_HOSTS
: Comma-separated list of hosts (default:https://localhost:9200
)ELASTICSEARCH_VERIFY_CERTS
/OPENSEARCH_VERIFY_CERTS
: Whether to verify SSL certificates (default:false
)
Start Elasticsearch/OpenSearch Cluster
Start the Elasticsearch/OpenSearch cluster using Docker Compose:
The default Elasticsearch username is elastic
and password is test123
. The default OpenSearch username is admin
and password is admin
.
You can access Kibana/OpenSearch Dashboards from http://localhost:5601.
Stdio
Option 1: Using uvx
Using uvx
will automatically install the package from PyPI, no need to clone the repository locally. Add the following configuration to 's config file claude_desktop_config.json
.
Option 2: Using uv with local development
Using uv
requires cloning the repository locally and specifying the path to the source code. Add the following configuration to Claude Desktop's config file claude_desktop_config.json
.
SSE
Option 1: Using uvx
Option 2: Using uv
Streamable HTTP
Option 1: Using uvx
Option 2: Using uv
Compatibility
The MCP server is compatible with Elasticsearch 7.x, 8.x, and 9.x. By default, it uses the Elasticsearch 8.x client (without a suffix). To use the Elasticsearch 7.x client, run the elasticsearch-mcp-server-es7
variant. For Elasticsearch 9.x, use elasticsearch-mcp-server-es9
. For example:
MCP Server | Elasticsearch |
---|---|
elasticsearch-mcp-server-es7 | Elasticsearch 7.x |
elasticsearch-mcp-server | Elasticsearch 8.x |
elasticsearch-mcp-server-es9 | Elasticsearch 9.x |
opensearch-mcp-server | OpenSearch 1.x, 2.x, 3.x |
License
This project is licensed under the Apache License Version 2.0 - see the LICENSE file for details.
remote-capable server
The server can be hosted and run remotely because it primarily relies on remote services or has no dependency on the local environment.
Tools
Facilitates interaction with Elasticsearch clusters by allowing users to perform index operations, document searches, and cluster management via a Model Context Protocol server and natural language commands.
- Overview
- Demo
- Features
- Configure Environment Variables
- Start Elasticsearch/OpenSearch Cluster
- Usage with Claude Desktop
- Usage with Anthropic MCP Client
- License
Related Resources
Related MCP Servers
- -securityFlicense-qualityA Model Context Protocol server that enables LLMs to interact with Elasticsearch clusters, allowing them to manage indices and execute search queries using natural language.Last updated -2
- AsecurityAlicenseAqualityA Model Context Protocol server implementation that enables natural language interactions with OpenSearch clusters, allowing users to search documents, analyze indices, and manage clusters through simple conversational commands.Last updated -610Apache 2.0
- AsecurityAlicenseAqualityConnects agents to Elasticsearch data using the Model Context Protocol, allowing natural language interaction with Elasticsearch indices through MCP Clients like Claude Desktop and Cursor.Last updated -1110914MIT License
- AsecurityAlicenseAqualityConnects to Elasticsearch databases using the Model Context Protocol, allowing users to query and interact with their Elasticsearch indices through natural language conversations.Last updated -40Apache 2.0