Simple Memory MCP Server
A lightweight MCP server that provides persistent knowledge graph storage for AI assistants, enabling memory across sessions through entity-relationship storage with JSON file persistence.
README
Simple Memory MCP Server
A lightweight Model Context Protocol (MCP) server that provides persistent knowledge graph storage for AI assistants. Enables AI agents to maintain memory across sessions through entity-relationship storage with JSON file persistence.
๐ Features
- Persistent Memory: Knowledge graph storage with automatic persistence to JSON files
- Entity Management: Create, read, update, and delete entities with typed observations
- Relationship Tracking: Manage relationships between entities with type annotations
- Search Capabilities: Full-text search across entity names, types, and observations
- MCP Compliant: Full Model Context Protocol v2025-06-18 compatibility
- Simple Architecture: Lightweight, single-file implementation with minimal dependencies
๐ Table of Contents
๐ Installation
Interactive Installation (Recommended)
# Bash installer with interactive configuration
curl -fsSL https://raw.githubusercontent.com/your-username/simple-memory-mcp/main/install.sh | bash
What it does:
- ๐ Auto-detects your Obsidian vaults
- ๐ Configures custom memory storage location
- โ๏ธ Sets up Claude Desktop/Cursor automatically
- ๐๏ธ Optional Obsidian auto-export configuration
Interactive Setup Flow:
๐ Memory Storage Configuration
Where should memory be stored? [~/.cursor/memory.json]:
๐๏ธ Obsidian Integration
Do you use Obsidian? (y/n) [n]: y
๐ Found Obsidian vaults:
1. My Knowledge Base (/Users/you/Documents/MyVault)
2. Work Notes (/Users/you/Desktop/WorkVault)
Choose vault (1-2) or enter custom path [1]: 1
Enable auto-export after entity creation? (y/n) [n]: y
Export format (markdown/dataview/canvas/all) [markdown]: all
Manual Installation
Prerequisites
- Node.js v18.x or higher
- npm or pnpm package manager
Install Dependencies
npm install
Environment Setup
The server automatically saves memory to:
~/.cursor/memory.json(default)- Custom path via
MEMORY_PATHenvironment variable
# Optional: Set custom memory file location
export MEMORY_PATH="/path/to/your/memory/directory"
๐ Quick Start
1. Start the Server
npm start
# or
node index.js
2. Test with MCP Inspector
# Install and run MCP Inspector
npx @modelcontextprotocol/inspector
# Configure server in Inspector:
# Command: node
# Args: /path/to/your/simple-memory-mcp/index.js
3. Basic Usage Example
// Create entities
await client.callTool({
name: "create_entities",
arguments: {
entities: [{
name: "john-doe",
entityType: "person",
observations: ["Software engineer", "Works remotely", "Enjoys hiking"]
}]
}
});
// Create relationships
await client.callTool({
name: "create_relations",
arguments: {
relations: [{
from: "john-doe",
to: "acme-corp",
relationType: "works_for"
}]
}
});
// Search entities
await client.callTool({
name: "search_nodes",
arguments: {
query: "engineer"
}
});
๐ API Reference
Tools Overview
| Tool | Description | Input | Output |
|---|---|---|---|
create_entities |
Create multiple entities | {entities: Entity[]} |
Created entities |
create_relations |
Create relationships | {relations: Relation[]} |
Created relations |
add_observations |
Add observations to entities | {observations: Observation[]} |
Updated observations |
delete_entities |
Delete entities and relations | {entityNames: string[]} |
Deleted entities |
delete_observations |
Remove specific observations | {deletions: Deletion[]} |
Deleted observations |
delete_relations |
Remove relationships | {relations: Relation[]} |
Deleted relations |
read_graph |
Get complete knowledge graph | {} |
Full graph data |
search_nodes |
Search entities by query | {query: string} |
Matching entities |
open_nodes |
Get specific entities | {names: string[]} |
Requested entities |
export_to_obsidian |
Export graph to Obsidian vault | {vaultPath: string, format?: string} |
Export result |
Data Types
Entity
interface Entity {
name: string; // Unique identifier
entityType: string; // Type classification
observations: string[]; // Array of observation texts
}
Relation
interface Relation {
from: string; // Source entity name
to: string; // Target entity name
relationType: string; // Relationship type
}
Observation
interface Observation {
entityName: string; // Target entity name
contents: string[]; // New observations to add
}
Deletion
interface Deletion {
entityName: string; // Target entity name
observations: string[]; // Observations to remove
}
Detailed Tool Documentation
create_entities
Creates multiple new entities in the knowledge graph.
Input Schema:
{
"entities": [
{
"name": "entity-name",
"entityType": "person|organization|concept|etc",
"observations": ["observation1", "observation2"]
}
]
}
Example:
{
"entities": [
{
"name": "alice-johnson",
"entityType": "person",
"observations": ["Data scientist", "PhD in Computer Science", "Lives in San Francisco"]
},
{
"name": "tech-startup-xyz",
"entityType": "organization",
"observations": ["AI/ML company", "Founded in 2023", "Series A funding"]
}
]
}
Response:
[
{
"name": "alice-johnson",
"entityType": "person",
"observations": ["Data scientist", "PhD in Computer Science", "Lives in San Francisco"]
}
]
create_relations
Creates relationships between existing entities.
Input Schema:
{
"relations": [
{
"from": "source-entity",
"to": "target-entity",
"relationType": "relationship-type"
}
]
}
Example:
{
"relations": [
{
"from": "alice-johnson",
"to": "tech-startup-xyz",
"relationType": "works_for"
}
]
}
search_nodes
Search entities using full-text search across names, types, and observations.
Input Schema:
{
"query": "search-term"
}
Example:
{
"query": "data scientist"
}
Response: Array of matching entities with complete data.
read_graph
Returns the complete knowledge graph with all entities and relations.
Input Schema:
{}
Response:
{
"entities": [
{
"name": "alice-johnson",
"entityType": "person",
"observations": ["Data scientist", "PhD in Computer Science"]
}
],
"relations": [
{
"from": "alice-johnson",
"to": "tech-startup-xyz",
"relationType": "works_for"
}
]
}
export_to_obsidian
Export the knowledge graph to an Obsidian vault in various formats.
Input Schema:
{
"vaultPath": "/path/to/obsidian/vault",
"format": "markdown",
"autoIndex": true
}
Parameters:
vaultPath(required): Path to the Obsidian vault directoryformat(optional): Export format - "markdown", "dataview", "canvas", or "all" (default: "markdown")autoIndex(optional): Whether to create index files (default: true)
Example:
{
"vaultPath": "/Users/username/Documents/MyVault",
"format": "all",
"autoIndex": true
}
Response:
{
"success": true,
"vaultPath": "/Users/username/Documents/MyVault",
"format": "all",
"entityCount": 42,
"relationCount": 18,
"timestamp": "2024-01-15T10:30:00.000Z"
}
โ๏ธ Configuration
Environment Variables
| Variable | Default | Description |
|---|---|---|
MEMORY_PATH |
~/.cursor/memory.json |
Custom memory file location |
NODE_ENV |
development |
Runtime environment |
OBSIDIAN_AUTO_EXPORT |
false |
Enable automatic Obsidian export after entity creation |
OBSIDIAN_VAULT_PATH |
- | Path to Obsidian vault for auto-export |
OBSIDIAN_EXPORT_FORMAT |
markdown |
Export format for auto-export |
Memory File Structure
The server persists data in JSON format:
{
"entities": [
{
"name": "entity-name",
"entityType": "type",
"observations": ["obs1", "obs2"]
}
],
"relations": [
{
"from": "entity1",
"to": "entity2",
"relationType": "relationship"
}
]
}
MCP Client Configuration
For Claude Desktop, add to your MCP settings:
{
"mcpServers": {
"simple-memory": {
"command": "node",
"args": ["/path/to/simple-memory-mcp/index.js"],
"env": {
"MEMORY_PATH": "/custom/path/to/memory/directory"
}
}
}
}
๐งช Testing
Running Tests
# Run comprehensive server test
node test-server.js
Expected Test Output
๐งช Testing Simple Memory MCP Server...
โ
Connected successfully!
โ
Found 9 tools: create_entities, create_relations, ...
โ
All tests passed! Server is working correctly.
Manual Testing with Inspector
- Start MCP Inspector:
npx @modelcontextprotocol/inspector - Configure server connection
- Test each tool with sample data
- Verify persistence by restarting server
Integration Testing
Test with actual MCP clients:
import { Client } from "@modelcontextprotocol/sdk/client/index.js";
import { StdioClientTransport } from "@modelcontextprotocol/sdk/client/stdio.js";
const transport = new StdioClientTransport({
command: "node",
args: ["index.js"]
});
const client = new Client({
name: "test-client",
version: "1.0.0"
}, {
capabilities: {}
});
await client.connect(transport);
๐ง Troubleshooting
Common Issues
Server Won't Start
Error: Cannot read properties of undefined (reading 'method')
Solution: Ensure you're using the correct MCP SDK version and schema imports:
import {
ListToolsRequestSchema,
CallToolRequestSchema,
ListPromptsRequestSchema,
ListResourcesRequestSchema
} from '@modelcontextprotocol/sdk/types.js';
Missing Capabilities Error
Error: Server does not support prompts (required for prompts/list)
Solution: Declare all capabilities in server configuration:
const server = new Server(
{ name: 'simple-memory-mcp', version: '1.1.0' },
{
capabilities: {
tools: {},
prompts: {},
resources: {}
}
}
);
Memory File Permissions
Error: EACCES: permission denied
Solution: Ensure write permissions to memory directory:
mkdir -p ~/.cursor
chmod 755 ~/.cursor
Tool Not Found
Error: Unknown tool: create_entities
Solution: Verify tool registration matches the schema names exactly.
Debug Mode
Enable detailed logging:
console.error("Debug info:", JSON.stringify(data, null, 2));
Performance Issues
For large knowledge graphs (>10,000 entities):
- Consider implementing pagination for
read_graph - Add indexing for search operations
- Implement lazy loading for entity details
๐ Development
Project Structure
simple-memory-mcp/
โโโ index.js # Main server implementation
โโโ package.json # Dependencies and scripts
โโโ test-server.js # Comprehensive test suite
โโโ inspector-config.json # MCP Inspector configuration
โโโ CLAUDE.md # AI development protocols
โโโ README.md # This documentation
Architecture
graph TD
A[MCP Client] --> B[StdioServerTransport]
B --> C[Simple Memory Server]
C --> D[Entity Manager]
C --> E[Relation Manager]
C --> F[Search Engine]
D --> G[JSON File Storage]
E --> G
F --> G
Core Classes
SimpleMemoryServer
Main server class handling:
- Memory persistence (
loadMemory(),saveMemory()) - Entity operations (CRUD)
- Relationship management
- Search functionality
Key Methods:
createEntities(entities)- Batch entity creationcreateRelations(relations)- Relationship creationsearchNodes(query)- Full-text searchreadGraph()- Complete graph export
Extending the Server
Adding New Tools
- Define tool schema in
tools/listhandler - Implement logic in
tools/callhandler - Add method to
SimpleMemoryServerclass - Update documentation
Custom Storage Backends
Replace JSON file storage:
class DatabaseMemoryServer extends SimpleMemoryServer {
async saveMemory() {
// Custom database implementation
}
async loadMemory() {
// Custom database loading
}
}
Contributing
- Fork the repository
- Create feature branch:
git checkout -b feature-name - Run tests:
node test-server.js - Commit changes:
git commit -m "Description" - Push branch:
git push origin feature-name - Create Pull Request
๐ License
MIT License - see LICENSE file for details.
๐ Additional Documentation
- Complete Documentation Index - All technical documentation
- API Reference - Detailed API documentation with TypeScript interfaces
- Debugging Guide - Comprehensive troubleshooting guide
- Obsidian Integration - Visualization and mindmap setup
- Implementation Guide - Built-in export implementation
- Project Roadmap - Strategic planning and future development
๐ค Support
- Issues: GitHub Issues
- Documentation: MCP Protocol Docs
- Community: MCP Discord
Built with โค๏ธ using the Model Context Protocol
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.