Dense Mem
Dense-Mem gives MCP clients a durable memory layer with provenance, typed claims and facts, verification gates, server-side embeddings, recall, team isolation, REST/OpenAPI, and a token-protected control portal. The host LLM owns conversation and judgment; Dense-Mem owns durable memory state and returns structured outcomes the host can explain to users.
Under the hood, Dense-Mem is a standalone HTTP MCP memory server. HTTP MCP is
the v1 supported MCP transport and is served at /mcp from the main HTTP
process.
Dense-Mem is part of the research preprint Governed Enterprise AI Memory Beyond RAG: From Vector Retrieval to Permissioned Knowledge Graphs.
Project Intro
Related MCP server: mcp-local-memory
Try the Hosted Demo
Create a temporary isolated team at https://demo-dense-mem.markhuang.ai and test Dense-Mem before self-hosting.
Why Dense-Mem?
AI agents need memory that can be trusted later, not only text that can be retrieved later.
Evidence is first-class. Memories start as source fragments before they become claims or facts.
Facts pass through typed claims, verification, and promotion gates.
Comparable conflicts become
clarifications[]; Dense-Mem does not silently overwrite active facts.The host LLM stays responsible for extracting candidates and asking the user questions. Dense-Mem stays responsible for durable state, gates, audit metadata, and recall.
Operators keep control of storage, team/profile isolation, API keys, and data egress boundaries.
60-Second Quickstart
Download the base local-only compose example and env template, set the required secrets, and start Dense-Mem:
mkdir dense-mem-local
cd dense-mem-local
curl -fsSLo docker-compose.yml \
https://raw.githubusercontent.com/markhuangai/dense-mem/main/examples/docker-compose.base.yml
curl -fsSLo .env.example \
https://raw.githubusercontent.com/markhuangai/dense-mem/main/examples/.env.example
cp .env.example .env
# Fill in POSTGRES_PASSWORD, NEO4J_PASSWORD, CONTROL_PORTAL_TOKEN, and AI_API_KEY.
${EDITOR:-vi} .env
docker compose up -d
docker compose exec server /app/provision-team --name "primary-memory"The base compose example provisions Postgres, neo4j:5.26-community with the
Neo4j Graph Data Science plugin, and the Dense-Mem server. It exposes only local
host ports:
MCP/API: http://127.0.0.1:8080/mcp
User portal: http://127.0.0.1:8080/ui
Control portal: http://127.0.0.1:8090/Cold image pulls can take longer than 60 seconds. Redis and public HTTPS are intentionally omitted from the base example; use the expert example when you need those deployment options.
The server requires a complete embedding configuration at startup:
AI_API_URL, AI_API_KEY, AI_API_EMBEDDING_MODEL, and
AI_API_EMBEDDING_DIMENSIONS. The compose examples provide OpenAI defaults for
the URL, model, and dimensions (https://api.openai.com/v1,
text-embedding-3-small, 1536), so the minimal local setup only needs you to
fill in AI_API_KEY. Override those values together when using a different
embedding provider or model.
Telemetry Overlay
Prometheus telemetry is optional and off by default. To collect usage,
performance, verifier token, embedding token, recall, and promotion metrics for
the /ui app and control portal dashboards, run the base stack with the
telemetry overlay:
curl -fsSLo prometheus.yml \
https://raw.githubusercontent.com/markhuangai/dense-mem/main/examples/prometheus.yml
curl -fsSLo docker-compose.telemetry.yml \
https://raw.githubusercontent.com/markhuangai/dense-mem/main/examples/docker-compose.telemetry.yml
export TELEMETRY_SCRAPE_TOKEN="$(openssl rand -hex 32)"
docker compose -f docker-compose.yml -f docker-compose.telemetry.yml up -dThe overlay starts Prometheus on 127.0.0.1:9090, retains 30 days of samples,
passes TELEMETRY_SCRAPE_TOKEN to Prometheus as a scrape secret, and points
Dense-Mem at http://prometheus:9090 for telemetry queries. It also sets
TELEMETRY_PROMETHEUS_JOB=dense-mem so dashboards query only the dense-mem
scrape job when Prometheus is shared.
Online recall-quality cards use densemem_recall_feedback_total and
densemem_recall_feedback_quality_score. They stay at zero until
RECALL_FEEDBACK_ENABLED=true registers the submit_recall_feedback tool and a
host LLM submits compact feedback for recall_memory results. Normal production
recall traffic still contributes request volume, result count, and latency.
For the disposable demo image, keep the control portal disabled and use the demo telemetry overlay instead:
curl -fsSLo prometheus.demo.yml \
https://raw.githubusercontent.com/markhuangai/dense-mem/main/examples/prometheus.demo.yml
curl -fsSLo docker-compose.demo.telemetry.yml \
https://raw.githubusercontent.com/markhuangai/dense-mem/main/examples/docker-compose.demo.telemetry.yml
export TELEMETRY_SCRAPE_TOKEN="$(openssl rand -hex 32)"
docker compose -f docker-compose.yml -f docker-compose.demo.telemetry.yml up -dThe demo overlay scrapes the demo service at demo:8091 on the private Compose
network and sets TELEMETRY_PROMETHEUS_JOB=dense-mem-demo. Do not publish that
metrics listener publicly.
Compare
Capability | Dense-Mem | File memory | Vector DB | Generic MCP memory |
Evidence provenance | Source fragments are stored before claims or facts | Usually absent or informal | Stores chunks, not truth history | Varies by implementation |
Fact changes | Verification gates and promotion rules | Manual edits | Similarity updates can obscure history | Often tool-specific |
Conflict handling | Comparable conflicts return clarification tasks | Caller must notice | Similar vectors do not mean contradiction | Usually caller-managed |
Recall | Facts, claims, fragments, contradictions, and clarifications | Text search | Vector similarity | Varies |
Agent boundary | Host LLM judges; Dense-Mem stores and enforces | Blurred | Retrieval only | Often blurred |
Operations | Teams, profiles, API keys, audit metadata, REST, OpenAPI, MCP | Minimal | Database operations | Varies |
Redis is optional for single-node deployments and required for multi-instance deployments.
Documentation
The README is the product overview. The full user documentation lives in the Dense-Mem wiki:
Goal | Wiki page |
Run Dense-Mem locally | |
Use memory day to day | |
Configure providers, Redis, and Traefik | |
Understand the system design | |
Review API and operations details |
Responsibility Boundary
Area | Dense-Mem owns | Host LLM owns |
Memory writes | Evidence fragments, typed claims, verification, gates, promotion | Extracting candidate memories from chat text |
Embeddings | Fragment embeddings and recall-query embeddings through the configured provider | No vectors for normal writes or recall |
Retrieval | Facts, validated claims, fragments, contradictions, clarification tasks | Choosing what to ask or cite in the conversation |
Truth changes | Comparable-conflict detection, confirmation-driven supersession | Asking the user which uncertain memory is correct |
Operations | Teams, named profiles, API keys, audit metadata, control portal | Client-side MCP configuration |
Dense-Mem is not an agent brain, planner, or external truth arbiter. It stores memory, applies explicit gates, and returns structured outcomes.
Memory Workflow
Tool | Purpose |
| Normal chat-session memory insertion. Saves evidence, creates typed claims, verifies, promotes when gates pass, and returns structured outcomes. |
| Ingests summarized historical conversations. By default it records evidence and validated claims without auto-promotion. |
| Retrieves facts, validated claims, fragments, and |
| Expands one fact or claim into bounded evidence, promotion lineage, contradictions, and supersession links. |
| Builds a bounded prompt-ready context block plus structured facts, claims, fragments, and clarifications. |
| Reviews active facts, candidate or disputed claims, contradictions, stale memories, and clarification needs. |
| Applies the user's answer to a clarification task, either accepting a claim and superseding comparable active facts or keeping/rejecting it. |
Low-level tools remain available for advanced callers: save_memory,
post_claim, verify_claim, promote_claim, search tools, graph query tools,
community tools, and retraction tools.
Memory moves through this path:
source fragment -> typed claim -> verification -> promotion gate -> active fact
|
v
clarification taskComparable conflicts are not resolved silently. Dense-Mem returns
clarifications[], and the host LLM asks the user which memory is correct. After
the user answers, the host calls confirm_memory.
Data Egress
Dense-Mem forwards fragment text and recall queries to the configured embedding provider. Claim verification can send candidate claims and supporting evidence to the configured verifier provider. Self-hosted providers keep that traffic inside your boundary; hosted providers do not. See the wiki Configuration and Technical Reference for provider settings and egress details.
Embedding Model Consistency
Dense-Mem owns embeddings for normal writes and recall. It checks the stored embedding model and dimension on startup so vectors from incompatible models are not mixed silently. Rotation requires re-embedding or rebuilding vector indexes; the step-by-step process belongs in the wiki Configuration.
Tool Discoverability
Dense-Mem exposes three discoverability surfaces backed by one registry:
Surface | Path | Purpose |
Tool catalog |
| Runtime tool discovery |
Runtime OpenAPI |
| Agents, codegen, integrations |
MCP Streamable HTTP |
| MCP clients over the main HTTP service |
The full route list and client examples live in the wiki Technical Reference and Quick Start.
Design Notes
License
Apache-2.0
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/markhuangai/dense-mem'
If you have feedback or need assistance with the MCP directory API, please join our Discord server