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.
Integrations
Connects to Elasticsearch clusters allowing interaction with indices through natural language, including listing indices, retrieving mappings, performing searches, managing index templates, bulk operations, reindexing data, and monitoring cluster health.
Elasticsearch MCP サーバー
任意の MCP クライアント (Claude Desktop、Cursor など) から Elasticsearch クラスターに直接接続するための MCP サーバー。
このサーバーは、モデルコンテキストプロトコルを使用してエージェントをElasticsearchデータに接続します。これにより、自然言語による会話を通じてElasticsearchインデックスと対話できるようになります。
デモ
機能の概要
利用可能な機能
クラスター管理
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
: インデックステンプレートを削除する
仕組み
- MCP クライアントはリクエストを分析し、必要な Elasticsearch 操作を決定します。
- MCP サーバーはこれらの操作 (インデックスの一覧表示、マッピングの取得、検索の実行) を実行します。
- MCP クライアントは結果を処理し、ユーザーフレンドリーな形式で表示します。
はじめる
前提条件
- Elasticsearchインスタンス
- Elasticsearch 認証資格情報 (API キーまたはユーザー名/パスワード)
- MCP クライアント (例: Claude Desktop、Cursor)
インストールとセットアップ
公開されたNPMパッケージの使用
[!TIP] Elasticsearch MCP Server を使用する最も簡単な方法は、公開されている npm パッケージを使用することです。
- MCPクライアントの設定
- MCPクライアントを開きます。MCPクライアントのリストを確認し、ここでClaude Desktopを設定します。
- 設定 > 開発者 > MCP サーバーに移動します
Edit Config
をクリックし、次の設定で新しい MCP サーバーを追加します。
Copy - 会話を始める
- MCP クライアントで新しい会話を開きます。
- MCP サーバーは自動的に接続されるはずです。
- Elasticsearch データについて質問できるようになりました。
設定オプション
Elasticsearch MCP サーバーは、Elasticsearch に接続するための構成オプションをサポートしています。
[!NOTE] 認証には、API キーまたはユーザー名とパスワードの両方を指定する必要があります。
環境変数 | 説明 | 必須 |
---|---|---|
ES_HOST | Elasticsearch インスタンスの 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 もサポート) | いいえ |
地域開発
[!NOTE] MCP サーバーを変更または拡張する場合は、次のローカル開発手順に従ってください。
- 正しいNode.jsバージョンを使用するCopy
- 依存関係をインストールするCopy
- プロジェクトを構築するCopy
- Claudeデスクトップアプリでローカルに実行
- Claudeデスクトップアプリを開く
- 設定 > 開発者 > MCP サーバーに移動します
Edit Config
をクリックし、次の設定で新しいMCPサーバーを追加します: GXP5
- カーソルエディタでローカルに実行
- カーソルエディタを開く
- カーソル設定 > MCPへ移動します。
Add new global MCP Server
をクリックし、次の構成で新しいMCPサーバーを追加します: GXP6
- MCP InspectorによるデバッグMCP Inspectorが起動し、リクエストのデバッグと分析が可能になります。以下の画面が表示されます。CopyCopy
クエリの例
[!TIP] MCP クライアントで試すことができる自然言語クエリをいくつか示します。
クラスター管理
- 「Elasticsearch クラスターのヘルスステータスはどうですか?」
- 「クラスター内にアクティブノードはいくつありますか?」
インデックス操作
- 「Elasticsearch クラスターにはどのようなインデックスがありますか?」
- 「3 つのシャードと 1 つのレプリカを持つ「users」という新しいインデックスを作成します。」
- 「'old_index' から 'new_index' にデータを再インデックスします。」
マッピング管理
- 「「製品」インデックスのフィールド マッピングを表示します。」
- 「「製品」インデックスに「タグ」というキーワード タイプのフィールドを追加します。」
検索とデータ操作
- 「先月の 500 ドルを超えるすべての注文を検索します。」
- 「5 つ星のレビューを最も多く獲得した製品はどれですか?」
- 「これらの顧客レコードを「顧客」インデックスに一括インポートします。」
テンプレート管理
- 「パターン 'logs-*' のログのインデックス テンプレートを作成します。」
- 「すべてのインデックス テンプレートを表示します。」
- 「'outdated_template' インデックス テンプレートを削除します。」
問題が発生した場合は、お気軽に GitHub リポジトリで問題を報告してください。
You must be authenticated.
Tools
モデル コンテキスト プロトコルを使用してエージェントを Elasticsearch データに接続し、Claude Desktop や Cursor などの MCP クライアントを通じて Elasticsearch インデックスとの自然言語による対話を可能にします。