MCP 实战:实现server端,并在cline调用

本文动手实现一个简单的MCP服务端的编写,并通过MCP Server 实现成绩查询的调用。

一、配置环境

安装mcp和uv, mcp要求python版本 Python >=3.10;

复制代码
pip  install   mcp

pip install    uv

二、编写并启用服务端

复制代码
# get_score.py
from mcp.server.fastmcp import FastMCP
from typing import Dict, Union
import asyncio
# 创建MCP服务器实例
mcp = FastMCP("ScoreQueryServer")

# 学生成绩数据
scores: Dict[str, int] = {
    "语文": 85,
    "数学": 90,
    "英语": 88,
}

@mcp.tool()
async def get_score(subject: str) -> Union[str, Dict[str, int]]:
    """
    查询指定科目的分数
    
    Args:
        subject: 要查询的科目名称
        
    Returns:
        如果科目存在,返回包含分数的字典
        如果科目不存在,返回错误信息字符串
    """
    if subject in scores:
        return {subject: scores[subject]}
    return f"错误:没有找到科目 '{subject}' 的成绩"

if __name__ == "__main__":
    try:
        print("成绩查询服务正在启动,等待连接...")
        mcp.run(transport='stdio')
    except Exception as e:
        print(f"服务器启动失败: {str(e)}")

此处使用简单的get_score函数模拟。

复制代码
python   get_score.py

使用上述命令运行代码

在vscode插件中安装cline,具体操作参考简单谈谈很火的MCP( Model Context Protocol,模型上下文协议)-CSDN博客

三、使用cline调用服务端

将下面的内容粘贴

复制代码
"score": {
      "autoApprove": [],
      "disabled": false,
      "timeout": 60,
      "command": "python",
      "args": [
        "xxx/xxx/get_score.py"
      ],
      "env": {},
      "transportType": "stdio"
    }
  }

"xxx/xxx/get_score.py"应该为自己本地的绝对路径。

当左侧的指示灯为绿色时,表示连接成功。

在cline中输入"语文成绩是多少"。LLM会调用该工具进行查询。

"The Chinese language (语文) score is 85."为LLM查询到的结果。

四、本地调试到服务端

复制代码
mcp  dev  get_score.py

输入y,回车。出现下面的内容表示启用成功。进入http://127.0.0.1:6274

点击左侧的connect进行连接。

点击get_score这个Tool.

输出结果,表示server没有问题。

通过学习MCP服务端的编写,可以提高对MCP的深入理解。

官网MCP服务端代码。For Server Developers - Model Context Protocol

相关推荐
碳基沙盒17 小时前
OpenClaw 多 Agent 配置实战指南
运维
Sinclair3 天前
简单几步,安卓手机秒变服务器,安装 CMS 程序
android·服务器
Rockbean4 天前
用40行代码搭建自己的无服务器OCR
服务器·python·deepseek
蝎子莱莱爱打怪4 天前
Centos7中一键安装K8s集群以及Rancher安装记录
运维·后端·kubernetes
茶杯梦轩4 天前
CompletableFuture 在 项目实战 中 创建异步任务 的核心优势及使用场景
服务器·后端·面试
海天鹰4 天前
【免费】PHP主机=域名+解析+主机
服务器
DianSan_ERP4 天前
电商API接口全链路监控:构建坚不可摧的线上运维防线
大数据·运维·网络·人工智能·git·servlet
呉師傅4 天前
火狐浏览器报错配置文件缺失如何解决#操作技巧#
运维·网络·windows·电脑
不是二师兄的八戒4 天前
Linux服务器挂载OSS存储的完整实践指南
linux·运维·服务器
芝士雪豹只抽瑞克五4 天前
Nginx 高性能Web服务器笔记
服务器·nginx