A blazingly fast Model Context Protocol (MCP) server for persistent memory storage with intelligent tagging and full-text search.
Perfect for AI assistants that need to remember context across conversations, store project notes, or build a personal knowledge base.
π New to Simple Memory? Read the Design Philosophy to understand why it's built this way, the trade-offs made, and when this approach makes sense for your needs.
- π§ Auto-Capture - LLM proactively stores important information during conversations
- π Sub-millisecond Performance - 2,000-10,000 operations/second
- π Full-Text Search - SQLite FTS5 with 0.14ms average query time
- π·οΈ Smart Tagging - Organize and filter memories with tags
- π Auto-Relationships - Automatically link related memories
- πΎ Automatic Backups - Optional lazy backups to cloud storage
- π Safe Migrations - Automatic schema upgrades without data loss
- π¦ Zero Config - Works out of the box with sensible defaults
| Operation | Average Time | Throughput | 
|---|---|---|
| Store Memory (1KB) | 0.1ms | ~10,000 ops/sec | 
| Tag Search | 0.18ms | ~5,500 ops/sec | 
| Full-Text Search | 0.14ms | ~7,000 ops/sec | 
| Bulk Relationships | 0.26ms | ~3,800 ops/sec | 
All operations complete in sub-millisecond timeframes with optimized indexes and prepared statements.
π‘ Best Experience: Simple Memory works best with Claude Sonnet in Agent Mode. The agent's autonomous decision-making and proactive behavior enables optimal memory capture and retrieval without explicit instructions.
From Source:
git clone https://github.com/chrisribe/simple-memory-mcp.git
cd simple-memory-mcp
npm run setupOr from npm (when published):
npm install -g simple-memory-mcpThat's it! The setup command automatically:
- β Installs dependencies
- β Builds TypeScript β JavaScript
- β
 Links globally (makes simple-memorycommand available)
