Crates Docs MCP 服务器
一个高性能的 Rust crate 文档查询 MCP 服务器,支持多种传输协议。
特性
- 🚀 高性能: 异步 Rust + LRU 智能缓存
- 📦 多架构 Docker 镜像: 支持
linux/amd64和linux/arm64 - 🔧 多种传输协议: Stdio、HTTP (Streamable HTTP)、SSE
- 📚 完整文档查询: crate 搜索、文档查找、特定项目查询
- 🛡️ 安全可靠: 速率限制、连接池、请求验证
- 📊 健康监控: 内置健康检查和性能监控
快速开始
使用 Docker(推荐)
# 从 Docker Hub 拉取镜像
# 运行容器(默认监听 0.0.0.0:8080)
# 使用自定义配置
Docker Compose
version: '3.8'
services:
crates-docs:
image: kingingwang/crates-docs:latest
ports:
- "8080:8080"
environment:
CRATES_DOCS_HOST: 0.0.0.0
CRATES_DOCS_PORT: 8080
CRATES_DOCS_TRANSPORT_MODE: hybrid
volumes:
- ./config.toml:/app/config.toml:ro
- ./logs:/app/logs
restart: unless-stopped
从源码构建
从 crates.io 安装
MCP 客户端集成
Claude Desktop
编辑配置文件:
- macOS:
~/Library/Application Support/Claude/claude_desktop_config.json - Windows:
%APPDATA%\Claude\claude_desktop_config.json - Linux:
~/.config/Claude/claude_desktop_config.json
Cursor
编辑 ~/.cursor/mcp.json:
Windsurf
编辑 ~/.codeium/windsurf/mcp_config.json:
Cherry Studio
- 打开 Cherry Studio 设置
- 找到
MCP 服务器选项 - 点击
添加服务器 - 填写参数:
| 字段 | 值 |
|---|---|
| 名称 | crates-docs |
| 类型 | STDIO |
| 命令 | /path/to/crates-docs |
| 参数1 | serve --mode stdio |
| 参数2 | --mode |
| 参数3 | stdio |
- 点击保存
注意:将
/path/to/crates-docs替换为实际的可执行文件路径。
HTTP 模式
适合远程访问或网络服务:
客户端配置:
MCP 工具
1. lookup_crate - 查找 Crate 文档
从 docs.rs 获取完整文档。
| 参数 | 类型 | 必需 | 描述 |
|---|---|---|---|
crate_name |
string | ✅ | Crate 名称,如 serde、tokio |
version |
string | ❌ | 版本号,默认最新 |
format |
string | ❌ | 输出格式:markdown(默认)、text、html |
2. search_crates - 搜索 Crate
从 crates.io 搜索 Rust crate。
| 参数 | 类型 | 必需 | 描述 |
|---|---|---|---|
query |
string | ✅ | 搜索关键词 |
limit |
number | ❌ | 结果数量(1-100),默认 10 |
format |
string | ❌ | 输出格式:markdown、text、json |
3. lookup_item - 查找特定项目
查找 crate 中的特定类型、函数或模块。
| 参数 | 类型 | 必需 | 描述 |
|---|---|---|---|
crate_name |
string | ✅ | Crate 名称 |
item_path |
string | ✅ | 项目路径,如 serde::Serialize |
version |
string | ❌ | 版本号 |
format |
string | ❌ | 输出格式 |
4. health_check - 健康检查
检查服务器和外部服务状态。
| 参数 | 类型 | 必需 | 描述 |
|---|---|---|---|
check_type |
string | ❌ | all、external、internal、docs_rs、crates_io |
verbose |
boolean | ❌ | 详细输出 |
使用示例
了解新 crate
用户: "帮我了解一下 serde"
AI 调用: { "crate_name": "serde" }
查找特定功能
用户: "tokio 怎么创建异步任务?"
AI 调用: { "crate_name": "tokio", "item_path": "tokio::spawn" }
搜索相关 crate
用户: "有什么好用的 HTTP 客户端?"
AI 调用: { "query": "http client", "limit": 10 }
命令行
# 启动服务器
# 生成配置
# 测试工具
配置
配置文件
创建 config.toml:
[]
= "crates-docs"
= "0.0.0.0"
= 8080
= "hybrid"
= ["localhost", "127.0.0.1"]
= ["http://localhost:*"]
[]
= "memory"
= 1000
= 3600
[]
= "info"
= true
= false # 默认仅控制台输出
启用文件日志:设置
enable_file = true并配置file_path可写入日志文件。
环境变量
# 日志配置(默认仅控制台输出)
# 启用文件日志(需可写文件系统)
文件日志:默认禁用。设置
CRATES_DOCS_ENABLE_FILE=true并配置file_path可写入日志文件。
传输协议
| 模式 | 适用场景 | 端点 |
|---|---|---|
stdio |
MCP 客户端集成(推荐) | 标准输入输出 |
http |
网络服务 | POST /mcp |
sse |
向后兼容 | GET /sse |
hybrid |
网络服务(推荐) | /mcp + /sse |
MCP 端点
POST /mcp- MCP Streamable HTTP 端点GET /sse- MCP SSE 端点
注意:这些是 MCP 协议端点,不是普通的 HTTP API。需要使用 MCP 客户端进行交互。
部署
Docker
# 使用预构建镜像
# 或使用特定版本
Systemd
创建 /etc/systemd/system/crates-docs.service:
[Unit]
Description=Crates Docs MCP Server
After=network.target
[Service]
Type=simple
User=crates-docs
WorkingDirectory=/opt/crates-docs
ExecStart=/opt/crates-docs/crates-docs serve --config /etc/crates-docs/config.toml
Restart=on-failure
[Install]
WantedBy=multi-user.target
开发
# 构建
# 测试
# 代码检查
故障排除
端口被占用
网络问题
日志
日志文件:./logs/crates-docs.log
[]
= "debug"
许可证
MIT License
贡献
欢迎 Issue 和 Pull Request!
- Fork 仓库
- 创建分支 (
git checkout -b feature/amazing-feature) - 提交更改 (
git commit -m 'Add amazing feature') - 推送分支 (
git push origin feature/amazing-feature) - 创建 Pull Request
致谢
- rust-mcp-sdk - MCP SDK
- docs.rs - Rust 文档服务
- crates.io - Rust 包注册表
支持
- Issues
- Email: kingingwang@foxmail.com