mcp-ariel-memory
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-ariel-memoryremember that my favorite color is blue"
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.
mcp-ariel-memory
Universal Two-Layer Memory MCP Server
A two-layer universal memory system for AI agents. Real MCP Python SDK, async, 37 tools, stdio + HTTP transports, dashboard, metrics, authentication, automatic backups, external wiki folders, read-only replica.
About
mcp-ariel-memory is a production-ready MCP (Model Context Protocol) server that provides persistent, searchable memory for AI agents. It implements a two-layer architecture:
Layer 1 (User) — stores facts about users: preferences, conversation history, emotional context, relationships
Layer 2 (Agent) — stores agent identity: decisions, errors, personality evolution, learning patterns
The server is built with the official MCP Python SDK (FastMCP), supports both stdio and HTTP transports, and includes enterprise features like authentication, rate limiting, automatic backups, and a real-time dashboard.
Key Capabilities
37 MCP tools covering memory CRUD, search, graph operations, and system management
Hybrid search combining FTS5 full-text with vector similarity via Reciprocal Rank Fusion
Knowledge graphs for epistemic (facts/decisions) and temporal (timeline) relationships
Wiki system with 14 content types, .md files as source of truth, and external folder sync
24 hooks for intercepting memory operations at every stage
Saga pattern for multi-step operations with compensation and watchdog
Platform-aware async — aiosqlite on Linux/macOS, sync fallback on Windows
Related MCP server: ContextStream MCP Server
Installation
Option 1: npm (recommended for MCP clients)
npx mcp-ariel-memory --transport stdioRequires Python 3.10+ on the system. The npm wrapper automatically installs the Python package.
Option 2: pip
pip install git+https://github.com/Cipher208/mcp-ariel-memory.git
python -m mcp_server --transport stdioOption 3: Docker
docker build -t ariel-memory .
docker run -p 8000:8000 ariel-memoryOption 4: From source
git clone https://github.com/Cipher208/mcp-ariel-memory.git
cd mcp-ariel-memory
pip install -e ".[all]"
python -m mcp_server --transport stdioQuick Start
Claude Desktop
Add to claude_desktop_config.json:
{
"mcpServers": {
"ariel-memory": {
"command": "npx",
"args": ["mcp-ariel-memory", "--transport", "stdio"]
}
}
}Or with Docker:
{
"mcpServers": {
"ariel-memory": {
"command": "docker",
"args": ["run", "--rm", "-i", "ariel-memory", "--transport", "stdio"]
}
}
}HTTP Server
# Start HTTP server
python -m mcp_server --transport http --port 8000
# Or with Docker
docker run -p 8000:8000 ariel-memory --transport http --port 8000
# Or with dashboard + metrics
docker run -p 8000:8000 ariel-memory --transport http --port 8000 --dashboarddocker-compose
docker-compose upPlatform Support
Platform | Method | Notes |
Windows | npm / pip / Docker | aiosqlite fallback (sync sqlite3 + to_thread) |
Linux | npm / pip / Docker | aiosqlite (native async) |
macOS | npm / pip / Docker | aiosqlite (native async) |
Docker | Any | Works on all platforms with Docker |
Features
Feature | Description |
37 MCP Tools | User layer (10), Agent layer (10), Auth (3), Backup (4), Saga (2), Replica (1), Import/Export (3), Maintenance (1), Emergency (1), Search (1), Context (1) |
Two-Layer Memory | L1 ReflexBuffer → L2 SessionStore → L3 EpisodicMemory → L4 CoreMemory |
Hybrid Search | FTS5 + vector similarity via Reciprocal Rank Fusion (RRF) |
Knowledge Graph | Epistemic graph (facts, decisions) + Temporal graph (timeline) |
Wiki System | 14 types (7 user + 7 agent), .md files as source of truth, FTS5 index |
24 Hooks | 12 user hooks + 12 agent hooks, integrated into tool pipeline |
Saga Pattern | Multi-step operations with compensation, timeout, watchdog |
Dashboard | HTML dashboard with stats, facts, episodes, audit log |
Auth | API keys + Bearer tokens, persistent storage |
Backup | Auto-backups with jitter, restore, cleanup |
Metrics | Prometheus-compatible metrics endpoint |
Read-Only Replica | SQLite read-only replica for queries |
Embeddings | Multilingual (100+ languages including Russian) |
Architecture
Memory Hierarchy
Message → L1 (ReflexBuffer, ring buffer, 50 items)
→ ImportanceGate (noise filter, threshold 0.3)
→ L2 (SessionStore, SQLite, 100 sessions)
→ EmotionTrigger (emotional analysis)
→ L3 (EpisodicMemory, SQLite, 1000 episodes)
→ L4 (CoreMemory, key-value, 5000 facts)Database Tables (21)
Table | Module | Purpose |
| core/memory.py | L4 key-value facts |
| core/session.py | L2 session history |
| core/episodic.py | L3 episodic memories |
| shared/dream_buffer.py | Temporary staging |
| shared/archived_memories.py | Archived memories |
| features/audit_trail.py | Audit trail |
| features/rate_limiting.py | Rate limiting |
| shared/embeddings.py | Cached embeddings |
| rag/engine.py | RAG document pages |
| rag/engine.py | RAG document chunks |
| rag/engine.py | RAG relations |
| graph/epistemic.py | Epistemic graph nodes |
| graph/epistemic.py | Epistemic graph edges |
| graph/temporal.py | Temporal events |
| graph/temporal.py | Temporal links |
| wiki/user_wiki.py | User wiki entries |
| wiki/agent_wiki.py | Agent wiki entries |
| wiki/file_wiki.py | Wiki FTS5 index |
| rag/conflict.py | Memory conflicts |
| shared/migrations.py | Migration history |
| features/auth.py | API keys |
Documentation
# | Document | Description |
01 | Stack, two-layer model, L1-L4, consolidation | |
02 | All 37 tools with parameters and examples | |
03 | ReflexBuffer, SessionStore, EpisodicMemory, CoreMemory | |
04 | FTS5 + fallback, RRF, RetrievalRouter, ConflictResolver | |
05 | EpistemicGraph, TemporalGraph | |
06 | Forgetting, EmotionTrigger, Consolidation | |
07 | 24 hooks (12 user + 12 agent) | |
08 | FileWiki (.md files + FTS5) | |
09 | Auth, Backup, Dashboard, Audit, RateLimit | |
10 | Cache, Saga+Watchdog, Middleware, Embeddings, Metrics | |
11 | Transports, Dashboard, Auth, Backup, Configuration | |
12 | pytest, project structure |
Testing
# Run all tests (104 passed)
pytest tests/ -v
# Run only integration tests
pytest tests/test_integration.py -v
# Run with coverage
pytest tests/ --cov=. --cov-report=term-missingConfiguration
# config.yaml (optional, mounted as volume)
layers: { user: { enabled: true }, agent: { enabled: true } }
limits: { l1_buffer_size: 50, l4_core_limit: 5000 }
hooks: { user: { message_received: true }, agent: { error_occurred: true } }
forgetting: { decay_rate: 0.01, archive_threshold_days: 90 }
rag: { fts_enabled: true, vec_enabled: true }
embeddings: { model: "BAAI/bge-small-en-v1.5" }
wiki:
user: { diary: true, external_dirs: ["/path/to/notes"] }
agent: { decision_log: true, external_dirs: ["/path/to/lore"] }
auth: { api_keys_enabled: true, bearer_token_enabled: true }
backup: { auto_backup: true, backup_interval_hours: 24 }Development
# Install dev dependencies
pip install -e ".[dev]"
# Run linter
ruff check .
# Format code
ruff format .
# Run tests
pytest tests/ -vLicense
MIT License - see LICENSE for details.
This 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/Cipher208/mcp-ariel-memory'
If you have feedback or need assistance with the MCP directory API, please join our Discord server