Chroma MCP サーバー
Chroma を介してベクターデータベース機能を提供するモデルコンテキストプロトコル(MCP)サーバー実装。このサーバーは、セマンティックドキュメント検索、メタデータフィルタリング、そして永続ストレージによるドキュメント管理を可能にします。
要件
- Python 3.8以上
- Chroma 0.4.0以降
- MCP SDK 0.1.0+
コンポーネント
リソース
サーバーは、Chroma のベクター データベースを通じてドキュメントの保存と取得を提供します。
- コンテンツとメタデータを含むドキュメントを保存します
src/chroma/data
ディレクトリにデータを保存します- 意味的類似性検索をサポート
ツール
サーバーは CRUD 操作と検索機能を実装します。
ドキュメント管理
create_document
: 新しいドキュメントを作成する- 必須:
document_id
、content
- オプション:
metadata
(キーと値のペア) - 戻り値: 成功確認
- エラー: すでに存在します。入力が無効です
- 必須:
read_document
: IDでドキュメントを取得する- 必須:
document_id
- 戻り値: ドキュメントのコンテンツとメタデータ
- エラー: 見つかりません
- 必須:
update_document
: 既存のドキュメントを更新する- 必須:
document_id
、content
- オプション:
metadata
- 戻り値: 成功確認
- エラー: 見つかりません、入力が無効です
- 必須:
delete_document
: ドキュメントを削除する- 必須:
document_id
- 戻り値: 成功確認
- エラー: 見つかりません
- 必須:
list_documents
: すべてのドキュメントを一覧表示する- オプション:
limit
、offset
- 戻り値: コンテンツとメタデータを含むドキュメントのリスト
- オプション:
捜索活動
search_similar
: 意味的に類似した文書を検索する- 必須:
query
- オプション:
num_results
、metadata_filter
、content_filter
- 返されるもの: 距離スコアによる類似文書のランク付けされたリスト
- エラー: 無効なフィルター
- 必須:
特徴
- セマンティック検索: Chroma の埋め込みを使用して意味に基づいてドキュメントを検索します
- メタデータフィルタリング: メタデータフィールドで検索結果をフィルタリングする
- コンテンツフィルタリング: ドキュメントコンテンツに基づく追加のフィルタリング
- 永続ストレージ: データはサーバーの再起動後もローカルディレクトリに保持されます
- エラー処理: 明確なメッセージによる包括的なエラー処理
- 再試行ロジック: 一時的な障害に対する自動再試行
インストール
- 依存関係をインストールします:
構成
クロードデスクトップ
Claude Desktop 構成にサーバー構成を追加します。
Windows: C:\Users\<username>\AppData\Roaming\Claude\claude_desktop_config.json
MacOS: ~/Library/Application Support/Claude/claude_desktop_config.json
データストレージ
サーバーは次の場所にデータを保存します。
- Windows:
src/chroma/data
- MacOS/Linux:
src/chroma/data
使用法
- サーバーを起動します。
- MCP ツールを使用してサーバーと対話します。
エラー処理
サーバーは、一般的なシナリオに対して明確なエラー メッセージを提供します。
Document already exists [id=X]
Document not found [id=X]
Invalid input: Missing document_id or content
Invalid filter
Operation failed: [details]
発達
テスト
- 対話型テストのために MCP Inspector を実行します。
- インスペクターの Web インターフェースを使用して次の操作を行います。
- CRUD操作をテストする
- 検索機能を確認する
- エラー処理を確認する
- サーバーログを監視する
建物
- 依存関係を更新します:
- ビルドパッケージ:
貢献
貢献を歓迎します!詳細については、貢献ガイドラインをご覧ください。
- コードスタイル
- テスト要件
- プルリクエストプロセス
ライセンス
このプロジェクトは MIT ライセンスに基づいてライセンスされています - 詳細についてはLICENSEファイルを参照してください。
This server cannot be installed
local-only server
The server can only run on the client's local machine because it depends on local resources.
Chroma を通じてベクター データベース機能を提供し、セマンティック ドキュメント検索、メタデータ フィルタリング、永続ストレージによるドキュメント管理を可能にするモデル コンテキスト プロトコル サーバーです。
Related Resources
Related MCP Servers
- -securityFlicense-qualityEnables efficient vector database operations for embedding storage and similarity search through a Model Context Protocol interface.Last updated -3Python
- -securityAlicense-qualityA Model Context Protocol server enabling LLMs to search, retrieve, and manage documents through Rememberizer's knowledge management API.Last updated -24PythonApache 2.0
- AsecurityAlicenseAqualityA high-performance, persistent memory system for the Model Context Protocol (MCP) providing vector search capabilities and efficient knowledge storage using libSQL as the backing store.Last updated -6641TypeScriptMIT License
- -securityAlicense-qualityA Model Context Protocol server that enables semantic search capabilities by providing tools to manage Qdrant vector database collections, process and embed documents using various embedding services, and perform semantic searches across vector embeddings.Last updated -89TypeScriptMIT License