Mtu API-DOC
首页应用对话
首页应用对话
WeChat ID:F25F91
  1. 快速上手
  • Mtu API简介
  • Model-Studio-Pricing模型列表价格
  • Model限时免费模型列表
  • 1206更新(接入纯搜索baidu接口)
  • 1204模型更新Mistral-Large-3(675B)
  • 1120模型更新Jina DeepSearch v1
  • 1119模型更新列表Gemini 3 API
  • 1116模型更新列表GPT-5.1系列
  • 1114模型更新列表
  • 1106模型更新列表
  • 1021模型更新列表
  • 1013模型更新列表
  • 1003模型更新列表
  • 0922模型更新列表
  • Migrate to the Responses API
  • GPT-5-codex API上线 0924更新
  • OpenAI Web search 网络搜索
  • Using tools OpenAI官方文档
  • Chat
    • Create chat completion
    • List chat completions
    • Get chat completion
    • Update chat completion metadata
    • Delete chat completion
    • Get chat messages
  • Images
    • Create image
    • Create image edit
    • Create image variation
  • Audio
    • Create speech
    • Create transcription
    • Create translation
  • Embeddings
    • Create embeddings
  • Moderations
    • Create moderation
  • Files
    • Upload file
    • List files
    • Retrieve file
    • Delete file
    • Retrieve file content
  • Models
    • List models
    • Retrieve model
    • Delete a fine-tuned model
  • MCP开发
    • MCP开始使用
      • 简介
      • 示例 Servers
      • 示例 Clients
      • 快速上手
        • 服务器开发
        • 客户端开发
        • Claude 桌面版开发
    • 教程
      • 使用 LLMs 构建 MCP
      • 调试 Debugging
      • 调试器 Inspector
    • 概念
      • 核心架构
      • 资源 Resources
      • 提示词 Prompts
      • 工具 Tools
      • 采样 Sampling
      • 根 Roots
      • 传输 Transports
    • 开发
      • 新计划
      • 规划
      • 贡献
  • OpenAI 项目
    • 介绍
    • 项目说明
    • 导言
    • 身份验证
    • 发出请求
    • 参数详情
    • 聊天(Chat)
      • Chat Completions 对象
      • Chat Completions 对象块
      • 创建 Chat Completions
    • 音频(Audio)
      • 创建语音
      • 创建转录
      • 创建翻译
    • 自动补全(Completions)
      • Completions 对象
      • 创建 Completions
    • 嵌入(Embeddings)
      • 嵌入对象
      • 创建嵌入
    • 微调(Fine-tuning)
      • 微调作业对象
      • 微调作业事件对象
      • 创建微调作业
      • 列出微调作业
      • 检索微调作业
      • 取消微调
      • 列出微调事件
    • 图像(Images)
      • README
      • 图像对象
      • 创建图像
      • 创建图片编辑
      • 创建图像变体
    • 模型(Models)
      • 模型对象
      • 列出模型
      • 检索模型
      • 删除微调模型
    • 文件(Files)
      • README
      • 文件对象
      • 列出文件
      • 上传文件
      • 删除文件
      • 检索文件
      • 检索文件内容
    • 审查(Moderations)
      • 调节对象
      • 创建内容审核
    • 助手测试版(AssistantsBeta)
      • 辅助对象
      • 辅助文件对象
      • 创建助手
      • 检索助手
      • 修改助手
      • 删除助手
      • 列出助手
      • 创建辅助文件
      • 检索助手文件
      • 删除辅助文件
      • 列出助手文件
    • 线程(Threads)
      • 线程对象
      • 创建线程
      • 检索线程
      • 修改线程
      • 删除话题
    • 留言(Messages)
      • 消息对象
      • 消息文件对象
      • 创建消息
      • 检索消息
      • 修改留言
      • 列出消息
      • 检索消息文件
      • 列出消息文件
    • 运行(Runs)
      • 运行对象
      • 运行步骤对象
      • 创建运行
      • 检索运行
      • 修改运行
      • 列表运行
      • 提交工具输出以运行
      • 取消运行
      • 创建线程并运行
      • 检索运行步骤
      • 列出运行步骤
    • 已弃用-音频(Audio)
      • 创建转录
      • 创建翻译
  • 通义千问 项目
    • 首次调用通义千问API
    • 文本生成
      • 深度思考(QwQ)
        • 深度思考(QwQ)概括
        • 快速开始
        • 多轮对话
      • 长上下文
        • 通过file-id传入文档信息
          • 简单示例
          • 传入多文档
          • 追加文档
        • 通过纯文本传入信息
          • 简单示例
          • 传入多文档
          • 追加文档
        • 通过JSON字符串传入文档信息
          • 简单示例
          • 传入多文档
          • 追加文档
      • 翻译能力
        • Qwen-MT模型
        • 支持的语言
        • 简单示例
        • 流式输出
        • 术语干预翻译
        • 使用翻译记忆
        • 领域提示
      • 数学能力
        • 模型概览
        • 示例代码
      • 代码能力
        • 模型概览
        • 简单示例
        • 代码补全
        • 根据前缀和后缀生成中间内容
      • 多轮对话
        • 开始使用
      • 流式输出(Stream)
        • 概述
        • 开始使用
      • 工具调用(Function Calling)
        • 概述
      • 结构化输出(Json Mode)
        • 支持的模型
        • 开始使用
      • 前缀续写(Partial Mode)
        • 支持的模型
        • 开始使用
      • 批量推理(Batch)
        • 概述
      • 上下文缓存(Context Cache)
        • 概述
    • 视觉理解
      • 全模态(Qwen-Omni )
        • 概述
        • 开始使用
        • 图片+文本输入
        • 音频+文本输入
        • 视频+文本输入
        • 多轮对话
  • Claude code 部署教程
    • Claude code 部署教程接入MTUAPI
    • Claude Code Router 配置指南
  • 数据模型
    • Schemas
      • ChatCompletionRequest
      • ChatCompletionObject
      • EmbeddingsRequest
      • ChatMessage
      • ImageCreateRequest
      • ModerationsRequest
      • FileObject
  1. 快速上手

客户端开发

开始构建您自己的客户端,该客户端可以与所有 MCP 服务器集成。
在本教程中,您将学习如何构建一个由 LLM 驱动的聊天机器人客户端,该客户端可以连接到 MCP 服务器。如果您已经完成了服务器快速入门,它将引导您完成构建第一个服务器的基础知识,这对您有所帮助。

Python#

您可以在此处找到本教程的完整代码。

系统要求#

在开始之前,请确保您的系统满足以下要求:
Mac 或 Windows 电脑
已安装最新 Python 版本
已安装最新版本的 uv

设置您的环境#

首先,使用 uv 创建一个新的 Python 项目:

设置您的 API 密钥#

您需要从 Anthropic 控制台 获取 Anthropic API 密钥。
创建一个 .env 文件来存储它:
将您的密钥添加到 .env 文件:
将 .env 添加到您的 .gitignore:
请务必保护好您的 ANTHROPIC_API_KEY!

创建客户端#

基本客户端结构#

首先,让我们设置我们的导入并创建基本客户端类:

服务器连接管理#

接下来,我们将实现连接到 MCP 服务器的方法:

查询处理逻辑#

现在,让我们添加用于处理查询和处理工具调用的核心功能:

交互式聊天界面#

现在,我们将添加聊天循环和清理功能:

主入口点#

最后,我们将添加主执行逻辑:
您可以在此处找到完整的 client.py 文件。

关键组件解释#

1. 客户端初始化#

MCPClient 类使用会话管理和 API 客户端进行初始化
使用 AsyncExitStack 进行适当的资源管理
配置 Anthropic 客户端以进行 Claude 交互

2. 服务器连接#

支持 Python 和 Node.js 服务器
验证服务器脚本类型
设置适当的通信通道
初始化会话并列出可用工具

3. 查询处理#

维护对话上下文
处理 Claude 的响应和工具调用
管理 Claude 和工具之间的消息流
将结果组合成一个连贯的响应

4. 交互式界面#

提供一个简单的命令行界面
处理用户输入并显示响应
包括基本的错误处理
允许正常退出

5. 资源管理#

正确清理资源
错误处理连接问题
正常的关闭程序

常见的自定义点#

1.
工具处理
修改 process_query() 以处理特定工具类型
为工具调用添加自定义错误处理
实现特定于工具的响应格式
2.
响应处理
自定义工具结果的格式化方式
添加响应过滤或转换
实现自定义日志记录
3.
用户界面
添加 GUI 或 Web 界面
实现丰富的控制台输出
添加命令历史记录或自动完成

运行客户端#

要使用任何 MCP 服务器运行您的客户端:
如果您正在继续服务器快速入门中的天气教程,您的命令可能如下所示:python client.py .../weather/src/weather/server.py
客户端将:
1.
连接到指定的服务器
2.
列出可用的工具
3.
启动一个交互式聊天会话,您可以在其中:
输入查询
查看工具执行
获取 Claude 的响应
如果连接到服务器快速入门中的天气服务器,则它应如下所示:
img

工作原理#

当您提交查询时:
1.
客户端从服务器获取可用工具的列表
2.
您的查询与工具描述一起发送给 Claude
3.
Claude 决定要使用哪些工具(如果有)
4.
客户端通过服务器执行任何请求的工具调用
5.
结果被发送回 Claude
6.
Claude 提供自然语言响应
7.
响应将显示给您

最佳实践#

1.
错误处理
始终将工具调用包装在 try-catch 块中
提供有意义的错误消息
优雅地处理连接问题
2.
资源管理
使用 AsyncExitStack 进行适当的清理
完成后关闭连接
处理服务器断开连接
3.
安全
将 API 密钥安全地存储在 .env 中
验证服务器响应
对工具权限保持谨慎

故障排除#

服务器路径问题#

仔细检查您的服务器脚本路径是否正确
如果相对路径不起作用,请使用绝对路径
对于 Windows 用户,请确保在路径中使用正斜杠 (/) 或转义的反斜杠 ()
验证服务器文件是否具有正确的扩展名(Python 为 .py,Node.js 为 .js)
正确路径用法的示例:

响应时间#

第一个响应可能需要长达 30 秒才能返回
这是正常的,并且发生在:
服务器初始化时
Claude 处理查询时
正在执行工具时
后续响应通常更快
在此初始等待期间不要中断该过程

常见错误消息#

如果您看到:
FileNotFoundError:检查您的服务器路径
Connection refused:确保服务器正在运行并且路径正确
Tool execution failed:验证是否已设置该工具的所需环境变量
Timeout error:考虑增加客户端配置中的超时时间

扫码加入 Mtu api 微信交流群

获得 Mtu api 使用上的任何帮助,效率得到大幅提升,技术客服WeChat:F25F91

扫码关注公众号
修改于 2025-09-12 09:50:17
上一页
服务器开发
下一页
Claude 桌面版开发
Built with