Skip to main content
Glama

ContextKeep Banner

ContextKeep 🧠

Infinite Long-Term Memory for AI Agents

Version: 1.3 Status: Stable Platform: Linux | Windows | macOS License: MIT Python 3.10+ MCP Compliant Docker Ready Ko-Fi

ContextKeep is a powerful, standalone memory server that gives your AI agents (Claude, Cursor, Gemini, OpenCode, and more) a persistent, searchable brain. Stop repeating yourself β€” let your AI remember everything, permanently.

Features β€’ What's New in V1.3 β€’ Installation β€’ MCP Tools β€’ Web Dashboard β€’ Configuration


🌟 Features

  • ♾️ Infinite Context: Store unlimited project details, preferences, decisions, and snippets β€” no expiry, no size cap.

  • πŸ’° Save Money & Tokens: Pull only the memories that matter, slashing context window usage and API costs.

  • πŸ”Œ Universal Compatibility: Works with any MCP-compliant client via Stdio (local) or SSE (remote/homelab).

  • 🧭 Memory Index Protocol: A reliable two-step retrieval system β€” list_all_memories() β†’ retrieve_memory() β€” so agents always find the right key, every time.

  • πŸ–₯️ Modern Web Dashboard: Manage your memories visually with Grid, List, and Calendar views in a sleek dark interface.

  • πŸ”’ Privacy First: 100% local storage. Your data never touches an external server.

  • πŸ”Ž Smart Search: Keyword and semantic search across all memory content.

  • 🐧 Linux Service: Runs silently in the background as a systemd service.

  • 🐳 Docker Ready: One-command deployment with Docker Compose.

  • ⬇️ Export & Backup: Export all memories as JSON via MCP tool or WebUI.


ContextKeep Showcase


πŸ†• What's New in V1.3 β€” Harbor

🐳 Docker Support

The #1 community request. ContextKeep now ships with a Dockerfile and docker-compose.yml for one-command deployment:

docker compose up --build

That's it. MCP server on :5100, WebUI on :5000, with persistent storage via Docker volumes.

πŸ“¦ Modern Python Packaging

  • pyproject.toml β€” canonical dependency spec for uv, poetry, or pip

  • uv support β€” the installer auto-detects uv and uses uv sync for blazing-fast setup

  • Backwards compatible β€” pip install -r requirements.txt still works

πŸ› οΈ 3 New MCP Tools (5 β†’ 8 total)

New Tool

Purpose

delete_memory(key)

Agents can now delete memories directly

get_memory_stats()

Memory count, total chars, storage path at a glance

export_memories()

Full backup as JSON β€” for migration or archival

⬇️ WebUI Export

  • Export All button in the toolbar (or press Ctrl+E)

  • Downloads a timestamped contextkeep_backup_YYYY-MM-DD.json

🧹 Code Quality

  • Fixed dead code in memory_manager.py (unreachable duplicate try/except)

  • Added missing core/__init__.py for proper Python packaging

  • Replaced bare except: with except Exception: throughout


πŸš€ Installation

Option 1: Quick Start (pip)

  1. Clone the repository:

    git clone https://github.com/mordang7/ContextKeep.git
    cd ContextKeep
  2. Run the Installer:

    • Linux/macOS:

      python3 install.py
    • Windows:

      python install.py
  3. Follow the Wizard: The installer creates a virtual environment, installs dependencies, and generates a ready-to-use mcp_config.json.

Option 2: uv (Fast)

git clone https://github.com/mordang7/ContextKeep.git
cd ContextKeep
uv sync
uv run python server.py
git clone https://github.com/mordang7/ContextKeep.git
cd ContextKeep
docker compose up --build -d

This starts:

Service

Port

Purpose

mcp-server

5100

MCP server (SSE transport)

webui

5000

Web dashboard

Memories persist in a Docker volume (contextkeep-data).


πŸ› οΈ MCP Tools

ContextKeep exposes 8 MCP tools to any connected agent:

Tool

Signature

Purpose

list_all_memories

(no args)

[USE FIRST] Returns a full directory of all memory keys, titles, tags, and timestamps

retrieve_memory

(key: str)

Fetch the full content of a specific memory by exact key

store_memory

(key: str, content: str, tags: str)

Create or update a memory

search_memories

(query: str)

Content-based keyword/semantic search across all memories

list_recent_memories

(no args)

Return the 10 most recently updated memories

delete_memory

(key: str)

Delete a memory permanently by key

get_memory_stats

(no args)

Get total memory count, character count, and storage path

export_memories

(no args)

Export all memories as a JSON array

Add this to your GEMINI.md, AGENTS.md, or CLAUDE.md:

