MCP Memory Server

MCP Memory Server

Provides persistent memory functionality for AI conversations by creating, managing and querying entities and relationships in a knowledge graph. Features SQLite storage, advanced search capabilities, and Windows auto-start integration for long-term AI memory retention.

Category
访问服务器

README

MCP Memory Server

Um servidor de protocolo de contexto de modelo (MCP) que fornece funcionalidades de memória persistente para conversas com IA. Este servidor permite que aplicações de IA criem, gerenciem e consultem entidades e relacionamentos em um grafo de conhecimento persistente.

🚀 Início Rápido

1. Clone e Configure

git clone https://github.com/jessefreitas/mcp_memory.git
cd mcp_memory
npm install
npm run build

2. Inicie o Servidor

# Configurar auto-start (Windows)
.\auto-start.ps1

# OU iniciar manualmente
.\server-controller.ps1

3. Teste a Funcionalidade

# Executar teste completo
.\run-test.ps1

# Verificar status
.\quick-status.ps1

4. Configure Claude Desktop

Adicione ao claude_desktop_config.json:

{
  "mcpServers": {
    "mcp_memory": {
      "command": "node",
      "args": ["./build/simple-index.js"],
      "cwd": "c:\\vscode\\mcp_memory"
    }
  }
}

5. Teste no Claude Desktop

Use o comando: mcp_memory_read_graph

Funcionalidades

  • 📊 Gerenciamento de Entidades: Crie, atualize e exclua entidades com observações
  • 🔗 Relacionamentos: Estabeleça e gerencie relacionamentos entre entidades
  • 🔍 Busca Avançada: Procure entidades e relacionamentos por conteúdo
  • 💾 Persistência: Armazenamento JSON simples e confiável
  • 🎯 Compatível com MCP: Funciona com qualquer cliente MCP (Claude Desktop, etc.)
  • 🚀 Auto-start: Configuração automática no Windows
  • 🔧 VS Code Integration: Integração completa com VS Code
  • 🧪 Suite de Testes: Scripts PowerShell para teste e validação
  • 📊 Dashboard: Interface web para monitoramento

Instalação

Via npm (Recomendado)

npm install -g mcp-memory-server

Desenvolvimento Local

git clone <repository-url>
cd mcp_memory
npm install
npm install typescript --save-dev
npm run build

Configuração

Claude Desktop

Adicione ao seu arquivo de configuração do Claude Desktop (claude_desktop_config.json):

{
  "mcpServers": {
    "memory": {
      "command": "npx",
      "args": ["-y", "mcp-memory-server"],
      "env": {
        "MCP_MEMORY_DB_PATH": "./memory.db"
      }
    }
  }
}

Configuração Local

Para desenvolvimento local:

{
  "mcpServers": {
    "mcp_memory": {
      "command": "node",
      "args": ["./build/simple-index.js"],
      "cwd": "c:\\vscode\\mcp_memory"
    }
  }
}

Configuração Automática (Windows)

Execute o script de configuração automática:

# Configurar auto-start
.\auto-start.ps1

# Verificar status
.\quick-status.ps1

# Executar testes
.\run-test.ps1

Uso

Ferramentas Disponíveis

O servidor MCP Memory fornece as seguintes ferramentas:

1. Criar Entidades

mcp_memory_create_entities({
  entities: [
    {
      name: "João Silva",
      entityType: "pessoa",
      observations: [
        "Trabalha como engenheiro de software",
        "Mora em São Paulo",
      ],
    },
  ],
});

2. Adicionar Observações

mcp_memory_add_observations({
  observations: [
    {
      entityName: "João Silva",
      contents: [
        "Gosta de programação em TypeScript",
        "Tem 5 anos de experiência",
      ],
    },
  ],
});

3. Criar Relacionamentos

mcp_memory_create_relations({
  relations: [
    {
      from: "João Silva",
      to: "TechCorp",
      relationType: "trabalha_para",
    },
  ],
});

4. Buscar Nós

mcp_memory_search_nodes({
  query: "engenheiro",
});

5. Abrir Nós Específicos

mcp_memory_open_nodes({
  names: ["João Silva", "TechCorp"],
});

