Obsidian CLI MCP Server
Provides tools to manage Obsidian vaults, including reading, writing, searching notes, listing files, and executing Obsidian CLI commands.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@Obsidian CLI MCP Serverlist notes in my inbox folder"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
Obsidian CLI MCP Server
使用 TypeScript 实现的 stdio MCP Server,通过 Obsidian 官方 CLI 为 Claude Code、Codex 等 AI Agent 提供 Vault 操作能力。
本项目不直接读写 Vault 文件,也不通过 shell 拼接命令。所有操作均以参数数组调用 Obsidian CLI,并提供 Vault 锁定、命令权限、超时、输出限制及跨进程串行保护。
功能
查询 Obsidian 及 CLI 状态
列出 Vault 内的文件和文件夹
读取、创建、覆盖、追加和前置写入笔记
搜索笔记及匹配上下文
调用属性、链接、任务、模板、历史、插件和开发者命令
按配置允许删除、
command、eval等高权限操作将 Server 硬锁定到指定 Vault
串行处理多个 Agent 或并发 MCP 请求
调用链如下:
Claude Code / Codex
│ stdio MCP
▼
Obsidian CLI MCP Server
│ FIFO + 跨进程锁
▼
Obsidian.com / obsidian
│ IPC
▼
正在运行的 ObsidianRelated MCP server: Obsidian Knowledge Management MCP Server
前置条件
Node.js 20 或更高版本
Obsidian 1.12.7 或更高版本的安装器
在 Obsidian 的“设置 → 常规”中启用“命令行接口”
调用时保持 Obsidian 桌面端运行
目标 Vault 已由 Obsidian 打开或管理
Windows 使用安装目录中的 Obsidian.com 作为终端重定向器。升级安装器后,应重新启用命令行接口并重启终端。
先验证官方 CLI:
obsidian version
obsidian vaults verbose安装与构建
Set-Location D:\Document\MyMCP\ObsidianCli
npm install
npm run check
npm test
npm run build构建入口为:
D:\Document\MyMCP\ObsidianCli\dist\index.js修改 TypeScript 源码后必须重新执行 npm run build,并重启 MCP 客户端会话。
配置 Claude Code
在 Vault 或 Claude Code 项目根目录创建 .mcp.json。下面是锁定到 Dance 且允许全部 Obsidian CLI 能力的配置:
{
"mcpServers": {
"obsidian-cli": {
"command": "node",
"args": [
"D:\\Document\\MyMCP\\ObsidianCli\\dist\\index.js"
],
"env": {
"OBSIDIAN_CLI_COMMAND": "D:\\Apps\\Common\\Obsidian\\Obsidian.com",
"OBSIDIAN_DEFAULT_VAULT": "Dance",
"OBSIDIAN_LOCKED_VAULT": "Dance",
"OBSIDIAN_CLI_ALLOW_UNSAFE": "true",
"OBSIDIAN_CLI_EXTRA_COMMANDS": "*"
}
}
}
}MCP 配置中的环境变量值必须全部是字符串。特别是应写成 "true",不能写成 JSON 布尔值 true,否则 Claude Code 会忽略整个 Server 配置。
从项目根目录验证:
claude mcp list
claude mcp get obsidian-cli预期状态:
obsidian-cli ... ✓ Connected修改 .mcp.json 或重新构建 Server 后,应退出并重新启动 Claude Code。
配置 Codex
在受信任的项目中创建 .codex/config.toml:
[mcp_servers.obsidian-cli]
command = "node"
args = ['D:\Document\MyMCP\ObsidianCli\dist\index.js']
cwd = 'D:\Workspace\Ob\Dance\Dance'
enabled = true
required = true
startup_timeout_sec = 30
tool_timeout_sec = 60
default_tools_approval_mode = "approve"
[mcp_servers.obsidian-cli.env]
OBSIDIAN_CLI_COMMAND = 'D:\Apps\Common\Obsidian\Obsidian.com'
OBSIDIAN_DEFAULT_VAULT = "Dance"
OBSIDIAN_LOCKED_VAULT = "Dance"
OBSIDIAN_CLI_ALLOW_UNSAFE = "true"
OBSIDIAN_CLI_EXTRA_COMMANDS = "*"Codex 只会为受信任项目加载项目级 .codex/config.toml。修改配置或重新构建后,以目标 Vault 为工作区新建 Codex 线程。
配合项目 Skill
MCP Server 负责提供操作能力,Skill 负责规定 Agent 的知识管理流程。当前 Dance 项目分别使用:
.claude/skills/curate-dance-vault/SKILL.md
.agents/skills/curate-dance-vault/SKILL.mdClaude Code 与 Codex 使用相同 Skill 内容,约束 inbox、atlas、workspace、archive、system 的数据流,并要求优先使用本 MCP,而不是 shell 文件操作。
MCP 工具
工具 | 主要输入 | 用途 |
| 无 | 查询 Obsidian 版本及 CLI 连通性 |
|
| 查询总帮助或指定命令帮助 |
|
| 列出 Vault、文件或文件夹 |
|
| 按 Vault 相对路径读取笔记 |
|
| 创建、追加或前置写入笔记 |
|
| 搜索笔记内容 |
|
| 执行其他允许的 Obsidian CLI 命令 |
obsidian_write_note.mode 支持:
createappendprepend
obsidian_cli 的参数格式:
{
"command": "move",
"parameters": {
"path": "inbox/source.md",
"to": "archive/source.md"
},
"flags": []
}Server 会将 Vault 参数放在命令之前,并将普通参数转换为 key=value。Obsidian 的普通布尔开关使用裸 flag,例如 overwrite、verbose;全局复制选项使用 --copy。
环境变量
环境变量 | 默认值 | 说明 |
|
| CLI 可执行文件名或绝对路径 |
| 未设置 | 工具调用未指定 Vault 时使用的默认值 |
| 未设置 | 将 Server 硬锁定到指定 Vault,并禁止枚举所有 Vault |
|
| 单个进程的执行超时,范围 1–300 秒 |
|
| 单次调用最大输出,最高 10 MiB |
|
| 允许已知高影响命令 |
| 未设置 | 额外命令名,逗号分隔; |
同时设置默认和锁定 Vault 时,两者必须一致,否则 Server 拒绝启动。
推荐的受限配置
OBSIDIAN_DEFAULT_VAULT=Dance
OBSIDIAN_LOCKED_VAULT=Dance
OBSIDIAN_CLI_ALLOW_UNSAFE=false完全信任配置
OBSIDIAN_DEFAULT_VAULT=Dance
OBSIDIAN_LOCKED_VAULT=Dance
OBSIDIAN_CLI_ALLOW_UNSAFE=true
OBSIDIAN_CLI_EXTRA_COMMANDS=*完全信任配置允许 delete、eval、command、插件管理、发布、恢复、主题及开发者命令,但仍不会把输入交给操作系统 shell。eval 和插件命令本身仍可能对 Obsidian 应用或 Vault 产生广泛影响。
安全与并发模型
命令安全
使用
spawn(executable, argv, { shell: false })校验命令、参数名和 flag 格式
默认使用安全命令白名单
高影响命令需要
OBSIDIAN_CLI_ALLOW_UNSAFE=true未知或插件命令需要显式加入额外白名单,或设置
OBSIDIAN_CLI_EXTRA_COMMANDS=*限制进程执行时间和输出大小
Vault 隔离
设置 OBSIDIAN_LOCKED_VAULT 后:
所有未指定 Vault 的命令自动使用锁定值
显式指定其他 Vault 会返回错误
obsidian_list type=vaults和通用vaults命令被禁用
Vault 锁定只约束通过本 Server 执行的命令。高权限的 Obsidian 应用级操作,例如插件安装或 eval,仍需由可信 Agent 使用。
并发保护
Windows Obsidian.com 通过 IPC 与 Obsidian 主进程通信。多个 CLI 进程同时发送消息可能导致主进程 JSON 边界损坏。
Server 使用两层保护:
每个 MCP Server 内部的 FIFO Promise 队列。
临时目录中的跨进程锁,并使用心跳与失效锁恢复。
因此 Claude Code、Codex 和并发 MCP 工具调用会依次访问 Obsidian CLI。直接在终端运行的 obsidian 命令不会经过此锁,Agent 工作期间不要在其他终端并行执行大量 CLI 命令。
故障排查
Claude Code 显示 No MCP servers configured
检查:
Claude Code 是否从包含
.mcp.json的项目根目录启动。.mcp.json是否为有效 JSON。env下所有值是否都是字符串。项目 MCP Server 是否已获准启用。
运行:
claude mcp list
claude mcp get obsidian-cli修改后重启 Claude Code。
Obsidian 主进程出现 Unexpected token ... is not valid JSON
这通常表示 Windows CLI IPC 收到了并发或损坏的消息。处理步骤:
确认已使用包含 FIFO 和跨进程锁的最新构建。
执行
npm run build。完全退出 Claude Code、Codex 和 Obsidian。
先重新启动 Obsidian,再启动 Agent。
不要从其他终端并行运行 Obsidian CLI。
跨进程锁异常退出后会自动恢复失效锁。
CLI 提示找不到 Obsidian
The CLI is unable to find Obsidian.确认:
Obsidian 正在运行
安装器为 1.12.7+
命令行接口已重新启用
MCP 进程与 Obsidian 运行在同一 Windows 用户和会话中
OBSIDIAN_CLI_COMMAND指向正确的Obsidian.com
修改源码后行为没有变化
MCP 客户端运行的是 dist/,不是 src/。执行:
npm run check
npm test
npm run build然后重启 Claude Code/Codex 会话。
开发
npm run dev项目结构:
src/
commands.ts 命令白名单、参数与 flag 构造
config.ts 环境变量解析和 Vault 锁定配置
runner.ts 进程执行、FIFO 与跨进程锁
server.ts MCP 工具注册
index.ts stdio 入口
test/
commands.test.ts
config.test.ts
runner.test.ts
server.test.tsstdio 的标准输出专用于 MCP 协议;Server 日志只能写入标准错误。
验证
npm run check
npm test
npm run build当前测试覆盖:
参数构造与 shell 注入边界
安全、危险及通配命令权限
Vault 锁定配置
CLI 退出码、超时与输出限制
单进程及跨 Runner 串行执行
MCP 工具发现
参考
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/husitao/MCP-ObsidianCli'
If you have feedback or need assistance with the MCP directory API, please join our Discord server