- β Configures VS Code (both stable and Insiders)
π‘ VS Code users: The setup automatically adds the MCP server to your
mcp.jsonfile. Just restart VS Code after setup!π‘ Need to customize? Run
npm run setupagain to see the config file path (Ctrl+click to open)
If you're using Claude Desktop or other MCP clients, add this to their config:
Claude Desktop (claude_desktop_config.json):
{
  "mcpServers": {
    "simple-memory-mcp": {
      "command": "simple-memory"
    }
  }
}π‘ Windows:
%APPDATA%\Claude\claude_desktop_config.json
π‘ macOS:~/Library/Application Support/Claude/claude_desktop_config.json
Restart your MCP client and the simple-memory-mcp server will be available. The AI assistant can now:
- π§ Remember information across conversations
- π Search your stored memories
- π·οΈ Organize with tags
- π Link related memories automatically
All transparent - no UI, no manual steps. Just works!
The server exposes tools that your AI assistant can use directly. Once configured, your assistant will:
π§ Auto-Capture Mode - Proactively store important information:
- Preferences you mention ("I prefer dark mode")
- Decisions you make ("Let's use PostgreSQL")
- Facts about people, projects, or tools
- Learnings and insights you discover
π Manual Storage - You can also explicitly ask:
- "Remember that I prefer dark mode"
- "Store this meeting summary with tags project and planning"
- "Search my memories for Python tips"
- "Show me all memories tagged with 'important'"
The assistant stores memories silently and retrieves them when relevant, creating a seamless conversation experience.
You can also use the CLI directly:
# Store a memory
simple-memory store-memory --content "Your content here" --tags "tag1,tag2"
# Search by content
simple-memory search-memory --query "search term"
# Search by tags
simple-memory search-memory --tags "tag1,tag2"
# Search with relevance filtering (0-1 scale)
simple-memory search-memory --query "architecture" --min-relevance 0.7
# Search memories from last week
simple-memory search-memory --query "project" --days-ago 7
# Search memories from specific date range
simple-memory search-memory --start-date "2025-01-01" --end-date "2025-01-31"
# View statistics
simple-memory memory-stats
# Update a memory
simple-memory update-memory --hash "abc123..." --content "Updated content" --tags "new,tags"
# Delete by tag
simple-memory delete-memory --tag "old-notes"Store content with optional tags.
π§ Auto-Capture: This tool is enhanced with guidelines that encourage your AI assistant to proactively store important information during conversations without explicit requests. The assistant learns to:
- Capture preferences, decisions, and facts automatically
- Store silently without announcing
- Use descriptive tags for easy retrieval
- Link related memories intelligently
Parameters:
- content(string, required) - The text content to store
- tags(array, optional) - Tags to associate with the memory
- autoLink(boolean, optional) - Auto-link to similar memories (default: true)
Example:
{
  "content": "Remember to use TypeScript for all new projects",
  "tags": ["coding", "best-practices"],
  "autoLink": true
}Search stored memories by content or tags, with optional time range filtering.
π‘ Proactive Usage: Enhanced with guidance for your AI assistant to search memories proactively at conversation start or when relevant topics arise, providing personalized context-aware responses.
Parameters:
- query(string, optional) - Text to search for in content
- tags(array, optional) - Filter by tags
- limit(number, optional) - Max results to return (default: 10)
- includeRelated(boolean, optional) - Include related memories (default: false)
- minRelevance(number, optional) - Minimum relevance score (0-1). Filters by BM25 ranking. Higher values (0.7-0.9) return only highly relevant matches. Useful for LLM context loading.
- daysAgo(number, optional) - Filter memories created within last N days (e.g., 7 for last week)
- startDate(string, optional) - Filter memories created on or after this date (ISO 8601: YYYY-MM-DD)
- endDate(string, optional) - Filter memories created on or before this date (ISO 8601: YYYY-MM-DD)
Example:
{
  "query": "TypeScript",
  "tags": ["coding"],
  "limit": 5,
  "minRelevance": 0.7
}Relevance Filtering Examples:
// High precision - only highly relevant results (best for LLM context)
{ "query": "architecture decisions", "minRelevance": 0.8 }
// Medium precision - moderately relevant results
{ "query": "bug fixes", "minRelevance": 0.5 }
// No filter - all matches ranked by relevance (default)
{ "query": "typescript" }Time Range Examples:
// Find memories from last week
{ "query": "project update", "daysAgo": 7 }
// Find memories from specific date range
{ "startDate": "2025-01-01", "endDate": "2025-01-31" }
// Find recent memories with specific tags
{ "tags": ["bug"], "daysAgo": 3 }Update an existing memory with new content and/or tags.
Parameters:
- hash(string, required) - Hash of the memory to update
- content(string, required) - New content for the memory
- tags(array, optional) - New tags to replace existing tags (if omitted, existing tags preserved)
Behavior:
- Hash changes when content changes
- Memory ID and creation date remain unchanged
- Relationships to other memories are preserved
Example:
{
  "hash": "abc123...",
  "content": "Updated project status: phase 2 complete",
  "tags": ["project", "status", "complete"]
}Delete memories by hash or tag.
Parameters:
- hash(string, optional) - Hash of specific memory to delete
- tag(string, optional) - Delete all memories with this tag
Example:
{
  "tag": "temporary"
}Get statistics about stored memories.
Returns:
- Total memories count
- Total relationships count
- Database size in bytes
- Schema version
- Backup status (if configured):
- Backup path
- Number of backup files
- Minutes since last backup
- Minutes until next backup
 