6. Ler Grafo Completo

mcp_memory_read_graph();

Recursos Disponíveis

O servidor também expõe recursos que podem ser acessados:

  • memory://graph - Grafo de conhecimento completo
  • memory://entities - Todas as entidades
  • memory://relations - Todos os relacionamentos
  • memory://stats - Estatísticas do grafo

Estrutura do Projeto

mcp_memory/
├── src/
│   ├── index.ts              # Servidor MCP original (SQLite)
│   ├── simple-index.ts       # Servidor MCP simplificado (JSON) ⭐
│   ├── memory/
│   │   └── MemoryManager.ts  # Gerenciador de memória SQLite
│   ├── tools/
│   │   └── index.ts          # Definições de ferramentas MCP
│   └── resources/
│       └── index.ts          # Definições de recursos MCP
├── scripts PowerShell/       # Scripts de gerenciamento
│   ├── run-test.ps1         # Teste de funcionalidades
│   ├── test-mcp-direct.ps1  # Teste direto do servidor
│   ├── quick-status.ps1     # Verificação de status
│   ├── server-controller.ps1 # Controle do servidor
│   └── auto-start.ps1       # Configuração de auto-start
├── .vscode/                 # Configuração VS Code
│   ├── tasks.json           # Tarefas do projeto
│   ├── settings.json        # Configurações
│   └── keybindings.json     # Atalhos
├── memory.json              # Dados persistentes
├── package.json
├── tsconfig.json
└── README.md

Desenvolvimento

Executar em Modo de Desenvolvimento

npm run dev

Construir o Projeto

npm run build

Executar Testes

npm test

Linting e Formatação

npm run lint
npm run format

Scripts de Gerenciamento

Windows PowerShell

  • .\run-test.ps1 - Executa teste completo de funcionalidades
  • .\test-mcp-direct.ps1 - Testa comunicação direta com o servidor
  • .\quick-status.ps1 - Verifica status do servidor e dados
  • .\server-controller.ps1 - Inicia/para o servidor
  • .\auto-start.ps1 - Configura inicialização automática
  • .\test-persistence.ps1 - Monitora persistência em tempo real

VS Code

  • Ctrl+Shift+P → "MCP: Start Server" - Iniciar servidor
  • Ctrl+Shift+P → "MCP: Test Memory" - Executar testes
  • Ctrl+Shift+P → "MCP: Check Status" - Verificar status
  • F5 - Executar em modo debug

Exemplos de Uso

Exemplo 1: Gerenciar Informações de Contato

// Criar uma pessoa
await mcp_memory_create_entities({
  entities: [
    {
      name: "Ana Costa",
      entityType: "pessoa",
      observations: ["Email: ana@example.com", "Telefone: (11) 99999-9999"],
    },
  ],
});

// Criar uma empresa
await mcp_memory_create_entities({
  entities: [
    {
      name: "Startup XYZ",
      entityType: "empresa",
      observations: ["Startup de tecnologia", "Fundada em 2023"],
    },
  ],
});

// Criar relacionamento
await mcp_memory_create_relations({
  relations: [
    {
      from: "Ana Costa",
      to: "Startup XYZ",
      relationType: "fundadora",
    },
  ],
});

Exemplo 2: Buscar Informações

// Buscar por termo específico
const resultado = await mcp_memory_search_nodes({
  query: "startup",
});

// Obter detalhes completos
const entidades = await mcp_memory_open_nodes({
  names: ["Ana Costa", "Startup XYZ"],
});

Arquitetura

O MCP Memory Server oferece duas implementações:

Servidor Principal (simple-index.ts) ⭐

  • JSON: Armazenamento simples e confiável em memory.json
  • TypeScript SDK: Implementação do protocolo MCP
  • Sincronização: Operações síncronas de leitura/escrita
  • Simplicidade: Código minimalista e fácil debugging

Servidor Avançado (index.ts)

  • SQLite: Para armazenamento mais robusto
  • Better SQLite3: Operações de banco performáticas
  • UUID: Identificadores únicos
  • Zod: Validação de esquemas

