Skip to main content
Glama

Elasticsearch MCP Server

README.zh-CN.md7.07 kB
# Elasticsearch MCP 服务器 [English](./README.md) | [中文](./README.zh-CN.md) [![smithery badge](https://smithery.ai/badge/@awesimon/elasticsearch-mcp)](https://smithery.ai/server/@awesimon/elasticsearch-mcp) MCP 服务器用于从任何 MCP 客户端(如 Claude Desktop、Cursor)直接连接到您的 Elasticsearch 集群。 该服务器使用模型上下文协议(Model Context Protocol)将智能体连接到您的 Elasticsearch 数据。它允许您通过自然语言对话与 Elasticsearch 索引进行交互。 ## 演示 [![Elasticsearch MCP Demo](https://img.youtube.com/vi/iJ1NPzAQ3bU/0.jpg)](https://www.youtube.com/watch?v=iJ1NPzAQ3bU "Elasticsearch MCP Demo") ## 功能概述 ### 可用工具 #### 集群管理 * `elasticsearch_health`: 获取 Elasticsearch 集群健康状态,可选择包括索引级别的详细信息 #### 索引操作 * `list_indices`: 列出可用的 Elasticsearch 索引,支持正则表达式 * `create_index`: 创建 Elasticsearch 索引,可选择设置和映射 * `reindex`: 将数据从源索引重新索引到目标索引,支持可选的查询和脚本 #### 映射管理 * `get_mappings`: 获取特定 Elasticsearch 索引的字段映射 * `create_mapping`: 为 Elasticsearch 索引创建或更新映射结构 #### 搜索与数据操作 * `search`: 使用提供的查询 DSL 执行 Elasticsearch 搜索 * `bulk`: 批量导入数据到 Elasticsearch 索引 #### 模板管理 * `create_index_template`: 创建或更新索引模板 * `get_index_template`: 获取索引模板信息 * `delete_index_template`: 删除索引模板 ### 工作原理 1. MCP 客户端分析您的请求并确定需要哪些 Elasticsearch 操作。 2. MCP 服务器执行这些操作(列出索引、获取映射、执行搜索)。 3. MCP 客户端处理结果并以用户友好的格式呈现。 ## 入门指南 ### 前提条件 * Elasticsearch 实例 * Elasticsearch 认证凭据(API 密钥或用户名/密码) * MCP 客户端(如 Claude Desktop、Cursor) ### 安装与设置 #### 使用已发布的 NPM 包 > [!TIP] > 使用 Elasticsearch MCP 服务器最简单的方法是通过已发布的 npm 包。 1. **配置 MCP 客户端** - 打开您的 MCP 客户端。查看 [MCP 客户端列表](https://modelcontextprotocol.io/clients),这里我们配置的是 Claude Desktop。 - 转到 **Settings > Developer > MCP Servers** - 点击 `Edit Config` 并添加一个新的 MCP 服务器,配置如下: ```json { "mcpServers": { "elasticsearch-mcp": { "command": "npx", "args": [ "-y", "@awesome-ai/elasticsearch-mcp" ], "env": { "ES_HOST": "your-elasticsearch-host", "ES_API_KEY": "your-api-key" } } } } ``` 2. **开始对话** - 在 MCP 客户端中打开新对话。 - MCP 服务器应自动连接。 - 现在您可以询问关于 Elasticsearch 数据的问题。 ### 配置选项 Elasticsearch MCP 服务器支持以下配置选项来连接到您的 Elasticsearch: > [!NOTE] > 您必须提供 API 密钥或同时提供用户名和密码进行身份验证。 | 环境变量 | 描述 | 必需 | |---------------------|-------------|----------| | `ES_HOST` | 您的 Elasticsearch 实例 URL(s) - 支持单个 URL 或逗号分隔的多个 URL(兼容旧版 `HOST`) | 是 | | `ES_API_KEY` | 用于身份验证的 Elasticsearch API 密钥(兼容旧版 `API_KEY`) | 否 | | `ES_USERNAME` | 用于基本身份验证的 Elasticsearch 用户名(兼容旧版 `USERNAME`) | 否 | | `ES_PASSWORD` | 用于基本身份验证的 Elasticsearch 密码(兼容旧版 `PASSWORD`) | 否 | | `ES_CA_CERT` | Elasticsearch SSL/TLS 的自定义 CA 证书路径(兼容旧版 `CA_CERT`) | 否 | ### 多URL配置 您可以配置多个 Elasticsearch 节点以实现高可用性和负载均衡: ```json { "mcpServers": { "elasticsearch-mcp": { "command": "npx", "args": [ "-y", "@awesome-ai/elasticsearch-mcp" ], "env": { "ES_HOST": "https://es-node1:9200,https://es-node2:9200,https://es-node3:9200", "ES_API_KEY": "your-api-key" } } } } ``` 客户端将自动处理配置节点之间的故障转移和负载均衡。 ## 本地开发 > [!NOTE] > 如果您想修改或扩展 MCP 服务器,请按照以下本地开发步骤操作。 1. **使用正确的 Node.js 版本** ```bash nvm use ``` 2. **安装依赖** ```bash npm install ``` 3. **构建项目** ```bash npm run build ``` 4. **在 Claude Desktop 应用中本地运行** - 打开 **Claude Desktop 应用** - 转到 **Settings > Developer > MCP Servers** - 点击 `Edit Config` 并添加一个新的 MCP 服务器,配置如下: ```json { "mcpServers": { "elasticsearch-mcp": { "command": "node", "args": [ "/path/to/your/project/dist/index.js" ], "env": { "ES_HOST": "your-elasticsearch-host", "ES_API_KEY": "your-api-key" } } } } ``` 5. **在 Cursor 编辑器中本地运行** - 打开 **Cursor 编辑器** - 转到 **Cursor Settings > MCP** - 点击 `Add new global MCP Server` 并添加一个新的 MCP 服务器,配置如下: ```json { "mcpServers": { "elasticsearch-mcp": { "command": "node", "args": [ "/path/to/your/project/dist/index.js" ], "env": { "ES_HOST": "your-elasticsearch-host", "ES_API_KEY": "your-api-key" } } } } ``` 6. **使用 MCP Inspector 进行调试** ```bash ES_HOST=your-elasticsearch-url ES_API_KEY=your-api-key npm run inspector ``` 这将启动 MCP Inspector,允许您调试和分析请求。您应该会看到: ```bash Starting MCP inspector... ⚙️ Proxy server listening on port 6277 🔍 MCP Inspector is up and running at http://127.0.0.1:6274 🚀 ``` ## 使用示例 > [!TIP] > 以下是您可以在 MCP 客户端中尝试的一些自然语言查询示例。 #### 集群管理 * "我的 Elasticsearch 集群的健康状态如何?" * "集群中有多少个活跃节点?" #### 索引操作 * "我的 Elasticsearch 集群中有哪些索引?" * "创建一个名为 'users' 的新索引,有 3 个分片和 1 个副本。" * "将数据从 'old_index' 重新索引到 'new_index'。" #### 映射管理 * "显示 'products' 索引的字段映射。" * "向 'products' 索引添加一个名为 'tags' 的关键字类型字段。" #### 搜索与数据操作 * "查找上个月超过 500 美元的所有订单。" * "哪些产品收到了最多的五星评价?" * "将这些客户记录批量导入到 'customers' 索引中。" #### 模板管理 * "为日志创建模式为 'logs-*' 的索引模板。" * "显示我所有的索引模板。" * "删除 'outdated_template' 索引模板。" 如果您遇到问题,请随时在 GitHub 仓库上提出 issue。

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/awesimon/elasticsearch-mcp'

If you have feedback or need assistance with the MCP directory API, please join our Discord server