OpenEdu MCP Server 是一个全面的模型上下文协议(MCP)服务器,旨在为教育工作者提供教育资源并支持课程规划。该服务器与多个教育 API 集成,可让用户访问书籍、文章、定义和研究论文,同时具备智能教育过滤功能和年级适用性评估。
git clone https://github.com/Cicatriiz/openedu-mcp.git
cd openedu-mcp
pip install -r requirements.txt
cp .env.example .env
# 如有需要,使用你偏好的设置编辑 .env 文件
python -m src.main
python run_validation_tests.py
若要进行开发,需安装额外的依赖:
pip install -r requirements-dev.txt
运行测试:
# 单元测试
pytest tests/
# 集成测试
pytest tests/test_integration/
# 性能测试
pytest tests/test_performance.py
格式化代码:
black src tests
isort src tests
教育 MCP 服务器通过四个 API 集成提供 21 + 个 MCP 工具:
search_educational_books根据年级和学科过滤条件搜索教育书籍。
search_educational_books(
query="mathematics",
subject="Mathematics",
grade_level="6-8",
limit=10
)
get_book_details_by_isbn根据 ISBN 获取详细的书籍信息和教育元数据。
get_book_details_by_isbn(
isbn="9780134685991",
include_cover=True
)
search_books_by_subject根据教育学科和课程对齐条件搜索书籍。
search_books_by_subject(
subject="Science",
grade_level="3-5",
limit=10
)
get_book_recommendations为特定年级获取精心挑选的书籍推荐。
get_book_recommendations(
grade_level="9-12",
subject="Physics",
limit=5
)
search_educational_articles使用教育过滤和分析功能搜索维基百科文章。
search_educational_articles(
query="photosynthesis",
grade_level="3-5",
subject="Science",
limit=5
)
get_article_summary获取文章摘要,并包含教育元数据和复杂度分析。
get_article_summary(
title="Solar System",
include_educational_analysis=True
)
get_article_content获取完整的文章内容,并进行教育内容增强。
get_article_content(
title="Photosynthesis",
include_images=True
)
get_featured_article获取维基百科的特色文章,并进行教育分析。
get_featured_article(
date="2024/01/15",
language="en"
)
get_articles_by_subject根据教育学科和年级过滤条件获取文章。
get_articles_by_subject(
subject="Mathematics",
grade_level="6-8",
limit=10
)
get_word_definition获取适合特定年级复杂度的教育词汇定义。
get_word_definition(
word="ecosystem",
grade_level="6-8",
include_pronunciation=True
)
get_vocabulary_analysis分析词汇的复杂度和教育价值。
get_vocabulary_analysis(
word="photosynthesis",
context="plant biology lesson"
)
get_word_examples获取教育性的词汇示例和使用上下文。
get_word_examples(
word="fraction",
grade_level="3-5",
subject="Mathematics"
)
get_pronunciation_guide获取语音信息和发音指南。
get_pronunciation_guide(
word="photosynthesis",
include_audio=True
)
get_related_vocabulary获取同义词、反义词和相关的教育术语。
get_related_vocabulary(
word="democracy",
relationship_type="related",
grade_level="9-12",
limit=10
)
search_academic_papers使用教育相关性过滤条件搜索学术论文。
search_academic_papers(
query="machine learning education",
academic_level="Undergraduate",
subject="Computer Science",
max_results=10
)
get_paper_summary获取论文摘要,并进行教育分析和可访问性评分。
get_paper_summary(
paper_id="2301.00001",
include_educational_analysis=True
)
get_recent_research根据教育学科获取近期的研究论文。
get_recent_research(
subject="Physics",
days=30,
academic_level="High School",
max_results=5
)
get_research_by_level获取适合特定学术水平的研究论文。
get_research_by_level(
academic_level="Graduate",
subject="Mathematics",
max_results=10
)
analyze_research_trends分析研究趋势,以获取教育洞察。
analyze_research_trends(
subject="Artificial Intelligence",
days=90
)
get_server_status获取全面的服务器状态和性能指标。
get_server_status()
本节详细介绍如何通过各种接口与 OpenEdu MCP 服务器进行交互,包括直接标准输入输出、用于工具执行的 HTTP 接口以及用于实时更新的服务器发送事件(Server-Sent Events)接口。
handle_stdio_input)服务器包含一个用于直接命令行或管道输入的工具。
handle_stdio_inputasync def handle_stdio_input(ctx: Context, input_string: str) -> str工具: handle_stdio_input
输入: "your text here"
输出: "Processed: YOUR TEXT HERE"
所有注册的 MCP 工具(包括 handle_stdio_input 和上述 20 + 个工具)都可以通过 HTTP 访问。这允许与各种应用程序和服务进行集成。服务器可能使用 JSON RPC 风格进行这些交互。
POST /mcp(这是支持 JSON RPC 的 FastMCP 服务器的常见约定)POSTContent-Type: application/json{
"jsonrpc": "2.0",
"method": "<工具名称>",
"params": {"参数1": "值1", ...},
"id": "你的请求 ID"
}
handle_stdio_input 的 curl 示例:curl -X POST -H "Content-Type: application/json" \
-d '{"jsonrpc": "2.0", "method": "handle_stdio_input", "params": {"input_string": "hello from http"}, "id": 1}' \
http://localhost:8000/mcp
{
"jsonrpc": "2.0",
"result": "Processed: HELLO FROM HTTP",
"id": 1
}
如果发生错误,result 字段将被 error 对象替换,其中包含 code 和 message。
服务器提供一个 SSE 端点,用于实时通知。这对于需要实时更新服务器发起事件的客户端非常有用。
GET /eventsevent: <事件类型>
data: <事件数据的 JSON 有效负载>
id: <可选的事件 ID>
(注意:空行分隔事件。)
已知事件:
connected:客户端成功连接到 SSE 流时发送一次。
data:{"message": "Successfully connected to SSE stream"}ping:定期发送,作为心跳以保持连接活动并指示服务器健康状况。
data:{"heartbeat": <循环计数>, "message": "ping"}(循环计数递增)error:如果在 SSE 生成流中发生错误,则发送此事件。
data:{"error": "<错误消息>"}使用 JavaScript 的 EventSource 进行连接的示例:
const evtSource = new EventSource("http://localhost:8000/events");
evtSource.onopen = function() {
console.log("Connection to SSE opened.");
};
evtSource.onmessage = function(event) {
// 如果没有匹配到特定事件类型,则使用通用消息处理程序
console.log("通用消息:", event.data);
try {
const parsedData = JSON.parse(event.data);
console.log("解析后的通用数据:", parsedData);
} catch (e) {
// 数据可能不是 JSON 格式
}
};
evtSource.addEventListener("connected", function(event) {
console.log("事件: connected");
console.log("数据:", JSON.parse(event.data));
});
evtSource.addEventListener("ping", function(event) {
console.log("事件: ping");
console.log("数据:", JSON.parse(event.data));
});
evtSource.addEventListener("error", function(event) {
if (event.target.readyState === EventSource.CLOSED) {
console.error("SSE 连接已关闭。", event);
} else if (event.target.readyState === EventSource.CONNECTING) {
console.error("SSE 连接正在重新连接...", event);
} else {
// 流式传输过程中发生错误,可能有可用数据
console.error("SSE 错误:", event);
if (event.data) {
try {
console.error("错误数据:", JSON.parse(event.data));
} catch (e) {
console.error("错误数据(原始):", event.data);
}
}
}
});
curl 进行连接的示例:curl -N -H "Accept:text/event-stream" http://localhost:8000/events
(注意:curl 将保持连接打开,并在事件到达时打印事件。)
你可以将 OpenEdu MCP 服务器与各种 AI 辅助编码工具和 IDE 插件集成。这允许这些工具在你的开发环境中直接利用服务器的教育功能。配置通常涉及告诉编辑器如何启动和与 OpenEdu MCP 服务器进行通信。服务器可通过在项目根目录下运行 python -m src.main 来启动。
以下是一些流行工具的示例配置。你可能需要根据本地设置调整路径(例如,cwd 路径或特定的 Python 环境)。
要将此服务器添加到 Cursor IDE:
Cursor 设置 > MCP。+ 添加新的全局 MCP 服务器。.cursor/mcp.json 文件中(确保 cwd 指向此项目的根目录):{
"mcpServers": {
"openedu-mcp-server": {
"command": "python",
"args": [
"-m",
"src.main"
],
"cwd": "/path/to/your/openedu-mcp" // 替换为实际项目根目录的路径
}
}
}
更多详细信息请参阅 Cursor 文档。
要在 Windsurf(原 Cascade)中设置 MCP:
Windsurf - 设置 > 高级设置 或使用命令面板打开 Windsurf 设置页面。mcp_config.json 中添加 OpenEdu MCP 服务器(确保 cwd 指向此项目的根目录):{
"mcpServers": {
"openedu-mcp-server": {
"command": "python",
"args": [
"-m",
"src.main"
],
"cwd": "/path/to/your/openedu-mcp" // 替换为实际项目根目录的路径
}
}
}
通过 Cline 的 MCP 服务器设置手动将以下 JSON 添加到你的 cline_mcp_settings.json 文件中(确保 cwd 指向此项目的根目录):
{
"mcpServers": {
"openedu-mcp-server": {
"command": "python",
"args": [
"-m",
"src.main"
],
"cwd": "/path/to/your/openedu-mcp" // 替换为实际项目根目录的路径
}
}
}
通过点击 Roo Code 设置中的 编辑 MCP 设置 或使用 VS Code 命令面板中的 Roo Code: 打开 MCP 配置 命令访问 MCP 设置(确保 cwd 指向此项目的根目录):
{
"mcpServers": {
"openedu-mcp-server": {
"command": "python",
"args": [
"-m",
"src.main"
],
"cwd": "/path/to/your/openedu-mcp" // 替换为实际项目根目录的路径
}
}
}
将以下内容添加到你的 claude_desktop_config.json 文件中(确保 cwd 指向此项目的根目录):
{
"mcpServers": {
"openedu-mcp-server": {
"command": "python",
"args": [
"-m",
"src.main"
],
"cwd": "/path/to/your/openedu-mcp" // 替换为实际项目根目录的路径
}
}
}
如果有可用的 Claude 桌面文档,请参阅该文档以获取更多详细信息。
# 查找适合年龄段的书籍
books = await search_educational_books(
query="animals",
grade_level="K-2",
subject="Science"
)
# 获取简单定义
definition = await get_word_definition(
word="habitat",
grade_level="K-2"
)
# 查找教育文章
articles = await search_educational_articles(
query="animal homes",
grade_level="K-2"
)
# 获取数学教科书
books = await search_books_by_subject(
subject="Mathematics",
grade_level="6-8"
)
# 分析词汇复杂度
analysis = await get_vocabulary_analysis(
word="equation",
context="solving math problems"
)
# 查找相关术语
related = await get_related_vocabulary(
word="algebra",
grade_level="6-8"
)
# 获取物理书籍推荐
books = await get_book_recommendations(
grade_level="9-12",
subject="Physics"
)
# 获取详细文章
article = await get_article_content(
title="Quantum mechanics"
)
# 查找可访问的研究论文
papers = await search_academic_papers(
query="climate change",
academic_level="High School"
)
# 查找学术教科书
books = await search_educational_books(
query="calculus",
grade_level="College"
)
# 获取近期研究
research = await get_recent_research(
subject="Computer Science",
academic_level="Graduate"
)
# 分析研究趋势
trends = await analyze_research_trends(
subject="Machine Learning"
)
服务器使用 config/ 目录下的 YAML 配置文件:
# config/default.yaml
server:
name: "openedu-mcp-server"
version: "1.0.0"
education:
grade_levels:
- "K-2"
- "3-5"
- "6-8"
- "9-12"
- "College"
subjects:
- "Mathematics"
- "Science"
- "English Language Arts"
- "Social Studies"
- "Arts"
- "Physical Education"
- "Technology"
apis:
open_library:
rate_limit: 100 # 每分钟请求数
wikipedia:
rate_limit: 200 # 每分钟请求数
dictionary:
rate_limit: 450 # 每小时请求数
arxiv:
rate_limit: 3 # 每秒请求数
可以使用环境变量覆盖配置:
export OPENEDU_MCP_CACHE_TTL=7200
export OPENEDU_MCP_LOG_LEVEL=DEBUG
export OPENEDU_MCP_RATE_LIMIT_WIKIPEDIA=300
教育 MCP 服务器
├── API 层 (FastMCP)
│ ├── 20 + 个 MCP 工具
│ └── 请求/响应处理
├── 服务层
│ ├── 缓存服务 (SQLite)
│ ├── 速率限制服务
│ └── 使用跟踪服务
├── 工具层
│ ├── 开放图书馆工具
│ ├── 维基百科工具
│ ├── 词典工具
│ └── arXiv 工具
├── API 层
│ ├── 开放图书馆 API
│ ├── 维基百科 API
│ ├── 词典 API
│ └── arXiv API
└── 数据层
├── 教育模型
├── 缓存数据库
└── 使用分析
# 单元测试
pytest tests/test_tools/ -v
# 集成测试
pytest tests/test_integration/ -v
# 性能测试
pytest tests/test_performance.py -v
# 真实 API 测试(需要联网)
make validate
pytest --cov=src --cov-report=html
open htmlcov/index.html
make validate
我们实现了全面的真实世界验证测试,以确保服务器在生产环境中的可用性。这些测试针对实时服务而非模拟数据验证功能。
python run_validation_tests.py
该脚本将:
✅ 已完成 - 所有功能已实现
git checkout -b feature/amazing-feature)pytest)git commit -m 'Add amazing feature')git push origin feature/amazing-feature)本项目采用 MIT 许可证。
如有问题、疑问或想要贡献代码,请参考以下方式:
docs/ 目录。OpenEdu MCP Server - 为教育工作者提供智能教育资源发现和课程规划工具。