Skip to main content
Glama

memory-mcp

Persistent, searchable, versioned memory for AI agents — backed by Valkey (Redis-compatible), exposed as an MCP server over HTTP.

Works with any MCP-compatible agent: Claude Code, Cursor, VS Code, and others.

What it does

  • Stores named memory entries with tags, types, and project scopes

  • Tag-intersection search, type/project filtering, and substring search

  • Hit tracking (entries accessed more float to the top)

  • Full version history with rollback

  • Prometheus metrics endpoint

  • Optional bearer token auth

Quick start

cp .env.example .env
# Optional: set MEMORY_MCP_AUTH_TOKEN in .env (see Auth section)
docker compose up -d

This pulls the pre-built image from GHCR. The MCP server is now available at http://127.0.0.1:3106/mcp.

To build locally instead:

docker compose build
docker compose up -d

Using an existing Redis or Valkey

By default docker compose up -d starts a bundled Valkey container. To connect to an existing Redis or Valkey instance instead, set VALKEY_URL and start only the memory-mcp service:

# .env
VALKEY_URL=redis://your-host:6379

docker compose up -d memory-mcp

Any Redis-compatible server (Redis 6+, Valkey, KeyDB, Upstash via rediss://, etc.) works. The server uses only basic data structures: hashes, lists, and sets.

Agent setup

Copy AGENTS.md from this repo into your project root. It tells your agent how to use the memory tools, what to store, and when.

Then register the MCP server with your agent client:

Claude Code

# Without auth
claude mcp add memory --transport http http://127.0.0.1:3106/mcp

# With auth
claude mcp add memory --transport http http://127.0.0.1:3106/mcp \
  --header "Authorization: Bearer your-token"

Or add manually to ~/.claude.json:

{
  "mcpServers": {
    "memory": {
      "type": "http",
      "url": "http://127.0.0.1:3106/mcp",
      "headers": { "Authorization": "Bearer your-token" }
    }
  }
}

Cursor

Add to ~/.cursor/mcp.json (global) or .cursor/mcp.json (project):

{
  "mcpServers": {
    "memory": {
      "url": "http://127.0.0.1:3106/mcp",
      "headers": { "Authorization": "Bearer your-token" }
    }
  }
}

VS Code (GitHub Copilot, MCP extension)

Add to .vscode/mcp.json in your project:

{
  "servers": {
    "memory": {
      "type": "http",
      "url": "http://127.0.0.1:3106/mcp",
      "headers": { "Authorization": "Bearer your-token" }
    }
  }
}

Omit the headers / Authorization line in any config if you are not using auth.

Configuration

Copy .env.example to .env and edit as needed.

Variable

Default

Description

MEMORY_MCP_BIND

127.0.0.1

Interface to bind on. Use 0.0.0.0 only with AUTH_TOKEN set.

MEMORY_MCP_HOST_PORT

3106

Port exposed on the host

MEMORY_MCP_AUTH_TOKEN

(empty)

Bearer token for /mcp. Empty = no auth. Generate: openssl rand -hex 32

MEMORY_MCP_MAX_ENTRIES_WARN

300

Soft cap — warns on write when exceeded

MEMORY_MCP_MAX_VERSIONS_PER_ENTRY

20

Max version snapshots per entry

MEMORY_MCP_MEM_LIMIT

256m

Container memory cap

VALKEY_IMAGE

valkey/valkey:9.0.3

Valkey image to use

Auth

By default the server runs unauthenticated. This is safe when bound to loopback (127.0.0.1) and accessed only from the local machine.

To enable auth:

# Generate a token
openssl rand -hex 32

# Add to .env
MEMORY_MCP_AUTH_TOKEN=your-generated-token

docker compose up -d

All requests to POST /mcp must then include:

Authorization: Bearer <token>

GET /health and GET /metrics are always unauthenticated.

Available tools

Tool

Description

memory_search

Search by tags (intersection), type, project, or text substring

memory_get

Fetch one entry by ID (increments hit counter)

memory_set

Create or update an entry (versioned on every write)

memory_list

List entries with optional type/project filter

memory_delete

Delete an entry (tombstone version written first)

memory_history

View version history for an entry

memory_rollback

Restore an entry to a previous version

memory_prune_candidates

Surface zero-hit stale entries for review (read-only)

Memory types

pattern, decision, reference, feedback, incident, project, entity, state

Endpoints

Method

Path

Auth

Description

POST

/mcp

if configured

MCP JSON-RPC endpoint

GET

/health

none

Health check

GET

/metrics

none

Prometheus metrics

Data model

Each entry is stored as a Redis hash at mem:<id>:

Field

Description

title

Short descriptive title

body

Full content

type

Entry type

tags

Comma-separated tag list

source

Who wrote it

project

Project scope (empty = cross-project)

created

ISO date of creation

updated

ISO date of last update

hits

Times retrieved via memory_get

ttl

Expiry in seconds (optional)

Version history is stored in a Redis list at memver:<id> (newest-first, capped at MAX_VERSIONS_PER_ENTRY).

Tag, type, and project indexes are Redis sets (tag:<name>, type:<name>, project:<name>).

License

MIT

A
license - permissive license
-
quality - not tested
B
maintenance

Maintenance

Maintainers
Response time
0dRelease cycle
2Releases (12mo)

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/joshdougall/memory-mcp'

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