langChain记忆

1、记忆类型

短期记忆---当前任务或会话的上下文

长期记忆---跨任务会话的经验与知识

2、添加记忆

2、1添加短期记---添加在内存

添加会话记忆(短期记忆)分为三步:

  • 导入并初始化Checkpointer

  • 创建Agent,指定Checkpointer

  • 调用Agent,指定thread_id

    from langchain.agents import create_agent
    from langgraph.checkpoint.memory import InMemorySaver

    agent = create_agent(
    "deepseek-chat",
    checkpointer=InMemorySaver()
    )
    from langchain.messages import HumanMessage

    设定thread_id,作为会话标识

    config = {"configurable": {"thread_id": "thread_1"}}

    第一次调用,告知AI我的信息

    response = agent.invoke(
    {"messages": [HumanMessage(content="你好,我叫虎哥,我最喜欢猫猫。")]},
    config # 调用时添加thread_id-------------------所有thread-id的都会快照成一组
    )

    print(response)

    ====================================

    ====================================

    第二次调用,询问我的信息,这次带上thread_id,唤起记忆

    response = agent.invoke(
    {"messages": [HumanMessage(content="我最喜欢的动物是什么?")]},
    config # 调用时添加thread_id
    )

    print(response)

2、2添加长期记---添加在数据库

复制代码
# 3.Memory持久化存储

这里我们选择使用Sqlite作为存储方案,首先需要按照langgraph-checkpoint-sqlite依赖:
```
uv add langgraph-checkpoint-sqlite
```
接着,按照以下步骤使用:
- 导入依赖
- 初始化checkpointer
- 自动建表
- 创建Agent,指定checkpointer-

=========基于sqlite=================================================

connection = sqlite3.connect("resources/checkpoint.db", check_same_thread=False)

将数据库文件存入resources目录下名为checkpoint.db

复制代码
import sqlite3
from langgraph.checkpoint.sqlite import SqliteSaver

# 连接sqlite
connection = sqlite3.connect("resources/checkpoint.db", check_same_thread=False)
# 初始化checkpointer
checkpointer = SqliteSaver(connection)
# 自动建表
checkpointer.setup()

# 创建agent
agent = create_agent(
    "deepseek-chat",
    checkpointer=checkpointer,
)

from langchain.messages import HumanMessage

# 设定thread_id,作为会话标识
config = {"configurable": {"thread_id": "thread_2"}}

# 第一次调用,告知AI我的信息
response = agent.invoke(
    {"messages": [HumanMessage(content="你好,我叫虎哥,我最喜欢猫猫。")]},
    config # 调用时添加thread_id
)

print(response)

# 第二次调用,询问我的信息,这次带上thread_id,唤起记忆
response = agent.invoke(
    {"messages": [HumanMessage(content="我最喜欢的动物是什么?")]},
    config # 调用时添加thread_id
)

print(response)

3、记忆管理策略

模型上下文溢出解决

当会话历史过长时,可能会超出模型的上下文窗口限制,常见的解决方案有:
**- 修剪消息----删除部分会话比如早期会话----不推荐

  • 删除消息----直接删除超出的快照----不推荐**
    - 总结消息摘要---用另一个模型进行总结---当上下文超出时总结

这里我们演示总结消息摘要的方案


常见写法

在这类 SummarizationMiddleware 里,trigger 通常是一个 tuple(二元组)

从语法上说

就你这里看,trigger 不是固定"几种语法",而是按照中间件实现支持哪些字段来决定。

最常见的可能有这几类:

  1. 按消息数触发

    复制代码
    trigger=("messages", 6)
  2. 按 token 数触发

    复制代码
    trigger=("tokens", 3000)
  3. 按字符/文本长度触发

    复制代码
    trigger=("chars", 5000)

    from langchain.agents import create_agent
    from langchain.agents.middleware import SummarizationMiddleware
    from langgraph.checkpoint.memory import InMemorySaver
    from langchain_core.runnables import RunnableConfig

    初始化checkpointer

    checkpointer = InMemorySaver()

    初始化中间件

    middleware = SummarizationMiddleware(
    model="deepseek-chat",
    trigger=("messages", 6), # 触发时机,当消息数超过3时,进行总结
    keep=("messages", 1) # 保留的会话数,超过2条
    )

    创建agent

    agent = create_agent(
    model="deepseek-chat",
    middleware=[middleware],
    checkpointer=checkpointer,
    )

    config: RunnableConfig = {"configurable": {"thread_id": "thread_3"}}

    制造长会话历史

    agent.invoke({"messages": [HumanMessage(content="你好,我是虎哥.")]}, config)
    agent.invoke({"messages": [HumanMessage(content="我最喜欢的运动是乒乓")]}, config)
    agent.invoke({"messages": [HumanMessage(content="我最喜欢的动物是猫猫")]}, config)

    测试效果

    final_response = agent.invoke({"messages": HumanMessage(content="你还记得我吗?")}, config)

    print(final_response)

    for message in final_response["messages"]:
    message.pretty_print()

相关推荐
什么半岛铁盒9 小时前
LangChain 入门与架构:快速搭建你的第一个 AI 应用
人工智能·架构·langchain
BU摆烂会噶9 小时前
【LangGraph】House_Agent 实战(一):架构与环境配置
人工智能·vscode·python·架构·langchain·人机交互
pixle010 小时前
LangChain v1.2 Text-to-SQL 实战:从入门到生产级部署
sql·langchain·agent·智能助手·text-to-sql
BU摆烂会噶10 小时前
【LangGraph】House_Agent 实战(五):持久化、流式输出与部署
人工智能·python·架构·langchain·人机交互
Artech11 小时前
[对比学习LangChain和MAF-03]完全不同的Agent设计哲学
python·ai·langchain·c#·agent·maf
SuniaWang11 小时前
AgentX 专栏-00前言:一个Java开发者的Agent实践之路
java·人工智能·spring boot·langchain·系统架构
什么半岛铁盒11 小时前
LangChain常用组件学习
学习·microsoft·langchain
Restart-AHTCM12 小时前
LangChain学习之模型 I/O 与输出解析器 (Output Parsers)(3/8)
前端·学习·langchain
倾颜12 小时前
AI 应用里的第一个 Agent:我如何做一个可控的 Tasklist Agent
langchain·agent·next.js