loading…
Search for a command to run...
loading…
Provides persistent, intelligent memory using Elasticsearch with hierarchical categorization and semantic search for LLM contexts.
Provides persistent, intelligent memory using Elasticsearch with hierarchical categorization and semantic search for LLM contexts.
A powerful Model Context Protocol (MCP) server that provides persistent, intelligent memory using Elasticsearch with hierarchical categorization and semantic search capabilities.
🏷️ Hierarchical Memory Categorization
identity, active_context, active_project, technical_knowledge, archived🤖 Intelligent Auto-Detection
📦 Batch Review System
🔄 Backward Compatible Fallback
🚀 Optimized Context Loading
💾 Persistent Memory
Install directly from PyPI:
pip install elasticsearch-memory-mcp
# Using Docker (recommended)
docker run -d -p 9200:9200 -e "discovery.type=single-node" elasticsearch:8.0.0
# Or install locally
# https://www.elastic.co/guide/en/elasticsearch/reference/current/install-elasticsearch.html
Add to ~/.config/Claude/claude_desktop_config.json:
{
"mcpServers": {
"elasticsearch-memory": {
"command": "uvx",
"args": ["elasticsearch-memory-mcp"],
"env": {
"ELASTICSEARCH_URL": "http://localhost:9200"
}
}
}
}
Note: If you don't have
uvx, install withpip install uvxor usepython -m elasticsearch_memory_mcpinstead.
claude mcp add elasticsearch-memory uvx elasticsearch-memory-mcp \
-e ELASTICSEARCH_URL=http://localhost:9200
If you want to contribute or modify the code:
# Clone repository
git clone https://github.com/fredac100/elasticsearch-memory-mcp.git
cd elasticsearch-memory-mcp
# Create virtual environment
python3 -m venv venv
source venv/bin/activate
# Install in development mode
pip install -e .
Then configure MCP pointing to your local installation:
{
"mcpServers": {
"elasticsearch-memory": {
"command": "/path/to/venv/bin/python",
"args": ["-m", "mcp_server"],
"env": {
"ELASTICSEARCH_URL": "http://localhost:9200"
}
}
}
}
Save a new memory with automatic categorization.
{
"content": "Fred prefers direct, brutal communication style",
"type": "user_profile",
"importance": 9,
"tags": ["communication", "preference"]
}
Loads hierarchical context with:
Review uncategorized memories in batches.
{
"batch_size": 10,
"min_confidence": 0.6
}
Returns suggestions with auto-detected categories and confidence scores.
Apply categorizations in batch after review.
{
"approve": ["id1", "id2"], // Auto-categorize
"reject": ["id3"], // Skip
"reclassify": {"id4": "archived"} // Force category
}
Semantic search with filters.
{
"query": "SAE project details",
"limit": 5,
"category": "active_project"
}
Batch auto-categorize uncategorized memories.
{
"max_to_process": 50,
"min_confidence": 0.75
}
┌─────────────────┐
│ Claude (MCP) │
└────────┬────────┘
│
▼
┌─────────────────────────────┐
│ MCP Server (v6.2) │
│ ┌─────────────────────┐ │
│ │ Auto-Detection │ │
│ │ - Keyword matching │ │
│ │ - Confidence score │ │
│ └─────────────────────┘ │
│ │
│ ┌─────────────────────┐ │
│ │ Batch Review │ │
│ │ - Review workflow │ │
│ │ - Bulk operations │ │
│ └─────────────────────┘ │
└──────────┬──────────────────┘
│
▼
┌──────────────────────────────┐
│ Elasticsearch │
│ ┌────────────────────────┐ │
│ │ memories (index) │ │
│ │ - embeddings (vector) │ │
│ │ - memory_category │ │
│ │ - category_confidence │ │
│ └────────────────────────┘ │
└──────────────────────────────┘
| Category | Description | Examples |
|---|---|---|
| identity | Core identity, values, preferences | "Fred prefers brutal honesty" |
| active_context | Current work, recent conversations | "Working on SAE implementation" |
| active_project | Ongoing projects | "Mirror architecture design" |
| technical_knowledge | Facts, configs, tools | "Elasticsearch index settings" |
| archived | Completed, deprecated, old migrations | "Refactored old auth system" |
"Fred prefere comunicação brutal" → identity (0.9)
"Refatoração do sistema SAE concluída" → archived (0.85)
"Próximos passos: implementar dashboard" → active_context (0.8)
"Fred prefere comunicação brutal. Primeira vez usando este estilo."
→ Match 1: "Fred prefere" (+0.9)
→ Match 2: "primeira vez" (+0.8)
→ Total: 0.95 (normalized)
The v6.2 system includes automatic fallback for v5 memories:
# Review and categorize v5 memories
review_uncategorized_batch(batch_size=20)
apply_batch_categorization(approve=[...])
# Run quick test
python test_quick.py
# Expected output:
# ✅ Elasticsearch connected
# ✅ Context loaded
# ✅ Identity memories found
# ✅ Projects separated from fallback
Contributions are welcome! Please:
git checkout -b feature/amazing-feature)git commit -m 'Add amazing feature')git push origin feature/amazing-feature)This project is licensed under the MIT License - see the LICENSE file for details.
Made with ❤️ for the Claude ecosystem
Выполни в терминале:
claude mcp add elasticsearch-memory-mcp -- npx Безопасность
Низкий рискАвтоматическая эвристика по публичным данным — не гарантия безопасности.