MCP Development Framework
hybrid server
The server is able to function both locally and remotely, depending on the configuration or use case.
Integrations
Supports loading environment variables from .env files for server configuration, including port, host, debug mode, and custom User-Agent settings.
Provides containerized deployment through Docker Compose, allowing for easier setup and management of the MCP server environment.
Supports contribution workflows through GitHub, including forking repositories, creating feature branches, and submitting pull requests.
MCP开发框架
一个强大的MCP(Model Context Protocol)开发框架,用于创建与大语言模型交互的自定义工具。该框架提供了一套完整的工具集,可以轻松地扩展Cursor IDE的功能,实现网页内容获取、文件处理(PDF、Word、Excel)以及AI对话等高级功能。
主要功能
本框架提供了以下核心功能:
1. 综合文件处理
使用file
工具可以自动识别文件类型并选择合适的处理方式,支持PDF、Word和Excel文件。
- 用法:
file /path/to/document
- 支持格式:
- PDF文件 (.pdf)
- Word文档 (.doc, .docx)
- Excel文件 (.xls, .xlsx, .xlsm)
- 参数:
file_path
- 文件的本地路径 - 返回: 根据文件类型返回相应的处理结果
2. PDF文档处理
使用pdf
工具可以处理PDF文档,支持两种处理模式:
- 用法:
pdf /path/to/document.pdf [mode]
- 参数:
file_path
- PDF文件的本地路径mode
- 处理模式(可选):quick
- 快速预览模式,仅提取文本内容full
- 完整解析模式,提取文本和图片内容(默认)
- 返回:
- 快速预览模式:文档的文本内容
- 完整解析模式:文档的文本内容和图片
3. Word文档解析
使用word
工具可以解析Word文档,提取文本、表格和图片信息。
- 用法:
word /path/to/document.docx
- 功能: 解析Word文档并提取文本内容、表格和图片信息
- 参数:
file_path
- Word文档的本地路径 - 返回: 文档的文本内容、表格和图片信息
- 特点: 使用python-docx库提供高质量的文本和表格提取
4. Excel文件处理
使用excel
工具可以解析Excel文件,提供完整的表格数据和结构信息。
- 用法:
excel /path/to/spreadsheet.xlsx
- 功能: 解析Excel文件的所有工作表
- 参数:
file_path
- Excel文件的本地路径 - 返回:
- 文件基本信息(文件名、工作表数量)
- 每个工作表的详细信息:
- 行数和列数
- 列名列表
- 完整的表格数据
- 特点:
- 使用pandas和openpyxl提供高质量的表格数据处理
- 支持多工作表处理
- 自动处理数据类型转换
5. 网页内容获取
使用url
工具可以获取任何网页的内容。
- 用法:
url https://example.com
- 参数:
url
- 要获取内容的网站URL - 返回: 网页的文本内容
- 特点:
- 完整的HTTP错误处理
- 超时管理
- 自动编码处理
6. MaxKB AI对话
使用maxkb
工具可以与MaxKB API进行交互,实现智能对话功能。
- 用法:
maxkb "您的问题或指令"
- 功能: 发送消息到MaxKB API并获取AI回复
- 参数:
message
- 要发送的消息内容(必需)re_chat
- 是否重新开始对话(可选,默认false)stream
- 是否使用流式响应(可选,默认true)
- 返回: AI的回复内容
- 特点:
- 支持流式响应
- 自动重试机制
- 完整的错误处理
- 60秒超时保护
- 保持连接配置优化
技术特点
本框架采用了多种技术来优化文件处理性能:
- 智能文件类型识别
- 自动根据文件扩展名选择合适的处理工具
- 提供统一的文件处理接口
- 高效的文档处理
- PDF处理:支持快速预览和完整解析两种模式
- Word处理:精确提取文本、表格和图片
- Excel处理:高效处理大型表格数据
- 内存优化
- 使用临时文件管理大型文件
- 自动清理临时资源
- 分块处理大型文档
- 错误处理
- 完整的异常捕获和处理
- 详细的错误信息反馈
- 优雅的失败处理机制
项目结构
本框架采用模块化设计,便于扩展和维护:
开发指南
如何开发新工具
- 在
tools
目录下创建一个新的Python文件,如your_tool.py
- 导入必要的依赖和基类
- 创建一个继承自
BaseTool
的工具类 - 使用
@ToolRegistry.register
装饰器注册工具 - 实现工具的
execute
方法
工具模板示例
部署指南
环境变量配置
在.env
文件中配置以下环境变量:
本地目录挂载
框架支持将本地目录挂载到容器中,以便工具可以访问本地文件。配置方法:
- 在
.env
文件中设置HOST_MOUNT_SOURCE
和HOST_MOUNT_TARGET
环境变量 HOST_MOUNT_SOURCE
是你本地机器上的目录路径HOST_MOUNT_TARGET
是容器内的挂载路径(默认为/host_files
)
使用工具时,可以直接引用本地文件路径,框架会自动将其转换为容器内的路径。例如:
这样,你就可以在不修改工具代码的情况下,轻松访问本地文件。
Docker部署(推荐)
- 初始设置:
- 使用Docker Compose:
- 访问服务:
- SSE端点: http://localhost:8000/sse
- Cursor IDE配置:
- 设置 → 功能 → 添加MCP服务器
- 类型: "sse"
- URL:
http://localhost:8000/sse
传统Python部署
- 安装系统依赖:
- 安装Python依赖:
- 启动服务:
依赖项
主要依赖:
mcp
: Model Context Protocol实现PyMuPDF
: PDF文档处理python-docx
: Word文档处理pandas
和openpyxl
: Excel文件处理httpx
: 异步HTTP客户端anyio
: 异步I/O支持click
: 命令行接口
贡献指南
- Fork仓库
- 创建功能分支 (
git checkout -b feature/amazing-feature
) - 提交更改 (
git commit -m 'Add some amazing feature'
) - 推送到分支 (
git push origin feature/amazing-feature
) - 打开Pull Request
许可证
本项目采用MIT许可证 - 详情请参阅LICENSE文件。