Memento MCP:面向法学硕士 (LLM) 的知识图谱记忆系统
可扩展、高性能的知识图谱记忆系统,具有语义检索、上下文回忆和时间感知功能。为任何支持模型上下文协议的 LLM 客户端(例如 Claude Desktop、Cursor、Github Copilot)提供弹性、自适应且持久的长期本体记忆。
核心概念
实体
实体是知识图谱中的主要节点。每个实体具有:
唯一名称(标识符)
实体类型(例如“人”、“组织”、“事件”)
观察结果列表
向量嵌入(用于语义搜索)
完整版本历史记录
例子:
关系
关系定义具有增强属性的实体之间的有向连接:
强度指标(0.0-1.0)
置信水平(0.0-1.0)
丰富的元数据(来源、时间戳、标签)
通过版本历史实现时间感知
基于时间的置信度衰减
例子:
Related MCP server: Memory MCP Server
存储后端
Memento MCP 使用 Neo4j 作为其存储后端,为图形存储和向量搜索功能提供了统一的解决方案。
为什么选择 Neo4j?
统一存储:将图形和矢量存储整合到单个数据库中
原生图形操作:专为图形遍历和查询而构建
集成向量搜索:Neo4j 内置的向量相似性搜索
可扩展性:大型知识图谱具有更好的性能
简化的架构:简洁的设计,所有操作均使用单一数据库
先决条件
Neo4j 5.13+(矢量搜索功能所需)
Neo4j 桌面设置(推荐)
开始使用 Neo4j 最简单的方法是使用Neo4j Desktop :
从https://neo4j.com/download/下载并安装 Neo4j Desktop
创建新项目
添加新数据库
将密码设置为
memento_password(或您喜欢的密码)启动数据库
Neo4j 数据库可在以下位置获取:
Bolt URI :
bolt://127.0.0.1:7687(用于驱动程序连接)HTTP :
http://127.0.0.1:74747474(用于 Neo4j 浏览器 UI)默认凭证:用户名:
neo4j,密码:memento_password(或您配置的任何密码)
使用 Docker 设置 Neo4j(替代方案)
或者,您可以使用 Docker Compose 来运行 Neo4j:
使用 Docker 时,Neo4j 数据库将在以下位置可用:
Bolt URI :
bolt://127.0.0.1:7687(用于驱动程序连接)HTTP :
http://127.0.0.1:74747474(用于 Neo4j 浏览器 UI)默认凭据:用户名:
neo4j,密码:memento_password
数据持久化与管理
由于docker-compose.yml文件中的 Docker 卷配置,Neo4j 数据在容器重启甚至版本升级后依然有效:
这些映射确保:
/data目录(包含所有数据库文件)在您的主机上保留在./neo4j-data/logs目录在您的主机上保留在./neo4j-logs/import目录(用于导入数据文件)保留在./neo4j-import
如果需要,您可以在docker-compose.yml文件中修改这些路径以将数据存储在不同的位置。
升级 Neo4j 版本
您可以更改 Neo4j 版本而不会丢失数据:
在
docker-compose.yml中更新 Neo4j 镜像版本使用
docker-compose down && docker-compose up -d neo4j重新启动容器使用
npm run neo4j:init重新初始化架构
只要卷映射保持不变,数据就会在此过程中保留下来。
完全数据库重置
如果您需要完全重置 Neo4j 数据库:
备份数据
要备份 Neo4j 数据,您只需复制数据目录:
Neo4j CLI 实用程序
Memento MCP 包含用于管理 Neo4j 操作的命令行实用程序:
测试连接
测试与 Neo4j 数据库的连接:
初始化架构
在正常运行情况下,当 Memento MCP 连接到数据库时,Neo4j 模式初始化会自动进行。您无需在常规使用中运行任何手动命令。
以下命令仅对于开发、测试或高级定制场景才是必需的:
高级功能
语义搜索
根据含义而非仅仅根据关键词来查找语义相关的实体:
向量嵌入:使用 OpenAI 的嵌入模型将实体自动编码到高维向量空间中
余弦相似度:即使使用不同的术语,也能找到相关概念
可配置阈值:设置最小相似度分数以控制结果相关性
跨模式搜索:使用文本查询来查找相关实体,无论它们是如何描述的
多模型支持:兼容多种嵌入模型(OpenAI text-embedding-3-small/large)
上下文检索:根据语义而不是精确的关键字匹配来检索信息
优化默认值:调整参数以平衡精度和召回率(相似度阈值 0.6,启用混合搜索)
混合搜索:结合语义和关键字搜索以获得更全面的结果
自适应搜索:系统根据查询特征和可用数据,智能地选择仅矢量、仅关键字或混合搜索
性能优化:优先进行向量搜索以实现语义理解,同时保持回退机制以实现弹性
查询感知处理:根据查询复杂性和可用的实体嵌入调整搜索策略
时间意识
通过时间点图形检索跟踪实体和关系的完整历史记录:
完整版本历史记录:对实体或关系的每次更改都通过时间戳保存
时间点查询:检索过去任何时刻知识图谱的精确状态
变更跟踪:自动记录 createdAt、updatedAt、validFrom 和 validTo 时间戳
时间一致性:保持对知识如何演变的历史准确看法
非破坏性更新:更新会创建新版本,而不是覆盖现有数据
基于时间的过滤:根据时间标准过滤图形元素
历史探索:调查特定信息如何随时间变化
信心衰退
根据可配置的半衰期,关系的可信度会随着时间的推移而自动衰减:
基于时间的衰减:如果不加强,关系中的信心自然会随着时间的推移而下降
可配置的半衰期:定义信息变得不确定的速度(默认值:30 天)
最低置信水平:设置阈值以防止重要信息过度衰减
衰减元数据:每个关系都包含详细的衰减计算信息
非破坏性:原始置信值与衰减值一起保留
强化学习:当新的观察得到强化时,关系会重新获得信心
参考时间灵活性:根据任意参考时间计算衰减以进行历史分析
高级元数据
对实体和具有自定义字段的关系提供丰富的元数据支持:
源跟踪:记录信息来源(用户输入、分析、外部来源)
置信度:根据确定性为关系分配置信度分数(0.0-1.0)
关系强度:表示关系的重要性或强度(0.0-1.0)
时间元数据:跟踪信息的添加、修改或验证时间
自定义标签:添加任意标签进行分类和过滤
结构化数据:在元数据字段中存储复杂的结构化数据
查询支持:基于元数据属性的搜索和过滤
可扩展架构:根据需要添加自定义字段,而无需修改核心数据模型
MCP API 工具
LLM 客户端主机可以通过模型上下文协议使用以下工具:
实体管理
创建实体
在知识图谱中创建多个新实体
输入:
entities(对象数组)每个对象包含:
name(字符串):实体标识符entityType(字符串):类型分类observations(string[]):相关观察
添加观察结果
向现有实体添加新观察
输入:
observations(对象数组)每个对象包含:
entityName(字符串):目标实体contents(string[]):要添加的新观察结果
删除实体
删除实体及其关系
输入:
entityNames(string[])
删除观察结果
从实体中删除特定观察结果
输入:
deletions(对象数组)每个对象包含:
entityName(字符串):目标实体observations(string[]):要删除的观察结果
关系管理
创建关系
在具有增强属性的实体之间创建多个新关系
输入:
relations(对象数组)每个对象包含:
from(字符串):源实体名称to(字符串):目标实体名称relationType(字符串):关系类型strength(数字,可选):关系强度(0.0-1.0)confidence(数字,可选):置信度(0.0-1.0)metadata(对象,可选):自定义元数据字段
获取关系
获取具有增强属性的特定关系
输入:
from(字符串):源实体名称to(字符串):目标实体名称relationType(字符串):关系类型
更新关系
使用增强属性更新现有关系
输入:
relation(对象):包含:
from(字符串):源实体名称to(字符串):目标实体名称relationType(字符串):关系类型strength(数字,可选):关系强度(0.0-1.0)confidence(数字,可选):置信度(0.0-1.0)metadata(对象,可选):自定义元数据字段
删除关系
从图中删除特定关系
输入:
relations(对象数组)每个对象包含:
from(字符串):源实体名称to(字符串):目标实体名称relationType(字符串):关系类型
图操作
读取图
阅读整个知识图谱
无需输入
搜索节点
根据查询搜索节点
输入:
query(字符串)
打开节点
按名称检索特定节点
输入:
names(string[])
语义搜索
语义搜索
使用向量嵌入和相似性在语义上搜索实体
输入:
query(字符串):要进行语义搜索的文本查询limit(数字,可选):返回的最大结果数(默认值:10)min_similarity(数字,可选):最小相似度阈值(0.0-1.0,默认值:0.6)entity_types(string[],可选):按实体类型过滤结果hybrid_search(布尔值,可选):结合关键字和语义搜索(默认值:true)semantic_weight(数字,可选):混合搜索中语义结果的权重(0.0-1.0,默认值:0.6)
特征:
根据查询上下文智能选择最佳搜索方法(向量、关键字或混合)
通过回退机制优雅地处理没有语义匹配的查询
通过自动优化决策保持高性能
获取实体嵌入
获取特定实体的向量嵌入
输入:
entity_name(字符串):要获取嵌入的实体的名称
时间特征
获取实体历史记录
获取实体的完整版本历史记录
输入:
entityName(字符串)
获取关系历史记录
获取关系的完整版本历史记录
输入:
from(字符串):源实体名称to(字符串):目标实体名称relationType(字符串):关系类型
获取时间图
获取特定时间戳的图表状态
输入:
timestamp(数字):Unix 时间戳(自纪元以来的毫秒数)
获取衰减图
获取具有随时间衰减的置信度值的图表
输入:
options(对象,可选):reference_time(数字):衰减计算的参考时间戳(自纪元以来的毫秒数)decay_factor(数字):可选衰减因子覆盖
配置
环境变量
使用以下环境变量配置 Memento MCP:
命令行选项
Neo4j CLI 工具支持以下选项:
嵌入模型
可用的 OpenAI 嵌入模型:
text-embedding-3-small:高效、经济(1536 维)text-embedding-3-large:准确率更高,成本更高(3072 维)text-embedding-ada-002:旧模型(1536 维)
OpenAI API 配置
要使用语义搜索,您需要配置 OpenAI API 凭据:
从OpenAI获取 API 密钥
使用以下配置来配置您的环境:
注意:在测试环境中,如果未提供 API 密钥,系统将模拟嵌入生成。但是,建议在集成测试中使用真实的嵌入。
与 Claude Desktop 集成
配置
将其添加到您的claude_desktop_config.json中:
或者,对于本地开发,您可以使用:
重要提示:始终在 Claude Desktop 配置中明确指定嵌入模型,以确保一致的行为。
推荐的系统提示
为了与 Claude 进行最佳集成,请将这些语句添加到系统提示符中:
测试语义搜索
配置完成后,Claude 可以通过自然语言访问语义搜索功能:
要创建具有语义嵌入的实体:
User: "Remember that Python is a high-level programming language known for its readability and JavaScript is primarily used for web development."按语义搜索:
User: "What programming languages do you know about that are good for web development?"要检索特定信息:
User: "Tell me everything you know about Python."
这种方法的优势在于用户可以自然地进行交互,而 LLM 则负责处理选择和使用适当记忆工具的复杂性。
实际应用
Memento 的自适应搜索功能提供了实际的好处:
查询多功能性:用户无需担心如何表述问题 - 系统会自动适应不同的查询类型
故障恢复:即使语义匹配不可用,系统也可以在无需用户干预的情况下恢复到替代方法
性能效率:通过智能选择最佳搜索方法,系统平衡每个查询的性能和相关性
改进的上下文检索:LLM 对话受益于更好的上下文检索,因为系统可以在复杂的知识图谱中找到相关信息
例如,当用户询问“你对机器学习了解多少?”时,即使用户没有明确提及“机器学习”,系统也能检索概念相关的实体——可能是关于神经网络、数据科学或特定算法的实体。但是,如果语义搜索的结果不足,系统会自动调整方法,以确保仍然返回有用的信息。
故障排除
矢量搜索诊断
Memento MCP 包含内置诊断功能,可帮助解决矢量搜索问题:
嵌入验证:系统检查实体是否具有有效的嵌入,如果缺失则自动生成
向量索引状态:验证向量索引是否存在且处于 ONLINE 状态
回退搜索:如果向量搜索失败,系统将返回基于文本的搜索
详细日志记录:全面记录矢量搜索操作,以便排除故障
调试工具(当 DEBUG=true 时)
启用调试模式后,可以使用其他诊断工具:
诊断_vector_search :有关 Neo4j 向量索引、嵌入计数和搜索功能的信息
force_generate_embedding :强制为特定实体生成嵌入
debug_embedding_config :有关当前嵌入服务配置的信息
开发者重置
要在开发过程中完全重置 Neo4j 数据库:
建筑与开发
安装
通过 Smithery 安装
通过Smithery自动为 Claude Desktop 安装 memento-mcp:
使用 npx 进行全局安装
您可以使用 npx 直接运行 Memento MCP,而无需全局安装:
建议将此方法与 Claude Desktop 和其他 MCP 兼容客户端一起使用。
本地安装
对于开发或为项目做出贡献:
执照
麻省理工学院