MCP Server POC

MCP Server POC

这个项目演示了如何创建和使用模型上下文协议 (MCP) 服务器,该服务器可以为 AI 助手(如 Claude 和其他支持 MCP 标准的助手)提供自定义工具和资源。该服务器包括: - 简单的数学运算(加法) - 动态问候语资源 - 使用 crawl4ai 库的网络爬取功能

TarcisioPhilips

研究与数据
访问服务器

README

MCP Server POC

一个模型上下文协议 (MCP) 服务器的概念验证实现,用于通过自定义工具和资源增强 AI 助手的能力。

概述

本项目演示了如何创建和使用模型上下文协议 (MCP) 服务器,该服务器可以为 AI 助手(如 Claude 和其他支持 MCP 标准的助手)提供自定义工具和资源。 该服务器包括:

  • LangChain、LlamaIndex 和 OpenAI 的文档搜索工具
  • 网络爬取功能
  • 与 Google Search API 集成

要求

  • Python 3.11
  • requirements.txt 中列出的必需软件包

安装和设置

  1. 克隆此存储库:
git clone https://github.com/yourusername/mcp-server-poc.git
cd mcp-server-poc
  1. 创建并激活虚拟环境:
# 创建一个 Python 3.11 虚拟环境
python -m venv venv

# 在 Windows 上激活
 .\venv\Scripts\Activate.ps1

# 在 macOS/Linux 上激活
source venv/bin/activate
  1. 安装所需的软件包:
pip install -r requirements.txt
  1. 设置环境变量:

    在根目录中创建一个 .env 文件,内容如下:

SERPER_API_KEY=your_serper_api_key_here

运行应用程序

要运行 MCP 服务器:

python main.py

服务器将启动并等待使用 stdio 传输方法的连接。

与 Cursor 集成

要将此 MCP 服务器与 Cursor IDE 一起使用:

  1. 创建或编辑文件 ~/.cursor/mcp.json(在 Windows 上:C:\Users\<username>\.cursor\mcp.json),内容如下:
{
    "mcpServers": {
        "mcp-server": {
            "command": "python", 
            "args": [
                "ABSOLUTE/PATH/TO/main.py"
            ]
        }
    }
}
  1. 将路径替换为 main.py 文件的绝对路径。

    • 在 Windows 上,使用双反斜杠:C:\\Users\\username\\path\\to\\main.py
    • 在 macOS/Linux 上,使用正斜杠:/Users/username/path/to/main.py
  2. 完全重启 Cursor(包括结束任何后台进程)以加载 MCP 服务器。

功能

工具

  • get_docs(query, library):搜索指定库(langchain、llama-index 或 openai)的文档并返回相关信息

技术细节

Windows 二进制模式修复

此服务器包含一个针对 Windows 的特定修复程序,以确保与 stdio 传输正常运行:

# Set binary mode for stdin/stdout on Windows
if os.name == 'nt':
    import msvcrt
    msvcrt.setmode(sys.stdin.fileno(), os.O_BINARY)
    msvcrt.setmode(sys.stdout.fileno(), os.O_BINARY)

此修复是必要的,因为 Windows 区分文本和二进制文件处理模式,这可能会导致 MCP 使用的 stdio 传输机制出现问题。

故障排除

如果您遇到 MCP 服务器的问题:

Windows 特有问题

  • "Failed to create client" 或 "Client closed" 错误
    • 确保使用服务器中包含的二进制模式修复
    • 在 mcp.json 配置中使用带有双反斜杠的绝对路径
    • 尝试直接运行 MCP 服务器,看看是否产生任何错误输出
    • 完全退出 Cursor(包括通过任务管理器终止任何后台进程)然后再重新启动

一般问题

  • 验证是否已安装所有必需的软件包(pip list 检查)
  • 检查配置文件中的绝对路径是否正确
  • 确保 MCP 服务器以正确的 Python 版本 (3.11) 运行
  • 验证您的 .env 文件是否包含所需的 API 密钥
  • 尝试重新安装 MCP 包:pip uninstall mcp && pip install mcp

许可证

MIT 许可证

致谢

推荐服务器

Crypto Price & Market Analysis MCP Server

Crypto Price & Market Analysis MCP Server

一个模型上下文协议 (MCP) 服务器,它使用 CoinCap API 提供全面的加密货币分析。该服务器通过一个易于使用的界面提供实时价格数据、市场分析和历史趋势。 (Alternative, slightly more formal and technical translation): 一个模型上下文协议 (MCP) 服务器,利用 CoinCap API 提供全面的加密货币分析服务。该服务器通过用户友好的界面,提供实时价格数据、市场分析以及历史趋势数据。

精选
TypeScript
MCP PubMed Search

MCP PubMed Search

用于搜索 PubMed 的服务器(PubMed 是一个免费的在线数据库,用户可以在其中搜索生物医学和生命科学文献)。 我是在 MCP 发布当天创建的,但当时正在度假。 我看到有人在您的数据库中发布了类似的服务器,但还是决定发布我的服务器。

精选
Python
mixpanel

mixpanel

连接到您的 Mixpanel 数据。 从 Mixpanel 分析查询事件、留存和漏斗数据。

精选
TypeScript
Sequential Thinking MCP Server

Sequential Thinking MCP Server

这个服务器通过将复杂问题分解为顺序步骤来促进结构化的问题解决,支持修订,并通过完整的 MCP 集成来实现多条解决方案路径。

精选
Python
Nefino MCP Server

Nefino MCP Server

为大型语言模型提供访问德国可再生能源项目新闻和信息的能力,允许按地点、主题(太阳能、风能、氢能)和日期范围进行筛选。

官方
Python
Vectorize

Vectorize

将 MCP 服务器向量化以实现高级检索、私有深度研究、Anything-to-Markdown 文件提取和文本分块。

官方
JavaScript
Mathematica Documentation MCP server

Mathematica Documentation MCP server

一个服务器,通过 FastMCP 提供对 Mathematica 文档的访问,使用户能够从 Wolfram Mathematica 检索函数文档和列出软件包符号。

本地
Python
kb-mcp-server

kb-mcp-server

一个 MCP 服务器,旨在实现便携性、本地化、简易性和便利性,以支持对 txtai “all in one” 嵌入数据库进行基于语义/图的检索。任何 tar.gz 格式的 txtai 嵌入数据库都可以被加载。

本地
Python
Research MCP Server

Research MCP Server

这个服务器用作 MCP 服务器,与 Notion 交互以检索和创建调查数据,并与 Claude Desktop Client 集成以进行和审查调查。

本地
Python
Cryo MCP Server

Cryo MCP Server

一个API服务器,实现了模型补全协议(MCP),用于Cryo区块链数据提取,允许用户通过任何兼容MCP的客户端查询以太坊区块链数据。

本地
Python