Fromsko/siyuan-mcp-server
If you are the rightful owner of siyuan-mcp-server and would like to certify it and/or have it hosted online, please leave a comment on the right or send an email to dayong@mcphub.com.
The SiYuan Note MCP Server integrates SiYuan Note with AI clients like Claude Desktop using the Model Context Protocol.
📖 项目介绍
思源笔记 MCP 服务器 是一个专为 思源笔记 设计的 Model Context Protocol 服务器实现。通过此服务器,您可以在 Claude Desktop 等支持 MCP 的 AI 客户端中直接操作思源笔记,实现笔记管理、内容搜索、文档编辑等功能的无缝集成。
✨ 主要特性
- 🔗 原生集成 - 在 AI 助手中直接操作思源笔记
- 📚 功能完整 - 支持笔记本、文档、块级操作的全套功能
- 🔍 智能搜索 - 全文检索、SQL 查询、标签搜索等多种搜索方式
- 🛠️ 开发者友好 - TypeScript 编写,提供完整的类型定义和 API 文档
- 📦 简单部署 - 支持 npm、Docker 多种安装方式
- 🔒 安全认证 - 基于 Token 的安全认证机制
🚀 快速开始
📋 环境要求
- Node.js >= 18.0.0
- 思源笔记 正在运行且已开启 API 服务
- Claude Desktop 或其他支持 MCP 的客户端
- 思源笔记 API Token(设置 → 关于 → API token)
📥 安装方式
1. 全局安装(推荐)
# 使用 npm
npm install -g @fromsko/siyuan-mcp-server
# 使用 pnpm
pnpm add -g @fromsko/siyuan-mcp-server
2. 直接使用(无需安装)
npx @fromsko/siyuan-mcp-server
3. Docker 方式
docker pull fromsko/siyuan-mcp-server
⚙️ 快速配置
环境变量设置
| 环境变量 | 必需 | 说明 |
|---|---|---|
SIYUAN_TOKEN | ✅ | 思源笔记 API 令牌,用于身份验证 |
在 Claude Desktop 中配置
在 Claude Desktop 配置文件中添加以下内容:
{
"mcpServers": {
"siyuan": {
"command": "npx",
"args": ["-y", "@fromsko/siyuan-mcp-server"],
"env": {
"SIYUAN_TOKEN": "your-api-token"
}
}
}
}
配置文件位置:
- macOS:
~/Library/Application Support/Claude/claude_desktop_config.json - Windows:
%APPDATA%\Claude\claude_desktop_config.json
命令行直接使用
# 全局安装后直接使用
SIYUAN_TOKEN=your-token siyuan-mcp-server
# 使用 npx(无需安装)
SIYUAN_TOKEN=your-token npx @fromsko/siyuan-mcp-server
# Docker 运行
docker run --rm -i \
-e SIYUAN_TOKEN=your-token \
fromsko/siyuan-mcp-server
📚 功能与使用
🔧 可用工具
本 MCP 服务器提供以下核心功能:
| 功能类别 | 描述 | 主要命令 |
|---|---|---|
| 📓 笔记本管理 | 创建、删除、重命名笔记本 | notebook.* |
| 📄 文档操作 | 创建、编辑、删除文档 | filetree.* |
| 🧱 块级操作 | 插入、更新、删除内容块 | block.* |
| 🔍 搜索功能 | 全文搜索、SQL 查询 | search.* |
| 📋 模板系统 | 模板创建和渲染 | template.* |
| 📊 数据查询 | 复杂数据库查询 | sql.* |
💡 使用示例
1. 创建新笔记本
{
"type": "executeCommand",
"params": {
"type": "notebook.createNotebook",
"params": {
"name": "AI 学习笔记"
}
}
}
2. 全文搜索内容
{
"type": "executeCommand",
"params": {
"type": "search.fullTextSearch",
"params": {
"query": "机器学习",
"method": 0
}
}
}
3. 创建带内容的文档
{
"type": "executeCommand",
"params": {
"type": "filetree.createDocWithMd",
"params": {
"notebook": "notebook-id",
"path": "/今日学习总结",
"markdown": "# 今日学习总结\n\n## 主要收获\n\n1. 学习了...\n2. 理解了..."
}
}
}
🆘 获取帮助
获取特定命令的详细帮助信息:
{
"type": "help",
"params": {
"type": "notebook.createNotebook"
}
}
🔧 开发指南
本地开发环境搭建
# 克隆项目
git clone https://github.com/fromsko/siyuan-mcp-server.git
cd siyuan-mcp-server
# 安装依赖
pnpm install
# 开发模式启动
SIYUAN_TOKEN=your-token pnpm dev
# 构建生产版本
pnpm build
# 运行测试
pnpm test
技术栈与要求
- 运行时: Node.js >= 18.0.0
- 语言: TypeScript >= 5.0.0
- 包管理: pnpm(推荐)或 npm
- 框架: @modelcontextprotocol/sdk
- 构建工具: TypeScript Compiler
Docker 开发
# 构建开发镜像
docker build -t siyuan-mcp-server:dev .
# 运行开发容器
docker run --rm -it \
-e SIYUAN_TOKEN=your-token \
-v $(pwd):/app \
siyuan-mcp-server:dev
🐛 问题排查
常见问题解答
❓ 服务器启动失败,提示"缺少 SIYUAN_TOKEN"
请确保正确设置了
SIYUAN_TOKEN环境变量。获取方式:思源笔记 → 设置 → 关于 → API token
❓ 无法连接到思源笔记
请检查以下几点:
- 思源笔记是否正在运行
- API 服务是否已开启(默认端口 6806)
- Token 是否正确且未过期
- 防火墙是否阻止了连接
❓ Claude Desktop 无法识别 MCP 服务器
请尝试以下解决方案:
- 检查配置文件 JSON 格式是否正确
- 重启 Claude Desktop 应用
- 查看 Claude Desktop 日志获取详细错误信息
- 确认 npx 命令可以正常执行
❓ 命令执行失败或返回错误
- 确认思源笔记中存在相应的笔记本或文档
- 检查 Token 权限是否足够
- 查看服务器日志获取详细错误信息
调试模式
启用详细的调试日志:
DEBUG=siyuan-mcp:* SIYUAN_TOKEN=your-token siyuan-mcp-server
日志分析
服务器会输出以下类型的日志:
INFO: 一般信息,如服务启动、连接状态WARN: 警告信息,如参数错误、连接异常ERROR: 错误信息,如 API 调用失败、认证失败
🤝 贡献指南
我们热烈欢迎社区贡献!您可以通过以下方式参与:
如何贡献
- Fork 项目 - 点击右上角的 Fork 按钮
- 创建分支 -
git checkout -b feature/awesome-feature - 提交代码 -
git commit -am 'Add awesome feature' - 推送分支 -
git push origin feature/awesome-feature - 创建 PR - 在 GitHub 上创建 Pull Request
开发规范
- 代码风格: 遵循 TypeScript 严格模式
- 测试覆盖: 为新功能编写单元测试
- 文档更新: 更新相关的 API 文档和使用说明
- 提交规范: 使用清晰的 commit message
报告问题
发现 Bug 或有改进建议?请通过以下方式报告:
- GitHub Issues
- 详细描述问题的复现步骤
- 提供相关的错误日志和环境信息
📜 开源协议
本项目采用 ISC 协议开源,详情请查看 文件。
🔗 相关资源
官方链接
社区与支持
❤️ 特别感谢
- 🌟 原始项目作者 onigeya - 本项目基于其优秀的开源工作进行改进和扩展
- 🙏 思源笔记 团队 - 提供优秀的笔记软件
- 🤖 Anthropic - 推动 MCP 协议发展
- 👥 所有贡献者和用户 - 让项目变得更好
🌟 如果这个项目对您有帮助,请给我们一个 Star!
💻 用 TypeScript 和 ❤️ 精心构建