Intelligent memory management for MCP clients with confidence tracking, relationship mapping, and knowledge quality maintenance.
Memento is an MCP server that provides persistent memory capabilities across multiple platforms:
- IDEs: Zed, Cursor, Windsurf, VSCode, Claude Desktop
- CLI Agents: Gemini CLI, Claude CLI, custom agents
- Programmatic Usage: MCP client (Python), Docker deployment, CLI export/import
- Applications: Any MCP-compatible application
Build a personal or team knowledge base that grows smarter over time, accessible from all your development tools.
- 🌱 A Gentle Introduction
- ✨ Key Features
- 🚀 Quick Start
- ⚙️ Configuration
- 📖 Core Concepts
- 🔗 Integrations
- 🛠️ Basic Usage Examples
- 📚 Documentation Structure
- 🏗️ Architecture Overview
- 📜 Background
- 🙏 Acknowledgments
- 🤝 Contributing
- 📄 License
- 🔗 Links
What is Memento? Imagine you're solving a complex bug, figuring out a tricky configuration, or establishing a new coding pattern. Usually, you'd forget the details in a few weeks. Memento is a "long-term memory drive" for your AI assistant. It allows your AI to save these solutions, decisions, and facts so it can recall them instantly across different projects, even months later.
💡 The Agentic Mindset: A Guide for Traditional Developers If you are used to deterministic software (where things happen automatically because a script says so), interacting with AI agents requires a slight mental shift.
Memento is not an autonomous agent that watches your screen and magically decides what to remember. Instead, Memento is a toolbelt provided to your AI assistant (like Claude, Cursor, or Gemini).
- The AI is the worker: It needs to be told when to use the toolbelt. Nothing is saved without explicit instruction or a pre-defined rule.
- You are the manager: You control what gets stored. You can either tell the AI during a chat ("Save this database connection string"), or you can give the AI standard operating procedures (via system prompts or
.cursorrules/CLAUDE.mdfiles) so it knows to automatically save certain things, like bug fixes or architecture decisions.
How to build the habit:
- Start of session: Ask your AI, "What do we know about the authentication system?" to pull context.
- During work: When you fix a tricky issue, say, "We fixed the Redis timeout. Store this solution."
- End of session: Tell your AI, "Store a summary of what we accomplished today."
Alternatively, you can add custom instructions to your AI (see our Agent Configuration Guide) to make it automatically execute these steps without you having to ask every time.
- Automatic decay: Unused knowledge loses confidence over time (5% monthly)
- Critical protection: Security/auth/API key memories never decay
- Boost on validation: Confidence increases when knowledge is successfully used
- Smart ordering: Search results ranked by
confidence × importance
- 35 relationship types: SOLVES, CAUSES, IMPROVES, USED_IN, etc. across 7 semantic categories (see Relationship Types Reference)
- Graph navigation: Find connections between concepts
- Pattern detection: Identify recurring solution patterns
| Profile | Tools | Best For |
|---|---|---|
| Core | 13 tools | All users - Essential operations |
| Extended | 17 tools | Power users - Statistics, contextual search, decay control |
| Advanced | 25 tools | Administrators - Graph analysis |
- SQLite backend: Zero dependencies, local storage
- Full-text search: Fast, fuzzy matching across all memories
- Automatic maintenance: Confidence decay, relationship integrity
- Shared database: Same database works across all integrations
# Install with pipx (recommended for MCP servers)
pipx install mcp-memento
# Or with pip
pip install mcp-mementoMemento supports multiple configuration methods. For clarity, we recommend using one method consistently:
Method 1: CLI Arguments (recommended - most explicit)
{
"mcpServers": {
"memento": {
"command": "memento",
"args": ["--profile", "extended", "--db", "~/.mcp-memento/context.db"]
}
}
}Method 2: Environment Variables
{
"mcpServers": {
"memento": {
"command": "memento",
"args": [],
"env": {
"MEMENTO_PROFILE": "extended",
"MEMENTO_DB_PATH": "~/.mcp-memento/context.db"
}
}
}
}Method 3: YAML Configuration File
Create ~/.mcp-memento/config.yaml:
profile: extended
db_path: ~/.mcp-memento/context.dbThen use minimal JSON config:
{
"mcpServers": {
"memento": {
"command": "memento",
"args": []
}
}
}CLI Agents (Gemini CLI):
gemini --mcp-servers mementoNote: The exact flag syntax depends on your Gemini CLI version. Refer to AGENT_CONFIGURATION.md for version-specific setup instructions.
Once configured, your AI assistant can now:
# Store solutions and knowledge
store_memento(
type="solution",
title="Fixed Redis timeout with connection pooling",
content="Increased connection timeout to 30s and added connection pooling...",
tags=["redis", "timeout", "production_fix"],
importance=0.8
)
# Find knowledge later
recall_mementos(query="Redis timeout solutions")📌 Note: The code above represents MCP tool calls — instructions you give your AI assistant (Claude, Cursor, Gemini, etc.) to invoke Memento's tools. This is not a Python library you can
import. For programmatic Python access see the Python Integration Guide.
💬 Natural Language: You can also interact with Memento through natural conversation. Just tell your AI assistant things like "Remember that..." or "Store this..." or "Memento..."- no code required.
For a deep dive into Memento's concepts (Confidence System, Tagging, Relationships), please read the comprehensive RULES.md and RELATIONSHIPS.md documentation.
Memento works with all major development tools:
| Platform | Configuration Guide | Notes |
|---|---|---|
| Zed Editor | IDE Integration | Native MCP support |
| Cursor | IDE Integration | AI-powered editor |
| Windsurf | IDE Integration | Modern code editor |
| VSCode | IDE Integration | Via MCP extension |
| Claude Desktop | IDE Integration | Desktop application |
| Gemini CLI | Agent Integration | Google's CLI agent |
| Claude CLI | Agent Integration | Anthropic's CLI agent |
| Python / MCP Client | Python Integration | Embed server or call via MCP client |
| Docker / CLI | API & Programmatic | MCP client, Docker, export/import |
See also: Integration Overview for guidance on choosing the right integration.
The examples below show the MCP tool calls that an AI assistant (Zed, Cursor, Claude, Gemini CLI, …) executes on your behalf when you ask it to remember or retrieve something. They are written in a Python-like pseudocode that mirrors the MCP tool interface — they are not a Python library you import directly.
To call these tools programmatically from Python, use the
mcpclient library. See Python Integration for a working example.
# Store a solution — the AI calls this tool when you say "remember this fix"
solution_id = store_memento(
type="solution",
title="Fixed memory leak in WebSocket handler",
content="Added proper cleanup in on_close()...",
tags=["websocket", "memory", "python"],
importance=0.9
)
# Natural language search — called when you ask "what do you know about X"
results = recall_mementos(query="WebSocket memory leak", limit=5)
# Tag-based search — for precise filtering
redis_solutions = search_mementos(tags=["redis"], memory_types=["solution"])# Find potentially obsolete knowledge
low_confidence = get_low_confidence_mementos(threshold=0.3)
# Boost confidence after verification
boost_memento_confidence(
memory_id=verified_solution_id,
boost_amount=0.15,
reason="Verified in production deployment"
)# Link solution to problem
create_memento_relationship(
from_memory_id=solution_id,
to_memory_id=problem_id,
relationship_type="SOLVES", # See all 35 types in docs/RELATIONSHIPS.md
strength=0.9,
context="Connection pooling resolved the timeout issue"
)
# Explore connected knowledge
related = get_related_mementos(
memory_id=solution_id,
relationship_types=["RELATED_TO", "USED_IN"],
max_depth=2
)Memento works through natural language conversations. The AI assistant interprets intent and calls the appropriate tools automatically.
Store information:
User: Remember that we solved Redis timeout with connection pooling
AI: ✅ Memento stored - "Redis timeout solution: connection pooling"
Retrieve knowledge:
User: What do you remember about Redis timeout?
AI: Found 2 solutions: 1) Connection pooling... 2) Query optimization...
Using the "Memento" keyword:
User: Memento the deployment script is in /scripts/deploy.sh
AI: ✅ Memento stored - "Deployment script location: /scripts/deploy.sh"
The AI can also store important information automatically when configured with the guidelines in AGENT_CONFIGURATION.md.
Memento supports multiple configuration sources (in order of precedence):
-
Command-Line Arguments (highest priority)
memento --profile advanced --db ~/custom/path/memento.db --log-level DEBUG -
Environment Variables
export MEMENTO_PROFILE="advanced" export MEMENTO_DB_PATH="~/custom/path/memento.db" export MEMENTO_LOG_LEVEL="DEBUG" export MEMENTO_ALLOW_CYCLES="false" # Allow cycles in relationship graph
-
YAML Configuration Files
- Project config:
./memento.yamlin current directory (overrides global) - Global config:
~/.mcp-memento/config.yaml
- Project config:
Priority Order: CLI Arguments > Environment Variables > Project YAML > Global YAML > Defaults
- Default Values (lowest priority)
The following keys are read and applied by the configuration loader. Any other keys present in the YAML file are silently ignored.
| Key | Type | Default | Description |
|---|---|---|---|
db_path |
string | ~/.mcp-memento/context.db |
SQLite database file path |
profile |
string | core |
Tool profile (core, extended, advanced) |
logging.level |
string | INFO |
Log level (DEBUG, INFO, WARNING, ERROR) |
features.allow_relationship_cycles |
bool | false |
Allow cyclic relationships in the graph |
Note: The
memento.yamltemplate shipped with the project contains additional commented sections (confidence,search,performance,memory,fts,project). These are not yet implemented — they are aspirational placeholders for future releases and have no effect on the current server behaviour.
Project configuration (./memento.yaml):
db_path: ~/.mcp-memento/context.db
profile: extended
logging:
level: INFO
features:
allow_relationship_cycles: falseGlobal configuration (~/.mcp-memento/config.yaml):
db_path: ~/.mcp-memento/global.db
profile: extended
logging:
level: INFO- Tools Reference - Complete guide to all MCP tools
- Confidence System - How confidence tracking works
- Relationship Types - All 35 relationship types with examples
- Usage Rules - Best practices and conventions
- Agent Configuration - Templates for AI agents
- Integration Overview - Choosing the right integration
- IDE Integration - Zed, Cursor, Windsurf, VSCode, Claude Desktop
- Python Integration - MCP client usage, server embedding, CLI export/import
- Agent Integration - CLI agents and custom applications
- API & Programmatic Integration - MCP client (Python), Docker deployment, CLI export/import
- Database Schema - Technical database structure
- Contributing Guidelines - Development setup and workflow
Memento uses a unified SQLite schema accessible from all integrations:
- Core tables:
nodes(memory storage),relationships(directed graph) - Full-text search:
nodes_fts— FTS5 virtual table for fast searching (falls back to LIKE-based search if FTS5 is unavailable) - Confidence tracking: Automatic decay with protection for critical memories
The system works identically across all platforms:
- Same database: All tools access the same SQLite file
- Same confidence tracking: Updates from one tool reflected everywhere
- Same search ranking: Results ordered by
confidence × importance - Same relationship types: 35 semantic relationship types available everywhere
Memento is a simplified, lightweight fork of MemoryGraph by Gregory Dickson, optimized for MCP integration across IDEs and CLI agents.
The fork focuses on portability and token efficiency: it removes heavy dependencies (NetworkX, multi-backend storage, bi-temporal tracking, multi-tenant architecture) in favor of a SQLite-only backend with confidence-based decay and guideline-driven storage.
Multiple users can share a SQLite database (e.g., on network storage) using tagging conventions (team:[name], author:[name]). Memento can also run as a remote MCP server, though all clients share the same database without tenant isolation. See Team Collaboration guidelines for details.
For true multi-tenancy, use the original MemoryGraph project.
- Use Memento: For lightweight, cross-platform memory management in IDEs and CLI tools
- Use MemoryGraph: For enterprise use cases requiring multi-tenancy, bi-temporal tracking, or custom backends
Memento is built upon the solid foundation of Gregory Dickson's MemoryGraph project. We're grateful for his pioneering work in memory management systems.
This fork maintains compatibility with MemoryGraph's core concepts while adapting them for the specific needs of MCP integration and modern development tooling. For users requiring the full power of MemoryGraph's advanced features, we recommend exploring the original project.
mcp-webgate is in beta. Core functionality is stable and the server is used in production, but the configuration API may still change before 1.0.
Feedback is very welcome. If something doesn't work as expected, behaves oddly, or you have a use case that isn't covered:
Bug reports, configuration questions, and feature requests all help shape the roadmap.
Contributions are welcome! Please see CONTRIBUTING.md for detailed guidelines on:
- Development setup and workflow
- Code style and conventions
- Testing requirements
- Documentation standards
- Pull request process
MIT License - see LICENSE for details.
- GitHub Repository - Source code and issues
- MCP Protocol - Model Context Protocol specification
- PyPI Package - Python Package Index
- MCP Registry - Model Context Protocol Registry
Need help? Check the documentation or open an issue on GitHub.