MCP Server Tutorial

MCP Server Tutorial

cthuaung

研究与数据
访问服务器

README

MCP服务器教程

本仓库包含一个使用 FastMCP 构建的简单 MCP (模型上下文协议) 服务器。该服务器提供各种数学运算作为工具,可以通过 MCP 协议使用。

功能特性

  • 基本算术运算(加法、减法、乘法、除法)

  • 高级数学函数:

    • 幂运算
    • 平方根
    • 立方根
    • 阶乘
    • 对数
    • 三角函数(sin、cos、tan)
    • 求余
  • 动态问候资源

前提条件

  • Python 3.8 或更高版本
  • FastMCP 库

安装

  1. 克隆本仓库
  2. 创建并激活虚拟环境:
    uv venv
    source venv/bin/activate  # 在 Windows 上:venv\Scripts\activate
    
  3. 安装依赖:
    uv install fastmcp
    

使用方法

运行服务器

使用以下命令运行服务器:

python main.py

服务器默认使用 SSE (服务器发送事件) 传输,允许您使用 MCP Inspector 连接。

使用 MCP Inspector 连接

  1. 打开 MCP Inspector
npx @modelcontextprotocol/inspector

  1. 选择 SSE 传输类型
  2. 连接到服务器 URL (通常是 http://localhost:8000/sse)
  3. 现在您可以与服务器中定义的数学工具和资源进行交互

可用工具

  • add(a, b): 将两个数字相加
  • subtract(a, b): 将两个数字相减
  • multiply(a, b): 将两个数字相乘
  • divide(a, b): 将两个数字相除
  • power(a, b): 计算 a 的 b 次方
  • sqrt(a): 计算一个数的平方根
  • cbrt(a): 计算一个数的立方根
  • factorial(a): 计算一个数的阶乘
  • log(a): 计算一个数的自然对数
  • remainder(a, b): 计算 a 除以 b 的余数
  • sin(a): 计算一个数的正弦值
  • cos(a): 计算一个数的余弦值
  • tan(a): 计算一个数的正切值

可用资源

  • greeting://{name}: 返回给定名称的个性化问候语

修改服务器

您可以按照 main.py 中的模式添加更多工具和资源:

  1. 要添加新工具,请使用 @mcp.tool() 装饰器
  2. 要添加新资源,请使用 @mcp.resource() 装饰器

传输选项

FastMCP 支持两种传输协议:

  • stdio: 标准输入/输出(基于终端)
  • sse: 服务器发送事件(基于浏览器,与 MCP Inspector 兼容)

要更改传输协议,请修改 mcp.run() 调用中的 transport 参数。

推荐服务器

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