Elasticsearch MCP Server允许你通过Model Context Protocol (MCP) 直接从任何MCP客户端(如Claude Desktop)连接到你的Elasticsearch数据。它能让你通过自然语言对话与Elasticsearch索引进行交互,不过此仓库包含的是用于研究和评估的实验性功能,尚未达到生产就绪状态。
💡 使用建议 使用Elasticsearch MCP Server最简单的方法是通过已发布的npm包。
配置MCP客户端
编辑配置,并添加一个新的MCP服务器,配置如下:{
"mcpServers": {
"elasticsearch-mcp-server": {
"command": "npx",
"args": [
"-y",
"@elastic/mcp-server-elasticsearch"
],
"env": {
"ES_URL": "your-elasticsearch-url",
"ES_API_KEY": "your-api-key"
}
}
}
}
开始对话
⚠️ 重要提示 如果你想修改或扩展MCP服务器,请按照以下本地开发步骤操作。
使用正确的Node.js版本
nvm use
安装依赖项
npm install
构建项目
npm run build
在Claude Desktop应用中本地运行
编辑配置,并添加一个新的MCP服务器,配置如下:{
"mcpServers": {
"elasticsearch-mcp-server-local": {
"command": "node",
"args": [
"/path/to/your/project/dist/index.js"
],
"env": {
"ES_URL": "your-elasticsearch-url",
"ES_API_KEY": "your-api-key"
}
}
}
}
使用MCP检查器进行调试
ES_URL=your-elasticsearch-url ES_API_KEY=your-api-key npm run inspector
这将启动MCP检查器,允许你调试和分析请求。你应该会看到:
Starting MCP inspector...
Proxy server listening on port 3000
🔍 MCP Inspector is up and running at http://localhost:5173 🚀
list_indices:列出所有可用的Elasticsearch索引。get_mappings:获取特定Elasticsearch索引的字段映射。search:使用提供的查询DSL执行Elasticsearch搜索。get_shards:获取所有或特定索引的分片信息。💡 使用建议 以下是一些你可以在MCP客户端中尝试的自然语言查询。
Elasticsearch MCP Server支持配置选项以连接到你的Elasticsearch:
⚠️ 重要提示 你必须提供API密钥或用户名和密码进行身份验证。
| 环境变量 | 描述 | 是否必需 |
|---|---|---|
ES_URL |
你的Elasticsearch实例URL | 是 |
ES_API_KEY |
用于身份验证的Elasticsearch API密钥 | 否 |
ES_USERNAME |
用于基本身份验证的Elasticsearch用户名 | 否 |
ES_PASSWORD |
用于基本身份验证的Elasticsearch密码 | 否 |
ES_CA_CERT |
用于Elasticsearch SSL/TLS的自定义CA证书的路径 | 否 |
你可以使用MCP客户端向Elasticsearch MCP Server发送自然语言查询,例如:
"What indices do I have in my Elasticsearch cluster?"
你可以构建更复杂的查询,例如:
"Find all orders over $500 from last month."
⚠️ 重要提示 避免使用集群管理员权限。创建具有有限范围的专用API密钥,并在索引级别应用细粒度的访问控制,以防止未经授权的数据访问。
你可以创建一个具有最小权限的专用Elasticsearch API密钥来控制对数据的访问:
POST /_security/api_key
{
"name": "es-mcp-server-access",
"role_descriptors": {
"mcp_server_role": {
"cluster": [
"monitor"
],
"indices": [
{
"names": [
"index-1",
"index-2",
"index-pattern-*"
],
"privileges": [
"read",
"view_index_metadata"
]
}
]
}
}
}
如果你遇到问题,请随时在GitHub仓库上打开一个问题。
本项目采用Apache License 2.0许可。