Obsidian语义MCP服务器是一个针对Obsidian进行语义优化和AI优化的MCP服务器,它将20种工具整合为5种智能操作,并提供上下文工作流提示,能有效提升AI代理对Obsidian操作的理解和使用效率。
这个MCP服务器让我们在将AI与Obsidian集成方面积累了宝贵经验。我们运用这些见解创建了 Obsidian MCP插件,它具有以下优势:
npm install -g obsidian-semantic-mcp
或者直接使用npx(推荐):
npx obsidian-semantic-mcp
在npm上查看:https://www.npmjs.com/package/obsidian-semantic-mcp
安装Obsidian插件:
配置Claude桌面版:
在Claude桌面版配置中会自动使用npx命令。将以下内容添加到Claude桌面版配置中(在macOS上,通常位于 ~/Library/Application Support/Claude/claude_desktop_config.json):
{
"mcpServers": {
"obsidian": {
"command": "npx",
"args": ["-y", "obsidian-semantic-mcp"],
"env": {
"OBSIDIAN_API_KEY": "your-api-key-here",
"OBSIDIAN_API_URL": "https://127.0.0.1:27124",
"OBSIDIAN_VAULT_NAME": "your-vault-name"
}
}
}
}
传统的MCP服务器提供了许多细粒度的工具(20多种),这可能会让AI代理不知所措,并导致工具选择效率低下。我们的语义方法具有以下特点:
vault - 文件和文件夹操作
list、read、create、update、delete、search、fragmentsedit - 智能内容编辑
window(模糊匹配)、append、patch、at_line、from_bufferview - 内容查看和导航
window(带上下文)、open_in_obsidianworkflow - 获取引导建议
suggestsystem - 系统操作
info、commands、fetch_webfetch_web 用于获取网页内容并将其转换为markdown格式(仅使用 url 参数)无需在 get_vault_file、get_active_file、read_file_content 等操作中进行选择,你只需使用:
{
"operation": "vault",
"action": "read",
"params": {
"path": "daily-notes/2024-01-15.md"
}
}
响应中会包含智能工作流提示:
{
"result": { /* 文件内容 */ },
"workflow": {
"message": "读取文件:daily-notes/2024-01-15.md",
"suggested_next": [
{
"description": "编辑此文件",
"command": "edit(action='window', path='daily-notes/2024-01-15.md', ...)",
"reason": "对内容进行更改"
},
{
"description": "跟随链接笔记",
"command": "vault(action='read', path='{linked_file}')",
"reason": "探索相关知识"
}
]
}
}
系统会跟踪上下文令牌,以提供相关建议:
[[链接]] 的文件后,建议跟随这些链接window 编辑操作在尝试编辑之前会自动缓冲新内容。如果编辑失败或你想对其进行细化,可以从缓冲区中检索:
{
"operation": "edit",
"action": "from_buffer",
"params": {
"path": "notes/meeting.md"
}
}
语义编辑器使用模糊匹配来查找和替换内容:
{
"operation": "edit",
"action": "window",
"params": {
"path": "daily/2024-01-15.md",
"oldText": "meting notes", // 拼写错误会进行模糊匹配
"newText": "meeting notes",
"fuzzyThreshold": 0.8
}
}
针对特定的文档结构进行操作:
{
"operation": "edit",
"action": "patch",
"params": {
"path": "projects/todo.md",
"operation": "append",
"targetType": "heading",
"target": "## In Progress",
"content": "- [ ] New task"
}
}
系统在读取文件时会自动使用智能片段检索,在保持相关性的同时显著减少令牌消耗:
{
"operation": "vault",
"action": "read",
"params": {
"path": "large-document.md"
}
}
返回相关片段而非整个文件:
{
"result": {
"content": [
{
"id": "file:large-document.md:frag0",
"content": "Most relevant section...",
"score": 0.95,
"lineStart": 145,
"lineEnd": 167
}
],
"fragmentMetadata": {
"totalFragments": 5,
"strategy": "adaptive",
"originalContentLength": 135662
}
}
}
片段搜索策略:
你可以在整个保险库中显式搜索片段:
{
"operation": "vault",
"action": "fragments",
"params": {
"query": "project roadmap timeline",
"maxFragments": 10,
"strategy": "proximity"
}
}
需要时,可使用以下方式检索完整文件:
{
"operation": "vault",
"action": "read",
"params": {
"path": "document.md",
"returnFullFile": true
}
}
语义工作流提示在 src/config/workflows.json 中定义,可以根据你的工作流偏好进行自定义。
片段检索系统在读取文件时会自动激活,以节省令牌。你可以控制此行为:
returnFullFile: true 参数获取完整内容adaptive 用于关键字匹配(1 - 2个单词的查询)proximity 用于查找相关术语相邻出现的情况(3 - 5个单词的查询)semantic 用于概念性分块(较长的查询)操作失败时,语义界面会提供智能恢复提示:
{
"error": {
"code": "FILE_NOT_FOUND",
"message": "File not found: daily/2024-01-15.md",
"recovery_hints": [
{
"description": "创建此文件",
"command": "vault(action='create', path='daily/2024-01-15.md')"
},
{
"description": "搜索类似文件",
"command": "vault(action='search', query='2024-01-15')"
}
]
}
}
如果存在 .env 文件,服务器会自动从该文件中加载环境变量。变量的设置优先级如下:
.env 文件.env 文件必需变量:
OBSIDIAN_API_KEY - 来自本地REST API插件的API密钥可选变量:
OBSIDIAN_API_URL - API URL(默认:https://localhost:27124)
OBSIDIAN_VAULT_NAME - 用于上下文的保险库名称示例 .env 文件:
OBSIDIAN_API_KEY=your-api-key-here
OBSIDIAN_API_URL=http://127.0.0.1:27123
OBSIDIAN_VAULT_NAME=MyVault
PATCH操作(patch_active_file 和 patch_vault_file)允许进行复杂的内容操作:
目标类型:
heading - 使用 "Heading 1::Subheading" 等路径针对特定标题下的内容block - 针对特定的块引用frontmatter - 针对前置元数据字段操作:
append - 在目标之后添加内容prepend - 在目标之前添加内容replace - 替换目标内容示例:在特定标题下追加内容:
{
"operation": "append",
"targetType": "heading",
"target": "Daily Notes::Today",
"content": "- New task added"
}
语义系统由以下部分组成:
src/semantic/router.ts) - 将操作路由到处理程序src/semantic/state-tokens.ts) - 跟踪上下文状态src/config/workflows.json) - 定义提示和建议src/utils/) - 共享功能,如文件读取和模糊匹配项目包含了针对语义系统的全面Jest测试:
npm test # 运行所有测试
npm test semantic-router # 测试路由逻辑
npm test semantic-tools # 测试集成
本项目采用MIT许可证。
欢迎贡献代码!感兴趣的领域包括:
workflows.json 中添加更多工作流模式