MemoryThreads
Integrates with OpenAI Codex to capture and recall conversation history, allowing seamless switching between Claude Code and Codex with shared 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., "@MemoryThreadsrecall context about the auth bug from last week"
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.
MemoryThreads
Persistent, searchable conversation memory shared across Claude Code and Codex.
MemoryThreads is a local MCP server that auto-captures every conversation turn from both Claude Code and OpenAI Codex into one SQLite database, then makes that history instantly searchable from any future session - hybrid BM25 (FTS5) + vector (sqlite-vec) recall, with cross-platform thread continuity. Start work in Claude Code, continue it in Codex, and either side can recall the full shared history.
No cloud, no account - everything lives in ~/.claude/memory-server/ on your machine.
Why
LLM coding sessions are stateless - close the terminal and the context is gone. MemoryThreads fixes that:
Never re-explain.
recall_context("that auth bug from last week")pulls the actual prior turns.Cross-tool. Claude Code and Codex write into and read from the same memory, so switching tools never loses the thread.
Automatic. Hooks capture turns on every session; you don't manage it.
Fast + private. Local SQLite, FTS5 + sqlite-vec. Your conversations never leave your machine.
Related MCP server: rawthink
How it works
Claude Code ─┐ ┌─ recall_context / search_docs
├─ hooks ─► jobs queue ─► worker.js ─► SQLite ◄─┤ (MCP tools)
Codex ─┘ (capture) (parse + embed) └─ mt launch (resume)Capture. Session hooks (Stop, PreCompact, UserPromptSubmit) queue each session's transcript for ingestion. A launchd file-watcher (
incremental-sync.js) also ingests Claude Code turns continuously.Parse + embed.
worker.jsparses transcripts (dual-format: Claude Code JSONL and Codex rollout JSONL viatranscript-parser.js), stores turns + threads, and embeds each turn (OpenAItext-embedding-3-small, 1536-dim) into a sqlite-vec table.Recall. The MCP server (
server.js) exposesrecall_context, which runs hybrid BM25 + cosine search over turns/threads and returns the matches to the model.Continuity. A
canonical_thread_idlinks a Claude Code stream and a Codex stream into one logical MemoryThread, so continuation works across both tools without sharing native session files.
MCP tools
Tool | Purpose |
| Hybrid BM25 + vector search. |
| FTS5 search over ingested reference docs. |
| Add a reference doc (URL, llms.txt, or local file). |
| Manage ingested docs. |
| Bookmark the current session as a named MemoryThread. |
| Manage and resume bookmarks. |
Slash commands & CLI
/mt-save <name>,/mt-list,/mt-delete <name>,/mt-doc-ingest <source>mt launch(terminal) - interactive picker to resume a saved thread.
Data model
One SQLite DB (data/memory.db). Core tables: threads, turns, turns_fts (FTS5), turn_embeddings (sqlite-vec), plus saved_threads, active_memory_threads, docs, tool_uses, summaries, recovery_buffer, and the worker jobs queue. Full DDL in SCHEMA.md.
Recall operates directly over conversation turns and threads - there is no extracted-knowledge layer.
Setup
See SETUP.md for the full guide. In short:
npm installPut
OPENAI_API_KEY=...in.env(gitignored).Register the MCP server:
claude mcp add --scope user memory node ~/.claude/memory-server/server.js(and the[mcp_servers.memory]block in~/.codex/config.tomlfor Codex).Add the hooks block to
~/.claude/settings.jsonand~/.codex/hooks.json.Start the worker via the launchd watchdog.
Hooks
Event | Script | Role |
|
| Status line; compaction recovery |
|
| Inject relevant prior turns + active-thread context |
|
| Snapshot recent turns to |
|
| Queue the session transcript for ingestion |
The same hook scripts serve both Claude Code (settings.json) and Codex (hooks.json).
Tech stack
Node.js (ES modules) · better-sqlite3 · sqlite-vec · OpenAI embeddings · @modelcontextprotocol/sdk · SQLite FTS5.
Privacy
All data is local. .env (your API key) and data/ (the DB) are gitignored and never committed.
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/v3velev/memorythreads'
If you have feedback or need assistance with the MCP directory API, please join our Discord server