Skip to main content

MCP server for Mem0 agent memory management with multi-backend support

Project description

Mem0 Agent Memory

PyPI version PyPI Downloads PyPI Downloads Python versions License: MIT

MCP server for Mem0 agent memory management with multi-backend support.

Features

  • Multi-backend: FAISS (local), OpenSearch (AWS), Mem0 Platform (cloud)
  • AWS Bedrock integration: Uses Amazon Titan embeddings and Claude 3.5 Haiku for processing
  • Auto user detection: Uses system username when no user_id provided
  • Relevance filtering: Returns memories with score > 0.7
  • Complete memory operations: store, search, list, get, delete, history
  • Pagination support: Handle large memory collections efficiently
  • Recent memory tracking: Get latest updates for session continuity
  • Robust error handling: Graceful fallbacks and clear error messages

Installation

pip install mem0-agent-memory

Quick Start

# Run directly with uvx
uvx mem0-agent-memory

# Or install and run
pip install mem0-agent-memory
python -m mem0_agent_memory

Configuration

AWS Configuration

For AWS Bedrock integration (used by default), ensure AWS credentials are configured:

# Option 1: AWS CLI configuration
aws configure

# Option 2: Environment variables
export AWS_ACCESS_KEY_ID="your-access-key"
export AWS_SECRET_ACCESS_KEY="your-secret-key"
export AWS_REGION="us-west-2"

Environment Variables

# FAISS (default - uses .mem0/memory in current directory)
export FAISS_PATH="/path/to/memory/storage"  # Optional

# OpenSearch
export OPENSEARCH_HOST="your-opensearch-endpoint"
export AWS_REGION="us-west-2"

# Mem0 Platform
export MEM0_API_KEY="your-api-key"

# User/Agent ID (optional - auto-detects if not provided)
export MEM0_USER_ID="custom-user-id"      # Defaults to system username
export MEM0_AGENT_ID="custom-agent-id"    # Defaults to workspace name

MCP Client Setup

Amazon Q CLI

Create or edit the MCP configuration file:

Global Scope: ~/.aws/amazonq/mcp.json Local Scope: .amazonq/mcp.json (project-specific)

{
  "mcpServers": {
    "mem0-agent-memory": {
      "command": "uvx",
      "args": ["mem0-agent-memory"],
      "env": {
        "FAISS_PATH": "/Users/yourname/.mem0/agent",
        "MEM0_USER_ID": "john",
        "MEM0_AGENT_ID": "my-project"
      }
    }
  }
}

KIRO

Add to your KIRO MCP configuration:

{
  "mcpServers": {
    "mem0-agent-memory": {
      "command": "uvx",
      "args": ["mem0-agent-memory"],
      "env": {
        "FAISS_PATH": "/Users/yourname/.mem0/agent",
        "MEM0_USER_ID": "john",
        "MEM0_AGENT_ID": "my-project"
      }
    }
  }
}

Agent Steering: Use the content from docs/KIRO_AGENT_STEERING.md as your agent steering document to enable memory-first development workflows.

Tools

  • store_memory(content, user_id?, agent_id?, metadata?) - Store memory with metadata
  • search_memories(query, user_id?, agent_id?, limit?, page?, page_size?) - Search with relevance filtering & pagination
  • list_memories(user_id?, agent_id?, page?, page_size?) - List all memories with pagination
  • get_memory(memory_id) - Get specific memory by ID
  • delete_memory(memory_id) - Delete memory by ID (permanent)
  • get_memory_history(memory_id) - Get change history for memory
  • get_recent_memory(days?, limit?, user_id?, agent_id?) - Get recent memories for session continuity

Usage Examples

Store Memory

Auto-detect user:

{"content": "User prefers React over Vue"}

With metadata:

{"content": "API endpoint changed", "metadata": {"type": "technical", "priority": "high"}}

Specific user:

{"content": "Project deadline is next Friday", "user_id": "john"}

Search Memories

Basic search:

{"query": "React preferences"}

With pagination:

{"query": "API endpoints", "limit": 5, "page": 2}

Specific user:

{"query": "project status", "user_id": "john"}

List Memories

Auto-detect user with pagination:

{"page": 1, "page_size": 10}

Specific user:

{"user_id": "john", "page": 2, "page_size": 25}

Get Recent Memories

Last week (default):

{}

Last 3 days, limit 5:

{"days": 3, "limit": 5}

Specific user:

{"days": 7, "user_id": "john"}

Memory Management

Get specific memory:

{"memory_id": "cafdf73c-f8c7-4729-b840-e88ce7d8a67c"}

Get memory history:

{"memory_id": "cafdf73c-f8c7-4729-b840-e88ce7d8a67c"}

Delete memory (permanent):

{"memory_id": "cafdf73c-f8c7-4729-b840-e88ce7d8a67c"}

Architecture

Backend Auto-Detection

  1. Mem0 Platform: If MEM0_API_KEY is set
  2. OpenSearch: If OPENSEARCH_HOST is set
  3. FAISS: Default fallback (local storage in .mem0/memory)

Auto User/Agent Detection

When neither user_id nor agent_id is provided, automatically detects:

  • user_id: MEM0_USER_ID env var → system username
  • agent_id: MEM0_AGENT_ID env var → workspace name (current directory)

This enables dual memories: user memories are personal, agent memories are workspace-specific.

Relevance Filtering

Search results automatically filtered to return only memories with relevance score > 0.7, ensuring high-quality results.

Error Handling

  • Automatic fallback to /tmp if FAISS path is not writable
  • Clear error messages for missing dependencies
  • Graceful handling of network issues and invalid parameters

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

Citation

If you use this software in your research or project, please cite it as:

@software{selvam_mem0_agent_memory_2025,
  author = {Selvam, Arunkumar},
  title = {Mem0 Agent Memory - MCP Server},
  url = {https://github.com/arunkumars-mf/mem0-agent-memory},
  version = {1.0.0},
  year = {2025}
}

License

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

mem0_agent_memory-1.0.8.tar.gz (111.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

mem0_agent_memory-1.0.8-py3-none-any.whl (13.5 kB view details)

Uploaded Python 3

File details

Details for the file mem0_agent_memory-1.0.8.tar.gz.

File metadata

  • Download URL: mem0_agent_memory-1.0.8.tar.gz
  • Upload date:
  • Size: 111.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.5

File hashes

Hashes for mem0_agent_memory-1.0.8.tar.gz
Algorithm Hash digest
SHA256 19e27ba7d0913a8712a8a9f8dcd19f47802d92f528edf8c1372c286eda0e2714
MD5 062e4b4bde2ed5e6f7d989b386a1ca04
BLAKE2b-256 be2bd62ac169c695a24a6c53064f490fe9ebbba9fd96dae28d7165c5dec3fae8

See more details on using hashes here.

File details

Details for the file mem0_agent_memory-1.0.8-py3-none-any.whl.

File metadata

File hashes

Hashes for mem0_agent_memory-1.0.8-py3-none-any.whl
Algorithm Hash digest
SHA256 994ece9fe83e7d91bb1e6e3e70730279bb95a444cdd057a9f33b05fd0ee8b39b
MD5 01fee9fea6b33580927c1f28a1371c27
BLAKE2b-256 5ca658984361a5bbe8a1b7a6e6298ea808cc1c6d1f04dc01aa0302cd0a294132

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page