distillory
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., "@distilloryremember that the client wants early delivery"
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.
distillory
The local-first memory engine that synthesizes at ingestion — not just stores.
Most "AI memory" is a logging layer with a vector index bolted on: it accumulates
facts and re-derives meaning on every query. distillory reasons once, at
ingestion — each new source updates one living, schema-graded profile per
entity, resolving contradictions and grounding facts in time, so every later read
is cheap and already-reasoned.
One embeddable SQLite file. No server, no Docker, no Postgres, no hosted reranker. Runs offline with no API key out of the box; bring your own model (Claude, an API key, or local) when you want real synthesis. MIT, engine included.
from distillory import Memory
mem = Memory.open("brain.db") # one file. works with zero config.
mem.add("Met David at LucidWay — wants the GTSI automation, ~$10k", entity="David Chen")
print(mem.profile("David Chen").body) # a synthesized profile, not a raw echoInstall
Not on PyPI yet — install from the repo (works today).
pip install distillorylands with the first release.
# core (numpy is the only dependency): FTS5 keyword + hash-embed + offline synthesis
pip install "distillory @ git+https://github.com/everyai-com/distillory"
# with the MCP server (for Claude / agents)
pip install "distillory[mcp] @ git+https://github.com/everyai-com/distillory"
# with real embeddings (bge-small ONNX) + Anthropic synthesis [hybrid retrieval: slice 4]
pip install "distillory[embed-fastembed,llm-anthropic] @ git+https://github.com/everyai-com/distillory"Extra | Adds |
(none) | FTS5 keyword search, hash-embed, extractive synthesis — fully offline |
| the |
| the |
|
|
| other synthesis providers |
|
|
Related MCP server: engram
60-second tour (offline, no key)
from distillory import Memory
mem = Memory.open("brain.db", synth="none", embed="hash") # true air-gap floor
# Two notes, dropped as they happen — they COMPOUND into one profile.
mem.add("David at LucidWay wants the GTSI automation, ~$10k", entity="David Chen")
mem.add("Follow-up: confirmed, also wants a dashboard. Based in New York.", entity="David Chen")
print(mem.profile("David Chen").body) # one living profile
for h in mem.search("GTSI dashboard"): # cited recall, profile first
print(h.kind, h.title, "<-", h.citations)With a key, the profile is genuinely synthesized and self-corrects:
mem = Memory.open("brain.db", synth="auto") # uses ANTHROPIC_API_KEY if present
mem.add("David is based in New York", entity="David Chen", event_date="2026-05-01")
mem.add("David just moved to London", entity="David Chen", event_date="2026-06-18")
mem.synthesize(entity="David Chen")
# profile now reads "London (moved 2026-06, was NY)" — not two contradictory facts
mem.ledger("David Chen") # the NY 'assert' is now [superseded] by a London 'update' — queryableMore in examples/.
The four verbs
Verb | What it does |
| Append an immutable source, chunk + embed + index, mark dirty. Deterministic, no LLM. |
| Cited recall — synthesized profiles first, then raw chunks. (Dense + RRF hybrid: slice 4.) |
| Read one entity's full living profile — the cheap, already-reasoned answer. |
| The dreamer: (re)synthesize a profile against the schema. The one expensive verb. |
Plus entities(), ledger() (the structured edge-typed facts behind a profile),
ingest(path), graph(), doctor(), and the mem CLI (1:1 with the API).
Plug it into Claude / agents (MCP)
distillory speaks MCP, so Claude Code, Claude
Desktop, or any MCP client gets persistent, synthesizing memory in one line:
// ~/.claude.json
{ "mcpServers": { "memory": {
"command": "mem",
"args": ["serve", "--mcp", "--db", "~/brain.db"]
} } }Tools memory_add / search / profile / entities / synthesize / graph + a
memory://profile/{slug} resource. stdio by default — no network, no port, no key.
Full guide: examples/mcp_with_claude.md. Non-Python
callers can use the zero-dep HTTP API: mem serve --http.
The schema is the trick
Every synthesis is graded against a schema — a definition of what a complete profile looks like, read before every write. Pass your own:
mem = Memory.open("brain.db", schema="./outcomes.md")Without it, synthesis drifts to a generic standard. With it, every write is held to your rules. That's the difference from a notes file, and from hand-authored skills.
Bring your own model
mem = Memory.open("brain.db", synth=MyOllamaSynth(), embed=MyEmbedder())synth takes "auto" | "none" | "claude" | "anthropic:<model>" | "ollama:<model>"
or any object with .complete() / .synthesize(). embed takes
"fastembed" | "potion" | "hash" | "none" or any object with .embed(). Both fall
through to an always-available floor, so a bare offline machine still works.
How it compares
Architecture, not benchmarks (we don't claim a recall number until we've run one —
see the roadmap). Full table + caveats + sources in
docs/COMPARISON.md.
distillory | mem0 | supermemory | Letta | |
Embeddable (no server) | ✅ one SQLite file | ✅ pip + Qdrant | ❌ local server | ❌ server |
Default offline, no key | ✅ | ❌ (OpenAI default) | ❌ (LLM at ingest) | ❌ |
Infra to run | none | pip + LLM key | self-host binary + LLM | Postgres/pgvector + LLM |
Approach | one per-entity profile | atomic facts | synthesize | store-and-retrieve |
All of these are good tools — the distinctions are about defaults and architecture (embeddable, offline, single-file), not capability ceilings. See the caveats doc; we keep it fair and up to date.
Status
v0.1: the keyword core, schema-graded synthesis with a fact-ledger grader
(validate→repair→retry, then contradiction resolution persisted as structured,
edge-typed rows — mem ledger), one SQLite file, the mem CLI, and an MCP +
HTTP server so any Claude / agent gets persistent memory today. Roadmap, in
order: dense (fastembed) + RRF hybrid retrieval, the nightly "dreaming" gap pass,
and LongMemEval / LOCOMO benchmarks. We don't pitch "hybrid" or numbers we haven't run.
Heir to mbrain (keyword-only); the synthesis engine is extracted from a production desktop app.
Contributing
Small, typed, honest — see CONTRIBUTING.md. make install && make test
(22 tests, all offline, no key). Issues and PRs welcome.
License
MIT.
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/everyai-com/distillory'
If you have feedback or need assistance with the MCP directory API, please join our Discord server