## Memory Index Protocol (MANDATORY)
1. FIRST β€” call `list_all_memories()` to get the complete key directory
2. THEN β€” call `retrieve_memory(exact_key)` using the exact key from step 1
Only use `search_memories()` for content-based searches, NOT for key lookup.

πŸ”Œ Configuration

Copy the contents of mcp_config.example.json into your AI client's config file and update the paths.

Option 1: Local (Claude Desktop / Gemini CLI / Cursor)

{
  "mcpServers": {
    "context-keep": {
      "command": "/absolute/path/to/ContextKeep/venv/bin/python",
      "args": ["/absolute/path/to/ContextKeep/server.py"]
    }
  }
}

Option 2: Remote via SSH (Homelab / Raspberry Pi)

Run ContextKeep on a home server and access it from any machine on your network:

{
  "mcpServers": {
    "context-keep": {
      "command": "ssh",
      "args": [
        "-i", "/path/to/private_key",
        "user@192.168.1.X",
        "'/path/to/ContextKeep/venv/bin/python'",
        "'/path/to/ContextKeep/server.py'"
      ]
    }
  }
}

Option 3: SSE Mode (HTTP)

Ideal for OpenCode, web apps, or any client that prefers HTTP transport:

{
  "mcpServers": {
    "context-keep": {
      "transport": "sse",
      "url": "http://localhost:5100/sse"
    }
  }
}

Option 4: Docker

Use mcp_config.docker.example.json or point your client to the container:

{
  "mcpServers": {
    "context-keep": {
      "transport": "sse",
      "url": "http://localhost:5100/sse"
    }
  }
}

🌐 Web Dashboard

ContextKeep ships with a full-featured web UI to manage your memories without touching the CLI.

  • URL: http://localhost:5000

  • Grid View: Memory cards with tag chips, char counts, and inline actions

  • List View: Dense, scannable table with all memories sorted by last updated

  • Calendar View: Browse your memory history by month

  • Search: Real-time filtering across titles, keys, and content

  • Full CRUD: Create, view, edit, and delete memories from the browser

  • Export: Download all memories as JSON with one click (Ctrl+E)

To start manually:

./venv/bin/python webui.py

Run both the MCP server and Web UI as persistent background services:

chmod +x install_services.sh
./install_services.sh

This installs:

Service

Port

Purpose

contextkeep-server

5100

MCP server (SSE transport)

contextkeep-webui

5000

Web dashboard

Manage services:

sudo systemctl status contextkeep-server
sudo systemctl restart contextkeep-webui

πŸ“‹ Changelog

V1.3 β€” Harbor

  • βœ… Docker Support β€” Dockerfile + docker-compose.yml for one-command deployment

  • βœ… Modern Packaging β€” pyproject.toml + uv support alongside pip

  • βœ… New MCP tool: delete_memory() β€” agents can now delete memories

  • βœ… New MCP tool: get_memory_stats() β€” memory count & size at a glance

  • βœ… New MCP tool: export_memories() β€” full backup as JSON

  • βœ… WebUI: Export All button with Ctrl+E shortcut

  • βœ… WebUI: Stats API endpoint

  • βœ… Fix: Removed dead code in memory_manager.py

  • βœ… Fix: Added missing core/__init__.py for Docker/package imports

  • βœ… Fix: Bare except replaced with except Exception

  • βœ… Updated installer to V1.3 with uv detection

  • βœ… Community contributors credited πŸ™

V1.2 β€” Obsidian Lab

  • βœ… New list_all_memories() MCP tool β€” complete memory directory in one call

  • βœ… Obsidian Lab UI redesign β€” dark premium aesthetic with cyan/neon accents

  • βœ… Memory count live badge in the header

  • βœ… Calendar month navigation (forward/back)

  • βœ… Grid cards now show tag chips and character count badges

  • βœ… Removed "Recent Memories" sidebar for a cleaner calendar layout

  • βœ… Memory Index Protocol V1.2 β€” standardised two-step agent retrieval pattern

V1.1

  • Web dashboard with Grid, List, and Calendar views

  • SSE transport support alongside Stdio

  • Linux systemd service installer

  • Memory titles and timestamps

V1.0

  • Core MCP server with store_memory, retrieve_memory, search_memories

  • JSON-backed persistent storage

  • SSH remote transport support


🀝 Contributing

Contributions are welcome. Open a PR, file an issue, or suggest a feature β€” all input is appreciated.

V1.3 Community Contributors

A huge thank you to everyone who contributed to the Harbor release:

β˜• Support the Project

If ContextKeep saves you time, tokens, or sanity β€” consider buying me a coffee.

Ko-Fi


-
security - not tested
F
license - not found
-
quality - not tested

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/mordang7/ContextKeep'

If you have feedback or need assistance with the MCP directory API, please join our Discord server