mcp-duckvault
Provides tools for searching and listing notes in an Obsidian vault using natural language queries, with support for tag filtering and recent note retrieval, returning Obsidian URI links.
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., "@mcp-duckvaultFind notes about machine learning projects"
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.
DuckVault-MCP
DuckVault-MCP is an MCP (Model Context Protocol) server that provides a RAG (Retrieval-Augmented Generation) system for your Obsidian Vault using DuckDB and vector search.
Features
Local Vector Search: Uses
sentence-transformers(intfloat/multilingual-e5-small) for local embeddings.Obsidian URI Links: Includes direct links to open notes in Obsidian from search results.
Incremental Indexing: Uses MD5 hashing to only update modified files.
Real-time Monitoring: Uses
watchdogto index changes as you edit your notes.Progress Indicators: Displays a progress bar during initial indexing for large vaults.
Fast Search: Leverages DuckDB with the
vssextension and HNSW indexing for millisecond-level retrieval.MCP Compatible: Works seamlessly with AI agents like Claude Code or Cursor.
Related MCP server: Obsidian MCP Server
Installation
# Using uv (recommended)
uv tool install mcp-duckvault
# From GitHub directly
uv tool install git+https://github.com/caron14/mcp-obsidian-duckdb.git
# From PyPI (once published)
pip install mcp-duckvaultUsage
Start the MCP server by pointing it to your Obsidian Vault:
duckvault /path/to/your/obsidian/vaultOptions
--db-path: Path to the DuckDB file (default:~/.duckvault/vault.db).--sync-only: Perform a full sync of the vault and exit.-v, --verbose: Enable verbose logging.
CLI Examples
Basic usage:
duckvault /path/to/your/obsidian/vaultCustom database path: Specify a custom location for the DuckDB index file.
duckvault /path/to/your/obsidian/vault --db-path ./vault_index.dbSync only (Headless mode): Index all files and exit without starting the MCP server.
duckvault /path/to/your/obsidian/vault --sync-onlyExample Queries for AI Agents
Once connected, you can interact with your vault using natural language through an AI agent:
Semantic Search: "Find notes about machine learning projects and list the key concepts mentioned."
Filtered Search: "Search for notes about 'meeting' with the tag #work and summarize the action items."
Stay Updated: "What are the most important notes I've worked on in the last 3 days?"
Cross-Note Analysis: "Based on my recent notes about 'React', how has my understanding of Hooks evolved?"
Excluding Files (.vaultignore)
To exclude specific files or directories from being indexed, create a .vaultignore file in the root of your Obsidian Vault. The syntax is similar to .gitignore.
By default, .obsidian and .trash are always excluded.
Example .vaultignore:
# Exclude specific folders
private/
drafts/
# Exclude specific file types
*.tmp
*.logRegistration for AI Agents
This server is MCP (Model Context Protocol) compliant and can be used with the following agents after you have installed it via uv tool install or pip install.
Note: Please specify the vault path as an absolute path (e.g., /Users/username/Documents/MyVault).
Claude Desktop (macOS)
Add the following to ~/Library/Application Support/Claude/claude_desktop_config.json:
{
"mcpServers": {
"duckvault": {
"command": "duckvault",
"args": [
"/absolute/path/to/your/obsidian/vault"
]
}
}
}Claude Code
You can add the server persistently using the CLI command (recommended) or by editing the configuration file.
Using the CLI command:
claude mcp add duckvault -- duckvault /absolute/path/to/your/obsidian/vaultBy editing the configuration file:
Add to ~/.claude.json:
{
"mcpServers": {
"duckvault": {
"command": "duckvault",
"args": [
"/absolute/path/to/your/obsidian/vault"
]
}
}
}Gemini CLI
You can add the server persistently using the CLI command (recommended) or by editing the configuration file.
Using the CLI command:
gemini mcp add duckvault --scope user duckvault /absolute/path/to/your/obsidian/vaultBy editing the configuration file:
Add to the mcpServers section of your configuration file (~/.gemini/settings.json).
{
"mcpServers": {
"duckvault": {
"command": "duckvault",
"args": [
"/absolute/path/to/your/obsidian/vault"
]
}
}
}GitHub Copilot (in the CLI)
GitHub Copilot in the CLI supports MCP servers. You can add the server using the interactive /mcp command or by editing the configuration file.
Using the CLI command:
Start an interactive session:
copilot(orgh copilot chat).Run the
/mcp addcommand and follow the prompts.
By editing the configuration file:
Add to ~/.copilot/mcp-config.json:
{
"mcpServers": {
"duckvault": {
"command": "duckvault",
"args": [
"/absolute/path/to/your/obsidian/vault"
]
}
}
}
## MCP Tools
The server exposes the following tools to AI agents:
1. `search_notes(query: str, tag: Optional[str] = None, limit: int = 5)`: Search for relevant notes using natural language.
2. `list_recent_notes(days: int = 7)`: List notes that were recently updated.
## License
MITThis 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/caron14/mcp-duckvault'
If you have feedback or need assistance with the MCP directory API, please join our Discord server