| Variable | Description | Default | Example | 
|---|---|---|---|
| MEMORY_DB | Database file path | ./memory.db | /home/user/memories.db | 
| MEMORY_BACKUP_PATH | Backup directory (optional) | None | /home/user/backups | 
| MEMORY_BACKUP_INTERVAL | Minutes between backups | 0(disabled) | 180 | 
| MEMORY_BACKUP_KEEP | Number of backups to keep | 10 | 24 | 
| MEMORY_CLOUD_SAFE | Cloud storage safe mode | false | true | 
| DEBUG | Enable debug logging | false | true | 
π‘ Quick Access: Run
npm run setupto see your config file path, then Ctrl+click to open it
{
  "mcpServers": {
    "simple-memory": {
      "command": "simple-memory",
      "env": {
        "MEMORY_DB": "/path/to/your/memory.db"
      }
    }
  }
}{
  "mcpServers": {
    "simple-memory": {
      "command": "simple-memory",
      "env": {
        "MEMORY_DB": "/home/user/memory.db",
        "MEMORY_BACKUP_PATH": "/home/user/OneDrive/MCP-Backups",
        "MEMORY_BACKUP_INTERVAL": "180",
        "MEMORY_BACKUP_KEEP": "24"
      }
    }
  }
}π‘ Backup Strategy:
- Lazy backups - Only backs up after write operations
- Throttled - Won't backup again until interval passes
- Efficient - No wasted backups when idle
- β Recommended: Store database locally, backup to cloud (as shown above)
- β οΈ Not Recommended: Store database directly in OneDrive/Dropbox- WAL mode creates 3 files that sync at different times β corruption risk
- File locking conflicts cause "database locked" errors
- 2-10x slower performance
 
If you must store directly in cloud storage, enable safe mode:
{
  "env": {
    "MEMORY_DB": "/path/to/OneDrive/memory.db",
    "MEMORY_CLOUD_SAFE": "true"
  }
}This uses DELETE journal mode instead of WAL (30-50% slower but safer).
Run multiple instances for different contexts:
{
  "mcpServers": {
    "memory-work": {
      "command": "simple-memory",
      "env": {
        "MEMORY_DB": "/path/to/work-memory.db"
      }
    },
    "memory-personal": {
      "command": "simple-memory",
      "env": {
        "MEMORY_DB": "/path/to/personal-memory.db"
      }
    }
  }
}- SQLite with WAL mode for better concurrency
- FTS5 for lightning-fast full-text search
- Normalized tags with proper indexing (50-200x faster than LIKE queries)
- Automatic relationships between related memories
- β Automatic migrations with data integrity guarantees
- β Optimized indexes on all hot paths
- β Prepared statements for all queries
- β 64MB cache with memory-based temp storage
- β Transaction-based bulk operations
- Maximum content size: 5MB per memory
- No limit on number of memories
- No limit on number of tags
# Clone the repository
git clone https://github.com/chrisribe/simple-memory-mcp.git
cd simple-memory-mcp
# Install dependencies
npm install
# Build
npm run build# Development mode with hot reload
npm run dev
# Build TypeScript
npm run build
# Build with version bump (for releases)
npm run build:release
# Run all tests (28 tests)
npm run test:all
# Run specific test suites
npm test              # Core functionality (9 tests)
npm run test:perf     # Performance tests (6 tests)
npm run test:migration # Migration tests (13 tests)
# Performance benchmarks
npm run benchmark
# Link/unlink globally for testing
npm run link          # Build and link globally (makes 'simple-memory' command available)
npm run unlink        # Remove global link
# Or manually
npm link              # Link current directory globally
npm unlink -g         # Unlink from global
simple-memory memory-stats  # Test the global commandThe project uses automated version bumping:
- Development builds: Use npm run build(no version change)
- Release builds: Use npm run build:release(bumps patch version)
- Manual version bumps: Use npm run version:patch|minor|major
- Automatic: All commits/merges to mainautomatically bump the patch version via GitHub Actions
The workflow skips version bumps for:
- Documentation-only changes (.mdfiles)
- Changes to docs/directory
- Commits containing [skip-version]in the message
The project has comprehensive test coverage:
- β Core Tests (9) - CRUD operations, search, basic functionality
- β Performance Tests (6) - Large content, size limits, throughput
- β Migration Tests (13) - Schema upgrades, rollback safety, data integrity
- β Benchmarks - Detailed performance metrics
All tests pass with 100% backward compatibility.
Simple Memory shines when used with AI assistants through MCP. Here are real conversation flows:
Day 1:
You: "I'm starting a new project. It's a React app with TypeScript, using Vite for bundling. We'll deploy to Vercel."
Assistant: Stores this with tags:
project,react,typescript,vite,vercel
Day 3:
You: "What stack am I using for my project again?"
Assistant: Searches memories and finds: "You're using React with TypeScript, Vite for bundling, and deploying to Vercel."
Week 2:
You: "We decided to add Prisma ORM with PostgreSQL for the database."
Assistant: Stores this and auto-links to previous project memories
Week 4:
You: "Give me a summary of all my tech stack decisions."
Assistant: Retrieves all related memories and provides complete context
Learning Session:
You: "Remember this: TypeScript generics allow type-safe reusable components. The syntax is
function name<T>(arg: T): T"Assistant: Stores with tags:
typescript,generics,learning
You: "Also note: Array.reduce() is perfect for transforming arrays into single values. Use it instead of forEach when accumulating."
Assistant: Stores with tags:
javascript,arrays,patterns
Later that week:
You: "What did I learn about TypeScript generics?"
Assistant: Retrieves your note with the exact syntax example
You: "Show me all my JavaScript tips"
Assistant: Searches tag
javascriptand finds all related notes
Storing Credentials:
You: "Store this API key for the payment gateway: sk_live_abc123xyz"
Assistant: Stores securely with tags:
api-key,payment,credentials
You: "The database connection string is postgresql://user:pass@host:5432/db"
Assistant: Stores with tags:
credentials,database,connection-string
Retrieval:
You: "What's my payment gateway API key?"
Assistant: Searches memories: "Your payment gateway API key is sk_live_abc123xyz"
You: "Show me all my stored credentials"
Assistant: Lists all memories tagged with
credentials
After Team Meeting:
You: "Meeting notes: Team agreed on 2-week sprints starting Monday. Sprint planning on Mondays at 10am. Retrospectives on Fridays."
Assistant: Stores with tags:
meeting,agile,team,schedule
You: "Important decision: We're going with PostgreSQL instead of MongoDB for better transaction support."
Assistant: Stores with tags:
decision,database,architecture
Later:
You: "When are our sprint meetings?"
Assistant: Retrieves schedule from meeting notes
You: "Why did we choose PostgreSQL?"
Assistant: Finds decision and reasoning: "For better transaction support"
The real power comes from persistent memory across all conversations:
Session 1: Store project setup info
  β
