Local MCP memory arbiter with dual timeline conflict handling.
Project description
mcp-name: io.github.billy12151/memory-arbiter-mcp
memory-arbiter-mcp
English
A lightweight, fully local MCP Server that gives your AI coding tools a shared memory store with built-in conflict arbitration.
Every tool — ZCode, Codex, Cursor, Claude Code — has its own memory. They don't talk to each other. Memory Arbiter fixes this: one SQLite database, all tools read and write through the same MCP protocol, conflicts are resolved by structured rules (not LLM guesswork).
Features
- Structured memory write:
content,agent_id,workspace,tags,source_type,event_time,ingest_time,confidence,protection_level, and more. - Source trust levels:
user_confirmed>document_extracted>agent_generated>unknown. - Dual timeline arbitration: resolves conflicts by user confirmation → event time → source trust → ingest time. Every decision comes with an explainable rationale.
- Locked protection:
user_confirmedmemories are automatically locked — no agent can overwrite them. - Client policy system: per-client enable/disable, agent allow/deny lists for multi-agent governance.
- Graceful degradation:
sqlite-vec→ FTS5 →LIKE→ JSONL backup. Never crashes. - Zero cloud, zero LLM calls: pure local SQLite. No Postgres, Redis, or external services.
Quick Start
Requirements: Python 3.11+
# Clone
git clone https://github.com/billy12151/memory-arbiter-mcp.git
cd memory-arbiter-mcp
# Setup
python3.11 -m venv .venv
source .venv/bin/activate
pip install -r requirements.txt
pip install -e .
# Optional: semantic recall via sqlite-vec
pip install '.[vec]'
# Run
memory-arbiter-mcp
Connect Your Tool
Add to your tool's MCP config (see examples/ for ready-made templates):
{
"mcpServers": {
"memory-arbiter": {
"command": "/path/to/memory-arbiter-mcp/.venv/bin/memory-arbiter-mcp",
"env": {
"MEMORY_ARBITER_CLIENT": "zcode",
"MEMORY_ARBITER_AGENT_ID": "zcode-default",
"MEMORY_ARBITER_DB_PATH": "~/.local/share/memory-arbiter/memory.sqlite3"
}
}
}
}
Change
MEMORY_ARBITER_CLIENTfor each tool (zcode,codex,cursor,claude-code). All tools share the sameDB_PATH— that's the whole point.
⚠️ New session required: MCP servers are loaded at session startup. Already-open sessions won't see the new tools. Start a fresh session after configuring.
Client Config Locations
| Client | Config Location |
|---|---|
| ZCode | ~/.zcode/v2/ MCP config |
| Codex CLI | ~/.codex/ MCP config |
| Claude Code | .mcp.json in project root |
| Cursor | ~/.cursor/mcp.json |
MCP Tools
| Tool | Description |
|---|---|
memory_write |
Write a memory (source_type=user_confirmed auto-locks) |
memory_search |
Search memories (FTS5 → LIKE fallback) |
memory_compare |
Compare two memories, returns explanation only |
memory_arbitrate |
Arbitrate conflict, can record result (apply=true) |
memory_confirm |
Promote a memory to user-confirmed and locked |
memory_list_conflicts |
List unresolved conflicts |
memory_status |
Show current mode, degradation status, storage paths |
Data Migration
Moving to a new machine? Just copy the SQLite file:
# Copy the database
cp ~/.local/share/memory-arbiter/memory.sqlite3 /new/machine/~/.local/share/memory-arbiter/
# Reinstall the project (don't copy .venv — rebuild it)
python3.11 -m venv .venv
source .venv/bin/activate
pip install -e .
Testing
python3.11 -m pip install -r requirements.txt
python3.11 -m pytest
License
MIT
中文
一个轻量、完全本地运行的 MCP Server,给你的 AI 编程工具提供共享记忆库,内置冲突仲裁机制。
你同时用 ZCode、Codex、Cursor、Claude Code——每个工具都有各自的记忆,互不相通。Memory Arbiter 解决这个问题:一个 SQLite 数据库,所有工具通过同一个 MCP 协议读写,冲突由结构化规则仲裁,不依赖大模型。
核心能力
- 结构化写入:
content、agent_id、workspace、tags、source_type、event_time、ingest_time、confidence、protection_level等。 - 来源可信度:
user_confirmed>document_extracted>agent_generated>unknown。 - 双时间轴仲裁:按 用户确认 → 事件发生时间 → 来源可信度 → 录入时间 的优先级判定,输出可解释的裁决理由。
- 锁定保护:
user_confirmed的记忆自动锁定,任何 Agent 都不能自动覆盖。 - 客户端策略:按客户端启用/禁用,Agent 级别的 allow/deny 白名单控制。
- 逐级降级:
sqlite-vec→ FTS5 →LIKE→ JSONL 备份,不会崩。 - 零云依赖、零大模型调用:纯本地 SQLite,不需要 Postgres、Redis 或外部服务。
快速开始
要求:Python 3.11+
# 克隆
git clone https://github.com/billy12151/memory-arbiter-mcp.git
cd memory-arbiter-mcp
# 安装
python3.11 -m venv .venv
source .venv/bin/activate
pip install -r requirements.txt
pip install -e .
# 可选:启用语义召回增强(sqlite-vec)
pip install '.[vec]'
# 启动
memory-arbiter-mcp
接入工具
在你的工具的 MCP 配置中加入(完整示例见 examples/ 目录):
{
"mcpServers": {
"memory-arbiter": {
"command": "/path/to/memory-arbiter-mcp/.venv/bin/memory-arbiter-mcp",
"env": {
"MEMORY_ARBITER_CLIENT": "zcode",
"MEMORY_ARBITER_AGENT_ID": "zcode-default",
"MEMORY_ARBITER_DB_PATH": "~/.local/share/memory-arbiter/memory.sqlite3"
}
}
}
}
每个工具改一下
MEMORY_ARBITER_CLIENT标识(zcode、codex、cursor、claude-code),共享同一个DB_PATH——这就是跨工具记忆共享的关键。
⚠️ 需要新建会话:MCP Server 在客户端启动时加载,已经打开的会话不会识别新添加的 Server。配置好后请新建一个会话。
客户端配置位置
| 客户端 | 配置文件位置 |
|---|---|
| ZCode | ~/.zcode/v2/ 下 MCP 配置 |
| Codex CLI | ~/.codex/ 下 MCP 配置 |
| Claude Code | 项目根目录 .mcp.json |
| Cursor | ~/.cursor/mcp.json |
MCP 工具
| 工具 | 说明 |
|---|---|
memory_write |
写入记忆(source_type=user_confirmed 自动锁定) |
memory_search |
搜索记忆(FTS5 → LIKE 自动降级) |
memory_compare |
比较两条记忆,只返回解释 |
memory_arbitrate |
仲裁冲突,自动判定胜者(apply=true 时落记录) |
memory_confirm |
用户确认某条记忆,锁定保护 |
memory_list_conflicts |
列出未解决的冲突 |
memory_status |
查看运行状态、模式、降级原因 |
数据迁移
换电脑只需拷贝一个文件:
# 拷贝数据库
cp ~/.local/share/memory-arbiter/memory.sqlite3 新电脑:~/.local/share/memory-arbiter/
# 重新安装项目(.venv 不要拷贝,新机器上重建)
python3.11 -m venv .venv
source .venv/bin/activate
pip install -e .
测试
python3.11 -m pip install -r requirements.txt
python3.11 -m pytest
License
MIT
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file memory_arbiter_mcp-0.2.0.tar.gz.
File metadata
- Download URL: memory_arbiter_mcp-0.2.0.tar.gz
- Upload date:
- Size: 19.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.15
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c36fe0758d799c68af9335076694825516810ce597f3932a08be70836c632766
|
|
| MD5 |
9d8178f9c5b86d008e43ea6b6a8d38e5
|
|
| BLAKE2b-256 |
f9868cd3647ac126629c86542c7f7fd19de11d13dc60d19cbb7042cbfd145896
|
File details
Details for the file memory_arbiter_mcp-0.2.0-py3-none-any.whl.
File metadata
- Download URL: memory_arbiter_mcp-0.2.0-py3-none-any.whl
- Upload date:
- Size: 18.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.15
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c268c8a03c34b4426217d71c5ae490efab7026a9794faac37bcf95add3b0d5be
|
|
| MD5 |
b6e0fe84053c0eb3be1c48ec6712a800
|
|
| BLAKE2b-256 |
046e49de64b2b5176e08893c6c720b93371ae0f309b65332aab3ede822d03864
|