Markdown Memory Context MCP Server

Markdown Memory Context MCP Server

Enables AI agents to maintain a structured Markdown or Obsidian memory vault with tools for reading, writing, searching, and organizing notes.

Category
Visit Server

README

Markdown Memory Context MCP Server

Markdown Memory Context, or MMC, is a local MCP server that gives AI agents structured read and write tools for a folder-based Markdown or Obsidian memory context vault.

The vault is intentionally simple: a top-level Project Index.md, lightweight category hubs, and focused child notes under category folders. Templates live outside the vault in memory-templates/, so agents can read them without cluttering the Obsidian graph.

Quickstart

From this repository:

cd markdown-memory
python -m venv .venv
source .venv/bin/activate
python -m pip install -e ".[dev]"
python -m pytest

Configure an MCP client to run the local executable:

{
  "mcpServers": {
    "mmc": {
      "command": "mmc-mcp",
      "args": [],
      "env": {
        "MARKDOWN_MEMORY_ROOT": ".markdown-memory",
        "MARKDOWN_MEMORY_EMBEDDINGS_API_KEY": "..."
      }
    }
  }
}

The older markdown-memory-mcp executable remains available for compatibility. New configs should prefer mmc as the MCP server key and mmc-mcp as the command.

You can also pass memory_root to every tool call. Tool arguments take precedence over MARKDOWN_MEMORY_ROOT; if neither is set, the server uses .markdown-memory in the current working directory.

Vault Layout

Run memory_init to create the base layout:

.markdown-memory/
  Project Index.md
  Architecture.md
  Architecture/
  Commands.md
  Commands/
  Current State.md
  Current State/
  Rules.md
  Rules/
  ...
memory-templates/
  Project Index Template.md
  Category Hub Template.md
  Memory Entry Template.md
  Architecture Entry Template.md
  Commands Entry Template.md
  Rules Entry Template.md
  Ignore Entry Template.md
  Decision Entry Template.md
  Risk Entry Template.md

Category hubs stay short and link to focused notes. Durable details belong in focused notes such as Architecture/Data Flow.md or Rules/Safety And Secrets.md.

Tools

  • memory_init: create missing vault hubs, category folders, and templates.
  • memory_index: list index, hubs, focused notes, tags, snippets, and presence flags.
  • memory_brief: return a compact orientation payload for agents.
  • memory_workflow: return the recommended read/write memory workflow.
  • memory_context_pack: combine the brief, semantic/lexical matches, and selected reads.
  • memory_search: search focused notes by query and optional category.
  • memory_vector_status: report whether semantic search is usable, chunk counts, stale notes, model, dimensions, and DB path.
  • memory_vector_rebuild: create or refresh the derived vector SQLite index.
  • memory_vector_search: semantic search focused notes, with silent lexical fallback.
  • memory_read: read one note by key or path.
  • memory_upsert: create or replace a focused note.
  • memory_append: append a bounded section to a focused note.
  • memory_link: ensure a category hub links to a focused note.

Semantic Search

Markdown remains the source of truth. The vector index is derived local state at:

.markdown-memory/.markdown-memory-vector/index.sqlite3

Deleting the SQLite file is safe; rebuild it with memory_vector_rebuild. Vector search uses OpenAI-compatible embeddings:

  • MARKDOWN_MEMORY_EMBEDDINGS_BASE_URL, default https://api.openai.com/v1
  • MARKDOWN_MEMORY_EMBEDDINGS_API_KEY
  • MARKDOWN_MEMORY_EMBEDDINGS_MODEL, default text-embedding-3-small
  • MARKDOWN_MEMORY_EMBEDDINGS_TIMEOUT, default 30

For compatibility, the server also accepts the corresponding JARVIS_EMBEDDINGS_* variables when Markdown Memory-specific variables are not set.

If embeddings or the database are unavailable, vector tools return non-fatal metadata and memory_vector_search falls back to memory_search. Memory writes still succeed. memory_upsert, memory_append, and memory_link try to refresh the affected note and hub vectors automatically.

Using With Coding Agents

Use memory as working context, not as a substitute for repository evidence.

  1. Start with memory_context_pack, memory_brief, or memory_index.
  2. Use memory_vector_search for task terms and categories; lexical search is the fallback.
  3. Use memory_read for the smallest relevant focused notes.
  4. Inspect source evidence before decisions.
  5. Save durable findings with memory_upsert or memory_append.

Prefer memory_append for decisions, risks, workflows, and time-based updates.

Safety

Markdown Memory refuses path traversal, writes outside the configured memory root, secret-like filenames, and secret-like content such as env assignments or private key blocks. It excludes .obsidian/ from index and search results.

Never store secrets, credentials, tokens, private environment values, or API keys in memory notes.

Recommended Servers

playwright-mcp

playwright-mcp

A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.

Official
Featured
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

graphlit-mcp-server

The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.

Official
Featured
TypeScript
Kagi MCP Server

Kagi MCP Server

An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

Exa Search

A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured