watsonx.data MCP Proxy
A proxy server that connects to IBM watsonx.data remote MCP server, automatically managing IBM Cloud API key token refresh for seamless access to watsonx.data assets and queries.
README
[!NOTE] まだテスト中です!
watsonx.data MCP Proxy
IBM watsonx.data Premium用のMCPプロキシサーバー。IBM watsonx.data remote Model Context Protocol (MCP) serverに接続し、IBM Cloud APIキーからアクセストークンを自動的に取得・更新してリクエストを中継します。
概要
このプロキシサーバーは、IBM watsonx.data Premiumのremote MCP server機能を利用するためのツールです。IBM Cloud IAMトークンの自動管理により、MCPクライアント(IBM BobやClaude Desktopなど)から簡単にwatsonx.dataのデータにアクセスできます。
特徴
- 自動トークン更新: IBM Cloud APIキーから自動的にトークンを取得し、期限切れ前に更新
- MCPプロトコル対応: Model Context Protocol (MCP)に完全対応
- 6つのツールをサポート: watsonx.dataのすべてのMCPツールに対応
- エラーハンドリング: 堅牢なエラー処理とリトライロジック
- ログ機能: 詳細なログでデバッグが容易
サポートされるツール
- LIST_DOCUMENT_LIBRARY - ドキュメントライブラリの一覧取得
- QUERY_DOCUMENT_LIBRARY - ドキュメントライブラリへのクエリ実行
- LIST_DOCUMENT_SET - ドキュメントセットの一覧取得
- QUERY_DOCUMENT_SET - ドキュメントセットへのクエリ実行
- LIST_DATA_ASSETS - データアセット(テーブル)の一覧取得
- QUERY_DATA_ASSETS - データアセットへのクエリ実行
インストール
前提条件
- Python 3.10以上
- pipx(推奨)またはpip
- IBM Cloud APIキー
- watsonx.data Premiumインスタンス
インストール方法
方法1: pipxでGitHubから直接インストール(推奨)
pipxを使用すると、独立した環境にインストールされ、システムのPython環境を汚染しません。
# pipxがインストールされていない場合
python -m pip install --user pipx
python -m pipx ensurepath
# GitHubから直接インストール
pipx install git+https://github.com/kyokonishito/watsonx_data_mcp_proxy.git
# 特定のブランチやタグからインストール
pipx install git+https://github.com/kyokonishito/watsonx_data_mcp_proxy.git@main
pipx install git+https://github.com/kyokonishito/watsonx_data_mcp_proxy.git@v0.1.0
方法2: pipでGitHubから直接インストール
# GitHubから直接インストール
pip install git+https://github.com/kyokonishito/watsonx_data_mcp_proxy.git
# または、ユーザーディレクトリにインストール
pip install --user git+https://github.com/kyokonishito/watsonx_data_mcp_proxy.git
方法3: ローカル開発用(開発者向け)
# リポジトリをクローン
git clone https://github.com/kyokonishito/watsonx_data_mcp_proxy.git
cd watsonx_data_mcp_proxy
# uvで仮想環境を作成(推奨)
uv venv
source .venv/bin/activate # Linux/macOS
# または .venv\Scripts\activate # Windows
# 開発モードでインストール
uv pip install -e ".[dev]"
# または、pipを使用
pip install -e ".[dev]"
インストールの確認
# コマンドが利用可能か確認
watsonx-data-mcp-proxy --help
# または、Pythonモジュールとして実行
python -m watsonx_data_mcp_proxy --help
アンインストール
pipxでインストールした場合
pipx uninstall watsonx-data-mcp-proxy
pipでインストールした場合
pip uninstall watsonx-data-mcp-proxy
ローカル開発環境の場合
# 開発モードでインストールした場合
pip uninstall watsonx-data-mcp-proxy
# または、仮想環境ごと削除
rm -rf .venv
使用方法
IBM Bob (MCP Client)での設定
IBM Bobで使用する場合、.bob/mcp.jsonに設定を追加します。インストール方法に応じて設定が異なります。
方法1: pipxでインストールした場合(推奨)
{
"mcpServers": {
"watsonx-data-premium": {
"command": "watsonx-data-mcp-proxy",
"env": {
"IBM_CLOUD_API_KEY": "your-ibm-cloud-api-key",
"WATSONX_DATA_URL": "https://your-instance.lakehouse.saas.ibm.com/api/v2/mcp/"
}
}
}
}
方法2: ローカル開発環境の場合
仮想環境のPythonの絶対パスを指定します:
{
"mcpServers": {
"watsonx-data-premium": {
"command": "/path/to/your/project/.venv/bin/python",
"args": ["-m", "watsonx_data_mcp_proxy"],
"env": {
"IBM_CLOUD_API_KEY": "your-ibm-cloud-api-key",
"WATSONX_DATA_URL": "https://your-instance.lakehouse.saas.ibm.com/api/v2/mcp/"
}
}
}
}
例: プロジェクトが/Users/username/watsonx-data-mcp-proxyにある場合:
{
"mcpServers": {
"watsonx-data-premium": {
"command": "/Users/username/watsonx-data-mcp-proxy/.venv/bin/python",
"args": ["-m", "watsonx_data_mcp_proxy"],
"env": {
"IBM_CLOUD_API_KEY": "your-ibm-cloud-api-key",
"WATSONX_DATA_URL": "https://your-instance.lakehouse.saas.ibm.com/api/v2/mcp/"
}
}
}
}
重要:
- 環境変数は
.bob/mcp.jsonのenvセクションで設定するため、シェルで別途exportする必要はありません - ローカル開発環境では、必ず仮想環境のPythonの絶対パスを指定してください
pythonやpython3などの相対コマンドは使用しないでください(モジュールが見つからないエラーが発生します)
Claude Desktop (MCP Client)での設定
Claude Desktopで使用する場合、設定ファイルの場所が異なります。
macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
Windows: %APPDATA%\Claude\claude_desktop_config.json
方法1: pipxでインストールした場合(推奨)
{
"mcpServers": {
"watsonx-data-premium": {
"command": "watsonx-data-mcp-proxy",
"env": {
"IBM_CLOUD_API_KEY": "your-ibm-cloud-api-key",
"WATSONX_DATA_URL": "https://your-instance.lakehouse.saas.ibm.com/api/v2/mcp/"
}
}
}
}
方法2: ローカル開発環境の場合
{
"mcpServers": {
"watsonx-data-premium": {
"command": "/path/to/your/project/.venv/bin/python",
"args": ["-m", "watsonx_data_mcp_proxy"],
"env": {
"IBM_CLOUD_API_KEY": "your-ibm-cloud-api-key",
"WATSONX_DATA_URL": "https://your-instance.lakehouse.saas.ibm.com/api/v2/mcp/"
}
}
}
}
サーバーの起動
IBM BobまたはClaude Desktopを起動すると、自動的にプロキシサーバーが起動します。トークンは自動的に取得・更新されます。
手動でテストする場合(開発時のみ):
export IBM_CLOUD_API_KEY="your-ibm-cloud-api-key"
export WATSONX_DATA_URL="https://your-instance.lakehouse.saas.ibm.com/api/v2/mcp/"
python -m watsonx_data_mcp_proxy
設定オプション
トークン更新マージン
デフォルトでは、トークンの有効期限の5分前に自動更新されます。この値はTokenManagerクラスのrefresh_marginパラメータで変更できます。
ログレベル
環境変数LOG_LEVELでログレベルを設定できます:
export LOG_LEVEL=DEBUG # DEBUG, INFO, WARNING, ERROR, CRITICAL
開発
テストの実行
# すべてのテストを実行
pytest
# カバレッジレポート付きで実行
pytest --cov=src/watsonx_data_mcp_proxy --cov-report=html
# 特定のテストファイルのみ実行
pytest tests/test_token_manager.py
# 統合テストを実行(実際のwatsonx.dataに接続)
# 環境変数を設定して実行
export IBM_CLOUD_API_KEY="your-ibm-cloud-api-key"
export WATSONX_DATA_URL="https://your-instance.lakehouse.saas.ibm.com/api/v2/mcp/"
pytest tests/test_integration.py -v -m integration
# または、uv仮想環境を使用する場合
IBM_CLOUD_API_KEY="your-api-key" WATSONX_DATA_URL="https://your-instance.lakehouse.saas.ibm.com/api/v2/mcp/" uv run pytest tests/test_integration.py -v -m integration
# LIST_DATA_ASSETSテストを実行する場合(追加の環境変数が必要)
export WATSONX_DATA_CONTAINER_ID="your-container-id"
export WATSONX_DATA_PRESTO_CRN="your-presto-instance-crn"
export WATSONX_DATA_PRESTO_ENGINE_ID="your-presto-engine-id"
pytest tests/test_integration.py::test_list_data_assets -v -s
テストの種類
-
ユニットテスト (
test_token_manager.py,test_server.py)- モックを使用した単体テスト
- 高速で依存関係なし
-
統合テスト (
test_integration.py)- 実際のIBM Cloudとwatsonx.dataに接続
- 環境変数の設定が必要
プロジェクト構造
mcp_wxd_premium/
├── src/
│ └── watsonx_data_mcp_proxy/
│ ├── __init__.py
│ ├── __main__.py
│ ├── server.py # MCPサーバー実装
│ └── token_manager.py # トークン管理
├── tests/
│ ├── test_token_manager.py # トークン管理のテスト
│ ├── test_server.py # サーバーのテスト
│ └── test_integration.py # 統合テスト
├── .bob/
│ └── mcp.json # IBM Bob設定ファイル
├── pyproject.toml # プロジェクト設定
└── README.md # このファイル
トラブルシューティング
トークン取得エラー
RuntimeError: IBM Cloudトークンの取得に失敗しました
解決方法:
- IBM Cloud APIキーが正しいか確認
- APIキーに適切な権限があるか確認
- ネットワーク接続を確認
watsonx.data接続エラー
RuntimeError: watsonx.dataへのリクエストが失敗しました
解決方法:
- watsonx.data URLが正しいか確認
- watsonx.dataインスタンスでMCPサーバー機能が有効化されているか確認
- トークンに適切な権限があるか確認
レスポンス形式エラー
Invalid response format: 'rows' is not a string []
解決方法:
- watsonx.dataのMCPサーバーバージョンを確認
- プロキシサーバーのログを確認してレスポンス内容を調査
ライセンス
このプロジェクトはApache License 2.0の下でライセンスされています。詳細はLICENSEファイルを参照してください。
参考資料
推荐服务器
Baidu Map
百度地图核心API现已全面兼容MCP协议,是国内首家兼容MCP协议的地图服务商。
Playwright MCP Server
一个模型上下文协议服务器,它使大型语言模型能够通过结构化的可访问性快照与网页进行交互,而无需视觉模型或屏幕截图。
Magic Component Platform (MCP)
一个由人工智能驱动的工具,可以从自然语言描述生成现代化的用户界面组件,并与流行的集成开发环境(IDE)集成,从而简化用户界面开发流程。
Audiense Insights MCP Server
通过模型上下文协议启用与 Audiense Insights 账户的交互,从而促进营销洞察和受众数据的提取和分析,包括人口统计信息、行为和影响者互动。
VeyraX
一个单一的 MCP 工具,连接你所有喜爱的工具:Gmail、日历以及其他 40 多个工具。
graphlit-mcp-server
模型上下文协议 (MCP) 服务器实现了 MCP 客户端与 Graphlit 服务之间的集成。 除了网络爬取之外,还可以将任何内容(从 Slack 到 Gmail 再到播客订阅源)导入到 Graphlit 项目中,然后从 MCP 客户端检索相关内容。
Kagi MCP Server
一个 MCP 服务器,集成了 Kagi 搜索功能和 Claude AI,使 Claude 能够在回答需要最新信息的问题时执行实时网络搜索。
e2b-mcp-server
使用 MCP 通过 e2b 运行代码。
Neon MCP Server
用于与 Neon 管理 API 和数据库交互的 MCP 服务器
Exa MCP Server
模型上下文协议(MCP)服务器允许像 Claude 这样的 AI 助手使用 Exa AI 搜索 API 进行网络搜索。这种设置允许 AI 模型以安全和受控的方式获取实时的网络信息。