Session 2: Assistant remembers and builds on it
  β
Session 5: Store API decisions
  β
Session 10: Assistant recalls everything - full context maintained
  β
Session 20: Complete project knowledge base available instantly
This is impossible with standard chat sessions that lose context!
You can also use the CLI directly for testing or scripting:
# Store a memory
simple-memory store-memory \
  --content "PostgreSQL connection: postgresql://localhost:5432/mydb" \
  --tags "database,credentials"
# Search by content
simple-memory search-memory --query "PostgreSQL"
# Search by tags
simple-memory search-memory --tags "credentials"
# View statistics
simple-memory memory-stats
# Delete memories by tag
simple-memory delete-memory --tag "temporary"When to use CLI:
- β Testing the MCP server works
- β Bulk operations or scripting
- β Debugging or inspecting the database
- β Manual backup before major changes
Primary use case: Let your AI assistant handle everything through natural conversation!
Contributions are welcome! Please feel free to submit a Pull Request.
- Fork the repository
- Create your feature branch (git checkout -b feature/amazing-feature)
- Commit your changes (git commit -m 'Add amazing feature')
- Push to the branch (git push origin feature/amazing-feature)
- Open a Pull Request
This project is licensed under the MIT License - see the LICENSE file for details.
- Built with the Model Context Protocol SDK
- Powered by SQLite and better-sqlite3
- ποΈ Design Philosophy - Why Simple Memory is built this way, trade-offs, and honest limitations
- π Performance Benchmarks - Detailed performance analysis and optimization insights
- π Changelog - Version history and changes
Found a bug or have a feature request?
- π Report Issues
- π¬ Start a Discussion
- π§ Check the documentation
Made with β€οΈ by chrisribe