Obsidian MCP Server

Obsidian MCP Server

Enables AI assistants to interact with Obsidian vaults via direct filesystem access for managing notes, folders, and metadata. It features advanced search capabilities and multi-layer caching to provide efficient, real-time access to your personal knowledge base.

Category
访问服务器

README

Obsidian MCP Server

A Model Context Protocol (MCP) server that provides seamless integration with Obsidian vaults via direct filesystem access, enabling AI assistants to interact with your notes and knowledge base.

Features

  • Note Management: Create, read, update, and delete notes
  • Folder Operations: Create, rename, move, and delete folders
  • Vault Search: Search with glob patterns, regex, tags, frontmatter, and relevance scoring
  • Intelligent Caching: Multi-layer caching with optional LMDB persistence
  • Real-Time Monitoring: File watching for automatic cache invalidation

Quick Start

Installation

npm install
npm run build

Configuration

Add to your MCP client configuration:

{
  "mcpServers": {
    "obsidian": {
      "command": "node",
      "args": ["/path/to/obsidian-mcp/build/index.js"],
      "env": {
        "OBSIDIAN_VAULT_PATH": "/path/to/your/vault"
      }
    }
  }
}

See Configuration Reference for all options.

Available Tools

Tool Description
list_notes List all notes in the vault
read_note Read the content of a note
create_note Create a new note
update_note Update an existing note
delete_note Delete a note
get_note_metadata Get frontmatter and tags
search_vault Search with required query
advanced_search_vault Advanced search with all options
search_vault_stream Streaming search for large vaults
manage_folder Create, rename, move, or delete folders
get_cache_stats Get cache performance statistics

See Tools Reference for detailed documentation.

Architecture

flowchart TB
    subgraph tools [MCP Tools]
        T1[search_vault]
        T2[read_note]
        T3[list_notes]
    end
    
    subgraph caching [Caching Layer]
        FC[FileListCache]
        CC[ContentCache]
        SC[SearchResultCache]
        PC[PersistentCache]
    end
    
    subgraph optimization [Search Optimization]
        II[InvertedIndex]
        PT[PathTrie]
    end
    
    subgraph fs [Filesystem]
        V[(Obsidian Vault)]
        FW[FileWatcher]
    end
    
    T1 --> SC
    T1 --> II
    T1 --> PT
    T2 --> CC
    T3 --> FC
    
    CC --> PC
    FC --> PC
    SC --> PC
    
    FW --> FC
    FW --> CC
    FW --> II
    
    V --> FW

See Features Reference for detailed architecture documentation.

Performance Features

Feature Description Default
File List Cache Cache folder listings 60s TTL
Content Cache LRU cache for file contents 100 entries
Search Result Cache Cache search query results 50 entries
Persistent Cache LMDB-backed persistence Disabled
Inverted Index Fast word-to-files lookup Disabled
Path Trie Efficient glob pattern matching Disabled
File Watcher Real-time cache invalidation Enabled
Cache Warmup Pre-load cache on startup Disabled

Configuration Quick Reference

Variable Default Description
OBSIDIAN_VAULT_PATH Required Path to your Obsidian vault
OBSIDIAN_ENABLE_PERSISTENT_CACHE false Enable LMDB persistence
OBSIDIAN_ENABLE_INVERTED_INDEX false Enable fast text search index
OBSIDIAN_ENABLE_PATH_TRIE false Enable fast glob matching
OBSIDIAN_ENABLE_CACHE_WARMUP false Pre-load cache on startup

See Configuration Reference for all 19 environment variables.

Development

# Build
npm run build

# Development mode
npm run dev

# Run tests
npm test

Project Structure

src/
├── config/                    # Configuration management
├── handlers/                  # MCP request handlers
├── services/
│   ├── cache/                 # Caching services
│   ├── search/                # Search optimization services
│   ├── fileSystem.ts          # Core filesystem operations
│   ├── FileWatcher.ts         # File change monitoring
│   └── FrontmatterParser.ts   # YAML frontmatter parsing
├── types/                     # TypeScript type definitions
├── index.ts                   # Entry point
└── server.ts                  # Main server class

Documentation

Security

  • Operations are restricted to the configured vault path
  • Path traversal protection is implemented
  • Consider running in a sandboxed environment for production use

Contributing

  1. Fork the repository
  2. Create a feature branch
  3. Make your changes
  4. Add tests if applicable
  5. Submit a pull request

推荐服务器

Baidu Map

Baidu Map

百度地图核心API现已全面兼容MCP协议,是国内首家兼容MCP协议的地图服务商。

官方
精选
JavaScript
Playwright MCP Server

Playwright MCP Server

一个模型上下文协议服务器,它使大型语言模型能够通过结构化的可访问性快照与网页进行交互,而无需视觉模型或屏幕截图。

官方
精选
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

一个由人工智能驱动的工具,可以从自然语言描述生成现代化的用户界面组件,并与流行的集成开发环境(IDE)集成,从而简化用户界面开发流程。

官方
精选
本地
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

通过模型上下文协议启用与 Audiense Insights 账户的交互,从而促进营销洞察和受众数据的提取和分析,包括人口统计信息、行为和影响者互动。

官方
精选
本地
TypeScript
VeyraX

VeyraX

一个单一的 MCP 工具,连接你所有喜爱的工具:Gmail、日历以及其他 40 多个工具。

官方
精选
本地
graphlit-mcp-server

graphlit-mcp-server

模型上下文协议 (MCP) 服务器实现了 MCP 客户端与 Graphlit 服务之间的集成。 除了网络爬取之外,还可以将任何内容(从 Slack 到 Gmail 再到播客订阅源)导入到 Graphlit 项目中,然后从 MCP 客户端检索相关内容。

官方
精选
TypeScript
Kagi MCP Server

Kagi MCP Server

一个 MCP 服务器,集成了 Kagi 搜索功能和 Claude AI,使 Claude 能够在回答需要最新信息的问题时执行实时网络搜索。

官方
精选
Python
e2b-mcp-server

e2b-mcp-server

使用 MCP 通过 e2b 运行代码。

官方
精选
Neon MCP Server

Neon MCP Server

用于与 Neon 管理 API 和数据库交互的 MCP 服务器

官方
精选
Exa MCP Server

Exa MCP Server

模型上下文协议(MCP)服务器允许像 Claude 这样的 AI 助手使用 Exa AI 搜索 API 进行网络搜索。这种设置允许 AI 模型以安全和受控的方式获取实时的网络信息。

官方
精选