Tecnologias Utilizadas

  • Node.js: Runtime JavaScript
  • TypeScript: Linguagem de programação
  • MCP SDK: Protocolo de contexto de modelo
  • PowerShell: Scripts de automação Windows
  • VS Code: Integração completa de desenvolvimento

Contribuição

  1. Faça um fork do projeto
  2. Crie uma branch para sua feature (git checkout -b feature/nova-funcionalidade)
  3. Commit suas mudanças (git commit -am 'Adicionar nova funcionalidade')
  4. Push para a branch (git push origin feature/nova-funcionalidade)
  5. Abra um Pull Request

Licença

Este projeto está licenciado sob a Licença MIT - veja o arquivo LICENSE para detalhes.

Suporte

Para questões e suporte:

  1. Abra uma issue no GitHub
  2. Consulte a documentação do MCP em modelcontextprotocol.io
  3. Participe das discussões da comunidade MCP

Status Atual ✅

Implementado

  • ✅ Servidor MCP funcional com persistência JSON
  • ✅ Suite completa de testes PowerShell
  • ✅ Auto-start no Windows
  • ✅ Integração total com VS Code
  • ✅ Scripts de gerenciamento e monitoramento
  • ✅ Dashboard de status HTML
  • ✅ Migração do servidor oficial MCP
  • ✅ Verificação de persistência em tempo real

Testado e Validado

  • ✅ Criação e leitura de entidades
  • ✅ Relacionamentos entre entidades
  • ✅ Persistência em memory.json
  • ✅ Carregamento automático na inicialização
  • ✅ Integração com Claude Desktop

Roadmap Futuro

  • [ ] Interface web para visualização do grafo
  • [ ] Suporte para importação/exportação de dados
  • [ ] Integração com outros formatos de dados
  • [ ] Métricas e analytics avançadas
  • [ ] Backup automático e recuperação
  • [ ] Suporte para múltiplos bancos de dados
  • [ ] API REST para acesso externo
  • [ ] Clustering e replicação

推荐服务器

Baidu Map

Baidu Map

百度地图核心API现已全面兼容MCP协议,是国内首家兼容MCP协议的地图服务商。

官方
精选
JavaScript
Playwright MCP Server

Playwright MCP Server

一个模型上下文协议服务器,它使大型语言模型能够通过结构化的可访问性快照与网页进行交互,而无需视觉模型或屏幕截图。

官方
精选
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

一个由人工智能驱动的工具,可以从自然语言描述生成现代化的用户界面组件,并与流行的集成开发环境(IDE)集成,从而简化用户界面开发流程。

官方
精选
本地
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

通过模型上下文协议启用与 Audiense Insights 账户的交互,从而促进营销洞察和受众数据的提取和分析,包括人口统计信息、行为和影响者互动。

官方
精选
本地
TypeScript
VeyraX

VeyraX

一个单一的 MCP 工具,连接你所有喜爱的工具:Gmail、日历以及其他 40 多个工具。

官方
精选
本地
graphlit-mcp-server

graphlit-mcp-server

模型上下文协议 (MCP) 服务器实现了 MCP 客户端与 Graphlit 服务之间的集成。 除了网络爬取之外,还可以将任何内容(从 Slack 到 Gmail 再到播客订阅源)导入到 Graphlit 项目中,然后从 MCP 客户端检索相关内容。

官方
精选
TypeScript
Kagi MCP Server

Kagi MCP Server

一个 MCP 服务器,集成了 Kagi 搜索功能和 Claude AI,使 Claude 能够在回答需要最新信息的问题时执行实时网络搜索。

官方
精选
Python
e2b-mcp-server

e2b-mcp-server

使用 MCP 通过 e2b 运行代码。

官方
精选
Neon MCP Server

Neon MCP Server

用于与 Neon 管理 API 和数据库交互的 MCP 服务器

官方
精选
Exa MCP Server

Exa MCP Server

模型上下文协议(MCP)服务器允许像 Claude 这样的 AI 助手使用 Exa AI 搜索 API 进行网络搜索。这种设置允许 AI 模型以安全和受控的方式获取实时的网络信息。

官方
精选