Knowledge Graph Memory Server

local-only server

The server can only run on the client’s local machine because it depends on local resources.

Integrations

  • Supports deployment as a Docker container for easy setup and integration with Claude Desktop

  • Uses SQLite as the backend database for storing the knowledge graph data, providing persistent storage of entities, relations, and observations

servidor mcp de memoria optimizada

Esto es para probar y demostrar las habilidades de programación de Claude AI, así como sus buenos flujos de trabajo de IA y diseño de indicaciones. Es una bifurcación de un servidor MCP de memoria de Python (creo que el oficial está en Java) que utiliza SQLite como backend.

Servidor de memoria de gráficos de conocimiento

Una implementación básica de memoria persistente mediante un grafo de conocimiento local. Esto permite a Claude recordar información sobre el usuario en todos los chats.

Conceptos básicos

Entidades

Las entidades son los nodos principales del grafo de conocimiento. Cada entidad tiene:

  • Un nombre único (identificador)
  • Un tipo de entidad (por ejemplo, "persona", "organización", "evento")
  • Una lista de observaciones

Ejemplo:

{ "name": "John_Smith", "entityType": "person", "observations": ["Speaks fluent Spanish"] }

Relaciones

Las relaciones definen conexiones dirigidas entre entidades. Siempre se almacenan en voz activa y describen cómo las entidades interactúan o se relacionan entre sí.

Ejemplo:

{ "from": "John_Smith", "to": "Anthropic", "relationType": "works_at" }

Observaciones

Las observaciones son fragmentos discretos de información sobre una entidad. Son:

  • Almacenados como cadenas
  • Adjunto a entidades específicas
  • Se puede agregar o quitar de forma independiente.
  • Debe ser atómico (un hecho por observación)

Ejemplo:

{ "entityName": "John_Smith", "observations": [ "Speaks fluent Spanish", "Graduated in 2019", "Prefers morning meetings" ] }

API

Herramientas

  • crear_entidades
    • Crear múltiples entidades nuevas en el gráfico de conocimiento
    • Entrada: entities (matriz de objetos)
      • Cada objeto contiene:
        • name (cadena): identificador de entidad
        • entityType (cadena): clasificación de tipos
        • observations (string[]): Observaciones asociadas
    • Ignora entidades con nombres existentes
  • crear_relaciones
    • Crear múltiples relaciones nuevas entre entidades
    • Entrada: relations (matriz de objetos)
      • Cada objeto contiene:
        • from (string): Nombre de la entidad de origen
        • to (cadena): nombre de la entidad de destino
        • relationType (cadena): Tipo de relación en voz activa
    • Omite relaciones duplicadas
  • añadir_observaciones
    • Agregar nuevas observaciones a entidades existentes
    • Entrada: observations (matriz de objetos)
      • Cada objeto contiene:
        • entityName (cadena): entidad de destino
        • contents (string[]): Nuevas observaciones para agregar
    • Devuelve observaciones agregadas por entidad
    • Falla si la entidad no existe
  • eliminar_entidades
    • Eliminar entidades y sus relaciones
    • Entrada: entityNames (cadena[])
    • Eliminación en cascada de relaciones asociadas
    • Operación silenciosa si la entidad no existe
  • eliminar_observaciones
    • Eliminar observaciones específicas de las entidades
    • Entrada: deletions (matriz de objetos)
      • Cada objeto contiene:
        • entityName (cadena): entidad de destino
        • observations (string[]): Observaciones para eliminar
    • Funcionamiento silencioso si no existe observación
  • eliminar_relaciones
    • Eliminar relaciones específicas del gráfico
    • Entrada: relations (matriz de objetos)
      • Cada objeto contiene:
        • from (string): Nombre de la entidad de origen
        • to (cadena): nombre de la entidad de destino
        • relationType (cadena): tipo de relación
    • Operación silenciosa si no existe relación
  • leer_gráfico
    • Lea el gráfico de conocimiento completo
    • No se requiere entrada
    • Devuelve la estructura gráfica completa con todas las entidades y relaciones
  • nodos de búsqueda
    • Búsqueda de nodos según la consulta
    • Entrada: query (cadena)
    • Búsquedas en:
      • Nombres de entidades
      • Tipos de entidad
      • Contenido de la observación
    • Devuelve entidades coincidentes y sus relaciones.
  • nodos abiertos
    • Recuperar nodos específicos por nombre
    • Entrada: names (cadena[])
    • Devoluciones:
      • Entidades solicitadas
      • Relaciones entre las entidades solicitadas
    • Omite silenciosamente nodos inexistentes

Uso con Claude Desktop

Configuración

Agregue esto a su claude_desktop_config.json:

Estibador

{ "mcpServers": { "memory": { "command": "docker", "args": ["run", "-i", "--rm", "mcp/memory"] } } }

NPX

{ "mcpServers": { "memory": { "command": "npx", "args": [ "-y", "@modelcontextprotocol/server-memory" ] } } }

Indicador del sistema

El indicador para utilizar la memoria depende del caso de uso. Cambiarlo ayudará al modelo a determinar la frecuencia y los tipos de memorias creadas.

Aquí tienes un ejemplo de mensaje para personalizar el chat. Puedes usarlo en el campo "Instrucciones personalizadas" de un proyecto de Claude.ai .

Follow these steps for each interaction: 1. User Identification: - You should assume that you are interacting with default_user - If you have not identified default_user, proactively try to do so. 2. Memory Retrieval: - Always begin your chat by saying only "Remembering..." and retrieve all relevant information from your knowledge graph - Always refer to your knowledge graph as your "memory" 3. Memory - While conversing with the user, be attentive to any new information that falls into these categories: a) Basic Identity (age, gender, location, job title, education level, etc.) b) Behaviors (interests, habits, etc.) c) Preferences (communication style, preferred language, etc.) d) Goals (goals, targets, aspirations, etc.) e) Relationships (personal and professional relationships up to 3 degrees of separation) 4. Memory Update: - If any new information was gathered during the interaction, update your memory as follows: a) Create entities for recurring organizations, people, and significant events b) Connect them to the current entities using relations b) Store facts about them as observations

Edificio

Estibador:

docker build -t mcp/memory -f src/memory/Dockerfile .

Licencia

Este servidor MCP cuenta con la licencia MIT. Esto significa que puede usar, modificar y distribuir el software libremente, sujeto a los términos y condiciones de la licencia MIT. Para más detalles, consulte el archivo de LICENCIA en el repositorio del proyecto.

-
security - not tested
A
license - permissive license
-
quality - not tested

Una implementación de memoria persistente que utiliza un gráfico de conocimiento local que permite a Claude recordar información sobre los usuarios en todas las conversaciones.

  1. Knowledge Graph Memory Server
    1. Core Concepts
    2. API
  2. Usage with Claude Desktop
    1. Setup
    2. System Prompt
    3. Building
    4. License
ID: 8pt2sa08m8