Skip to main content
Glama

MCP Advisor

MIT License
88
64
  • Apple
  • Linux
README_zh.md15.8 kB
# MCP Advisor [![Model Context Protocol](https://img.shields.io/badge/Model%20Context%20Protocol-purple)](https://modelcontextprotocol.org) [![npm version](https://img.shields.io/npm/v/@xiaohui-wang/mcpadvisor.svg)](https://www.npmjs.com/package/@xiaohui-wang/mcpadvisor) [![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT) [![DeepWiki](https://img.shields.io/badge/DeepWiki-istarwyh%2Fmcpadvisor-blue.svg?logo=)](https://deepwiki.com/istarwyh/mcpadvisor) <!-- DeepWiki badge generated by https://deepwiki.ryoppippi.com/ --> [![Verified on MseeP](https://mseep.ai/badge.svg)](https://mseep.ai/app/a6ebedc6-e004-46f0-b7ec-e692a17ee7aa) [![MCP Badge](https://lobehub.com/badge/mcp/istarwyh-mcpadvisor)](https://lobehub.com/mcp/istarwyh-mcpadvisor) <a href="https://glama.ai/mcp/servers/@istarwyh/mcpadvisor"> <img width="380" height="200" src="https://glama.ai/mcp/servers/@istarwyh/mcpadvisor/badge" alt="Advisor MCP server" /> </a> [English](./README.md) | [简体中文](./README_zh.md) ## 简介 MCP Advisor 是一个发现和推荐服务,帮助 AI 助手使用自然语言查询探索 Model Context Protocol (MCP) 服务器。它让用户更容易找到并利用适合特定任务的 MCP 工具。 ## 用户故事 1. **MCP服务器发现与推荐** - 作为AI Agent 开发者,我希望通过自然语言查询快速找到适合特定任务的MCP服务器 - 直接提问:`"Find MCP servers for insurance risk analysis"` 2. **MCP服务器安装与配置** - 作为普通用户发现一个 MCP 很好用,我希望能够快速用上这个MCP - 直接指示:`"安装一下这个 MCP: https://github.com/Deepractice/PromptX` 3. **企业内部MCP服务器发现与安装** - 作为内部的 MCP 管理者,我同样希望运用 MCP Advisor 提供企业内部的 MCP 服务器发现与安装服务 - 可以配置 MySQL 的 transport 或者 Nacos 的环境变量实现和您自己的 MCP 数据源无缝连接 ### 演示 https://github.com/user-attachments/assets/7a536315-e316-4978-8e5a-e8f417169eb1 ## 文档导航 - [快速开始指南](docs/GETTING_STARTED.md) - 安装、配置和基本使用 - [技术参考手册](docs/TECHNICAL_REFERENCE.md) - 高级功能和搜索提供者 - [贡献指南](CONTRIBUTING.md) - 开发设置和贡献准则 - [架构文档](docs/ARCHITECTURE.md) - 系统架构详解 - [故障排除](docs/TROUBLESHOOTING.md) - 常见问题和解决方案 - [发展路线图](ROADMAP.md) - 未来发展计划 ## 2025年重构更新 🚀 项目在2025年进行了重大重构,提升了代码组织和可维护性: ### ✅ 主要改进 - **🏗️ 目录结构重构** - 采用清洁架构原则重新组织代码 - **🧪 全面测试覆盖** - 单元测试、集成测试和端到端测试 - **🤖 自动化测试** - 基于 Playwright 的完整自动化测试流程 - **🔧 改进的错误处理** - 更好的错误处理和日志记录 - **📦 模块化设计** - 清晰的服务分层和依赖管理 ### 新的项目结构 ``` src/ ├── services/ │ ├── core/ # 核心业务逻辑 │ │ ├── installation/ # 安装指南服务 │ │ ├── search/ # 搜索提供者 │ │ └── server/ # MCP服务器实现 │ ├── providers/ # 外部服务提供者 │ │ ├── meilisearch/ # Meilisearch集成 │ │ ├── nacos/ # Nacos服务发现 │ │ ├── oceanbase/ # OceanBase向量数据库 │ │ └── offline/ # 离线搜索引擎 │ ├── common/ # 共享工具 │ └── interfaces/ # 类型定义 ├── tests/ # 测试套件 │ ├── unit/ # 单元测试 │ ├── integration/ # 集成测试 │ └── e2e/ # 端到端测试 └── scripts/ # 自动化脚本 ``` - [路线图](ROADMAP.md) - 项目未来发展计划 - [贡献指南](CONTRIBUTING.md) - 如何贡献代码 ## 快速开始 ### 安装 最快的方式是通过 MCP 配置集成 MCP Advisor: ```json { "mcpServers": { "mcpadvisor": { "command": "npx", "args": ["-y", "@xiaohui-wang/mcpadvisor"] } } } ``` 将此配置添加到您的 AI 助手的 MCP 设置文件中: - MacOS/Linux: `~/Library/Application Support/Claude/claude_desktop_config.json` - Windows: `%AppData%\Claude\claude_desktop_config.json` 更多安装方法和详细配置请参阅 [快速开始指南](docs/GETTING_STARTED.md)。 ## 开发者指南 ### 架构概述 MCP Advisor 采用模块化架构,具有清晰的关注点分离和函数式编程原则: ```mermaid graph TD Client["Client Application"] --> |"MCP Protocol"| Transport["Transport Layer"] subgraph "MCP Advisor Server" Transport --> |"Request"| SearchService["Search Service"] SearchService --> |"Query"| Providers["Search Providers"] subgraph "Search Providers" Providers --> MeilisearchProvider["Meilisearch Provider"] Providers --> GetMcpProvider["GetMCP Provider"] Providers --> CompassProvider["Compass Provider"] Providers --> NacosProvider["Nacos 服务发现"] Providers --> OfflineProvider["Offline Provider"] end OfflineProvider --> |"Hybrid Search"| HybridSearch["Hybrid Search Engine"] HybridSearch --> TextMatching["Text Matching"] HybridSearch --> VectorSearch["Vector Search"] SearchService --> |"Merge & Filter"| ResultProcessor["Result Processor"] SearchService --> Logger["Logging System"] end ``` ### 核心组件 1. **搜索服务层** - 统一的搜索接口与提供者聚合 - 支持多个搜索提供者并行执行 - 可配置的搜索选项(limit,minSimilarity) 2. **搜索提供者** - **Meilisearch Provider**: 使用 Meilisearch 的向量搜索 - **GetMCP Provider**: 来自 GetMCP 注册表的 API 搜索 - **Compass Provider**: 来自 Compass 注册表的 API 搜索 - **Nacos Provider**: 从 Nacos 服务注册中心发现 MCP 服务器 - **Offline Provider**: 结合文本和向量的混合搜索 3. **混合搜索策略** - 文本匹配与向量搜索的智能结合 - 可配置的权重平衡 - 智能适应性过滤机制 4. **传输层** - Stdio(CLI 默认) - SSE(Web 集成) - REST API 端点 更详细的架构文档请参阅 [架构文档](docs/ARCHITECTURE.md)。 ## 技术亮点 ### 高级搜索技术 1. **向量归一化** - 所有向量都被归一化为单位长度(大小 = 1) - 确保一致的余弦相似度计算 - 通过关注方向而非大小来提高搜索精度 2. **并行搜索执行** - 向量搜索和文本搜索并行运行 - 利用 Promise.all 实现最佳性能 - 如果任一搜索失败,则启用后备机制 3. **加权结果合并** - 向量和文本结果之间的可配置权重 - 默认:向量相似度 (70%),文本匹配 (30%) ### 错误处理和日志系统 MCP Advisor 实现了强大的错误处理和日志系统: 1. **上下文错误格式化** - 标准化的错误对象丰富 - 堆栈跟踪保存和格式化 - 错误类型分类和标准化 2. **优雅降级** - 多提供者后备策略 - 部分结果处理 - 关键失败的默认响应 更多技术细节请参阅 [技术参考手册](docs/TECHNICAL_REFERENCE.md)。 ## 开发者快速上手 ### 开发环境设置 1. 克隆仓库 2. 安装依赖项: ```bash pnpm install ``` 3. 构建项目: ```bash pnpm run build ``` 4. 配置环境变量(参见 [快速开始指南](docs/GETTING_STARTED.md)) ### 测试 MCP Advisor 包含全面的测试套件以确保代码质量和功能性: #### 单元测试 ```bash # 运行单元测试 pnpm run test # 监听模式运行测试 pnpm run test:watch # 生成覆盖率报告 pnpm run test:coverage ``` #### 端到端测试 项目包含使用 Playwright 的自动化端到端测试,测试完整的 MCP Inspector 工作流程: ```bash # 运行端到端测试(推荐用于开发) pnpm run test:e2e:headed # 无头模式运行端到端测试(CI/CD) pnpm run test:e2e # 交互式调试端到端测试 pnpm run test:e2e:debug ``` #### 自动化测试脚本 为了方便使用,使用自动化测试脚本处理完整的测试工作流: ```bash # 运行完整的端到端测试套件(构建、启动inspector、运行测试) ./scripts/run-e2e-test.sh # 可用模式: ./scripts/run-e2e-test.sh headed # 浏览器可见(默认) ./scripts/run-e2e-test.sh headless # 后台测试 ./scripts/run-e2e-test.sh debug # 调试模式 ``` 自动化测试覆盖: - ✅ **推荐功能** - 自然语言 MCP 服务器发现 - ✅ **安装指南生成** - 自动化安装说明 - ✅ **错误处理** - 优雅的错误响应 - ✅ **性能测试** - 响应时间验证 ### 库使用 ```typescript import { SearchService } from '@xiaohui-wang/mcpadvisor'; // 初始化搜索服务 const searchService = new SearchService(); // 搜索 MCP 服务器 const results = await searchService.search('向量数据库集成'); console.log(results); ``` ### 传输选项 MCP Advisor 支持多种传输方式: 1. **Stdio 传输**(默认) - 适用于命令行工具 2. **SSE 传输** - 适用于 Web 集成 3. **REST 传输** - 提供 REST API 端点 更多开发详情请参阅 [贡献指南](CONTRIBUTING.md)。 ## 贡献指南 我们欢迎对 MCP Advisor 的贡献!项目最近进行了重构以改善代码组织和可维护性。 ### 开发工作流 1. **Fork 和克隆**:Fork 仓库并克隆您的 fork 2. **设置环境**:按照上面的开发环境设置 3. **创建分支**:从 `main` 创建功能分支 4. **进行更改**:按照我们的编码标准实现您的更改 5. **测试**:运行所有测试以确保您的更改不会破坏现有功能: ```bash pnpm run check # 代码检查和格式检查 pnpm run test # 单元测试 pnpm run test:e2e # 端到端测试 ``` 6. **提交**:遵循常规提交消息格式: ``` feat: 添加新的搜索提供者集成 fix: 解决向量搜索性能问题 docs: 更新安装指南 test: 为推荐工作流添加端到端测试 refactor: 重新组织服务目录结构 ``` 7. **拉取请求**:提交带有清晰更改描述的 PR ### 代码质量标准 - **TypeScript**:使用严格类型,避免 `any` - **测试**:保持测试覆盖率在 80% 以上 - **文档**:为新功能更新文档 - **架构**:遵循清洁架构原则 - **性能**:考虑性能影响 ### 最近改进(2025年) - ✅ **目录重构** 提升可维护性 - ✅ **全面测试套件** 包含单元、集成和端到端测试 - ✅ **自动化测试工作流** 使用 Playwright - ✅ **改进的错误处理** 和日志记录 - ✅ **清洁架构** 实现 ## 使用示例 ### 示例查询 以下是一些可以使用 MCP Advisor 的示例查询: ``` "查找用于自然语言处理的 MCP 服务器" "金融数据分析的 MCP 服务器" "电商推荐引擎 MCP 服务器" "具有图像识别功能的 MCP 服务器" "天气数据处理 MCP 服务器" "文档摘要 MCP 服务器" ``` ### 示例响应 ```json [ { "title": "NLP Toolkit", "description": "全面的自然语言处理工具包,具有情感分析、实体识别和文本摘要功能。", "github_url": "https://github.com/example/nlp-toolkit", "similarity": 0.92 }, { "title": "Text Processor", "description": "高效的文本处理 MCP 服务器,支持多语言。", "github_url": "https://github.com/example/text-processor", "similarity": 0.85 } ] ``` 更多示例和高级用法请参阅 [技术参考手册](docs/TECHNICAL_REFERENCE.md)。 ## 故障排除 ### 常见问题 1. **连接被拒绝** - 确保服务器在指定端口上运行 - 检查防火墙设置 2. **未返回结果** - 尝试更一般的查询 - 检查与注册表 API 的网络连接 3. **性能问题** - 考虑添加更具体的搜索词 - 检查服务器资源(CPU/内存) 更多故障排除信息请参阅 [TROUBLESHOOTING.md](docs/TROUBLESHOOTING.md)。 ## 搜索提供者 MCP Advisor 支持多个可同时使用的搜索提供者: 1. **Compass 搜索提供者**:使用 Compass API 检索 MCP 服务器信息 2. **GetMCP 搜索提供者**:使用 GetMCP API 和向量搜索进行语义匹配 3. **Meilisearch 搜索提供者**:使用 Meilisearch 进行快速、容错的文本搜索 有关搜索提供者的详细信息,请参阅 [技术参考手册](docs/TECHNICAL_REFERENCE.md)。 ## API 文档 更多技术细节和 API 信息请参阅 [技术参考手册](docs/TECHNICAL_REFERENCE.md)。 ## 路线图 MCP Advisor 正在从简单的推荐系统发展为智能代理编排平台。我们的愿景是创建一个系统,它不仅推荐正确的 MCP 服务器,还能从交互中学习并帮助代理动态规划和执行复杂任务。 ### 主要发展阶段 1. **推荐能力优化** (2025 Q2-Q3) - 接受用户反馈 - 打磨推荐效果 - 引入更多索引 详细的路线图请参阅 [发展路线图](ROADMAP.md)。 ## 测试 ### 手动测试 使用 [MCP Inspector](https://github.com/modelcontextprotocol/inspector) 进行交互式测试: ```bash ENABLE_FILE_LOGGING=true npx @modelcontextprotocol/inspector node build/index.js ``` ### 自动化测试 项目包含全面的自动化测试: #### 快速测试 ```bash # 运行所有测试 pnpm run check && pnpm run test && pnpm run test:e2e ``` #### 完整端到端测试工作流 ```bash # 自动化脚本,构建、启动 inspector 并运行测试 ./scripts/run-e2e-test.sh ``` 此自动化测试涵盖: - **推荐功能** - 自然语言 MCP 服务器发现 - **安装指南生成** - 自动化安装说明 - **错误处理** - 优雅的错误响应 - **性能验证** - 响应时间测试 #### 测试结构 ``` tests/ ├── unit/ # 单个组件的单元测试 ├── integration/ # 提供者交互的集成测试 └── e2e/ # 使用 Playwright 的端到端测试 ``` 详细的测试信息请参阅[开发者指南](#开发者快速上手)部分。 ## 许可证 本项目采用 MIT 许可证 - 详见 [LICENSE](LICENSE) 文件。

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/istarwyh/mcpadvisor'

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