MCP 内存服务器 - HTTP 流式传输
基于官方 MCP Memory Server 重构的 HTTP 流式传输版本,使用 Hono.js 框架。
项目来源
本项目基于 MCP Servers 仓库 中的官方 @modelcontextprotocol/server-memory 重构而来。原始内存服务器使用 stdio 传输,而此版本经过重构以支持 HTTP 流式传输,适用于独立部署场景。
与原版本的主要差异
传输方式: HTTP 流式传输,而非 stdio
框架选择: 使用 Hono.js,而非 Express.js(其他 HTTP 服务器使用)
架构设计: 按单一职责原则重构为多文件架构
部署方式: 可作为独立 HTTP 服务部署
架构设计
原始的单文件实现已重构为模块化结构:
功能特性
完全保留原始内存服务器的所有功能:
知识图谱存储: 存储和管理实体、关系和观察
文件持久化: JSON 行格式存储(与原版兼容)
搜索能力: 按名称、类型或观察内容查询实体
CRUD 操作: 对所有图元素的完整增删改查支持
可用工具
create_entities - 在知识图谱中创建新实体
create_relations - 在实体间创建关系
add_observations - 向现有实体添加观察
delete_entities - 删除实体及相关关系
delete_observations - 从实体中移除特定观察
delete_relations - 删除特定关系
read_graph - 读取整个知识图谱
search_nodes - 按查询字符串搜索实体
open_nodes - 按名称检索特定实体
安装和使用
安装依赖
构建项目
启动 HTTP 服务器
服务器将默认在 http://localhost:3002/mcp 启动。
环境变量
PORT- 服务器端口(默认:3002)MEMORY_FILE_PATH- 内存存储文件路径(默认:./memory.json)
HTTP API 端点
服务器提供符合 MCP 协议的端点:
GET /- 服务器基本信息GET /health- 健康检查端点(用于服务监控)POST /mcp- 初始化会话并处理 MCP 请求GET /mcp- 服务器发送事件(SSE)流式传输实时更新DELETE /mcp- 会话终止
所有 MCP 请求必须包含 mcp-session-id 请求头进行会话管理。
健康检查示例
响应示例:
存储格式
存储格式与原始内存服务器完全相同:
每行包含一个带有
type字段的 JSON 对象("entity" 或 "relation")实体包含 name、entityType 和 observations 数组
关系包含 from、to 和 relationType 字段
基础用法和测试示例
1. 启动服务器
服务器将在 http://localhost:3002/mcp 启动。
2. 使用 cURL 测试
初始化会话
响应将包含 mcp-session-id 头,后续请求需要使用此 ID。
创建实体
创建关系
查询知识图谱
搜索实体
添加观察
3. 查看存储数据
查看 memory.json 文件内容:
示例输出:
4. 使用 MCP 客户端连接
如果使用支持 MCP 协议的客户端(如 Claude Desktop),可以在配置中添加:
5. TypeScript 测试脚本
我们还提供了一个 TypeScript 测试脚本 test-memory-server.ts,展示如何以编程方式与 MCP 服务器交互:
TypeScript 测试脚本包含以下测试用例:
会话初始化和管理
创建实体和关系
添加观察数据
搜索和查询功能
完整的知识图谱读取
存储文件验证
6. Bash 测试脚本
也可以使用 Bash 脚本进行测试:
运行测试:
测试数据示例
测试完成后,memory.json 文件将包含类似以下内容:
开发
监视模式
文件结构
types.ts - TypeScript 接口和类型定义
storage.ts - 知识图谱持久化的文件 I/O 操作
knowledge-graph.ts - 图操作的核心业务逻辑
tools.ts - MCP 工具模式定义
server.ts - MCP 服务器设置和请求处理
http-server.ts - 基于 Hono.js 的 HTTP 服务器实现
兼容性
此服务器与以下内容完全兼容:
原始 MCP Memory Server 数据格式
MCP 协议规范
stdio 版本的现有内存文件
许可证
MIT - 与原始 MCP Servers 项目相同
This server cannot be installed
Related Resources
Related MCP Servers
- -securityAlicense-qualityProvides knowledge graph functionality for managing entities, relations, and observations in memory with strict validation rules to maintain data consistency.Last updated -17MIT License
- AsecurityFlicenseAqualityProvides tools for managing quantitative research knowledge graphs, enabling structured representation of research projects, datasets, variables, hypotheses, statistical tests, models, and results.Last updated -68
- AsecurityFlicenseAqualityProvides tools for managing qualitative research knowledge graphs, enabling structured representation of research projects, participants, interviews, observations, codes, themes, and findings.Last updated -66
- -securityFlicense-qualityEnables storage and retrieval of knowledge in a graph database format, allowing users to create, update, search, and delete entities and relationships in a Neo4j-powered knowledge graph through natural language.Last updated -4