Provides advanced contextual and semantic memory management using Redis and Redis Stack, enabling agents to store chronological logs, perform vector similarity searches, manage temporary scratchpad data with TTL, and facilitate inter-agent communication via Pub/Sub.
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-memory-serverShow me the most recent context entries for agent:dev_agent_01"
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-memory-server
Servidor MCP de memoria contextual y avanzada sobre Redis: listas cronológicas, memoria semántica (Redis Stack), rollup de historial, scratchpad con TTL y Pub/Sub inter-agente. Pensado para orquestación de agentes.
Arquitectura (hexagonal mínima)
domain/ — Contrato de resultado (
ToolResult,toolErrorResult,errorToToolResult). Sin I/O.ports/ — Interfaces:
ContextualMemoryPort,SemanticMemoryPort,ScratchpadPort,EventPublisherPort.application/ — Casos de uso que reciben un puerto y devuelven
ToolResult(formateo y reglas de negocio).adapters/redis/ — Implementación de los puertos con ioredis (y RediSearch para semántica).
adapters/mcp/ — Schemas Zod y registro de tools en el servidor MCP; cada tool parsea input y llama al caso de uso con el puerto inyectado.
El entrypoint (index.ts) crea el cliente Redis, instancia los adaptadores y arranca el servidor con startServer(ports).
Herramientas (Tools)
Memoria cronológica (listas)
Nombre | Parámetros | Descripción |
|
| Últimas N entradas de la bitácora (hidratación del agente). |
|
| Registra un nuevo hito en la bitácora. |
|
| Historial completo (para orquestador o resumen). |
Memoria semántica (Redis Stack; búsqueda por similitud)
Nombre | Parámetros | Descripción |
|
| Guarda un recuerdo con vector para búsqueda asociativa. |
|
| "Tráeme recuerdos similares a este contexto". |
Rollup / compresión
Nombre | Parámetros | Descripción |
|
| Cantidad de entradas y primera/última ts; para decidir cuándo hacer rollup. |
|
| Reemplaza entradas antiguas por un ítem [RESUMEN HISTÓRICO]; el orquestador genera el resumen y pasa el texto. |
Scratchpad (TTL)
Nombre | Parámetros | Descripción |
|
| Guarda dato temporal; Redis lo borra al expirar. |
|
| Lee un scratchpad. |
|
| Borra antes del TTL. |
Comunicación inter-agente (Pub/Sub)
Nombre | Parámetros | Descripción |
|
| Publica en un canal; agentes suscritos (fuera del MCP) lo reciben. |
|
| Lee los últimos mensajes del log del canal (para quien no mantiene suscripción). |
Nota: El MCP no mantiene suscripciones; solo publica y escribe en log. La recepción en tiempo real la hace un proceso que ejecute SUBSCRIBE en Redis.
Datos en Redis: listas por agent_key con JSON {ts, entry, type?}; memoria semántica en hashes con RediSearch; scratchpad en claves con EX; canales con prefijo channel:.
Cómo ejecutar
Con Cursor (MCP en host, Redis en Docker)
Levantar Redis: desde la raíz del repo:
docker compose up -d redis_dbEn
mcp-memory-server:cd mcp-memory-server npm install npm run buildEn
.cursor/mcp.json(raíz del workspace) añadí el servidor. Reiniciar Cursor tras cambiarmcp.json.
Cursor: uso standalone (repo por separado)
Si este repo se usa solo (sin orquestador), en la raíz del proyecto donde está mcp-memory-server:
npm install && npm run buildEn .cursor/mcp.json del workspace que use este MCP:
"mcp-memory-server": {
"command": "node",
"args": ["mcp-memory-server/dist/index.js"],
"env": {
"REDIS_URL": "redis://localhost:6379"
}
}Si el MCP está en otra ruta, ajustá args (ej. path absoluto o relativo al cwd de Cursor).
Todo en Docker
docker compose up -dEl servicio mcp_memory_server corre dentro de la red; para uso por stdio desde Cursor hay que ejecutar el MCP en el host (ver arriba).
Orquestación y prompts de ejemplo
Prompt para el agente (memoria cronológica)
Eres un arquitecto experto. Para recordar en qué estás trabajando, usa la herramienta de memoria con la clave
agent:arq_1. Al empezar, llama aget_recent_contextcon esa clave; cuando completes un paso, usaappend_contextual_memorycon la misma clave y un resumen breve.
Playbook orquestador (cuándo llamar cada tool)
Hidratación (agente):
get_recent_context(agent_key, limit)— solo los últimos 5 (o N) pasos.Trabajo (agente):
append_contextual_memory(agent_key, new_entry)— registrar hitos.Memoria a largo plazo: El orquestador (o el agente) genera embeddings y usa
append_semantic_memory; para recuperar contexto similar,search_semantic_memorycon el embedding de la consulta actual.Compresión: Si
get_memory_stats(agent_key)devuelve más de 100 entradas, el orquestador puede generar un resumen de las más antiguas y llamarrollup_memory_segment(agent_key, keep_last: 20, summary_entry: "[RESUMEN HISTÓRICO] ...").Pensamientos efímeros: El agente usa
set_scratchpad_entrypara cálculos o planes de la tarea actual (TTL ej. 1h);get_scratchpad_entrypara leer;clear_scratchpad_entrysi termina antes.Comunicación: Un agente publica en
publish_interagent_message(channel: "backend_devs", sender_agent_key, payload); otro puede leer el log conget_channel_log("backend_devs")si no está suscrito.Resumen final (orquestador):
get_all_context(agent_key)para pasar el historial a otro modelo o resumir.
Referencia de patrones: .cursor/skills/orchestration-patterns.
Variables de entorno
Variable | Obligatoria | Descripción |
| Sí | URL de Redis (ej. |
| No | Nombre del índice RediSearch para memoria semántica (default: |
| No | Dimensión del vector de embeddings (default: 1536). |
| No | Métrica de distancia: COSINE, L2 o IP (default: COSINE). |
Memoria semántica requiere Redis Stack (RediSearch + Vector Search). El docker-compose.yml usa redis/redis-stack-server:latest. Si usas Redis sin Stack, las tools de memoria semántica fallarán; el resto (cronológica, scratchpad, pub/sub) funciona con Redis estándar.
No guardar secrets en el repo; documentar aquí y usar env en mcp.json o en el contenedor.
Tests y desarrollo
Tests:
npm test(Vitest; tools con mock de Redis).Desarrollo:
npm run dev(tsx watch) con Redis levantado.
Spec y dependencias
SDK:
@modelcontextprotocol/sdkRedis:
ioredis; Redis Stack para memoria semántica (RediSearch + Vector Search). Listas, hashes, strings con TTL, Pub/Sub.
This server cannot be installed
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.