一些容易混淆的点(个人记录)

config 和 configurable:

config

是框架的标准流转载体,必须是请求内的局部变量,并发处理

configurable

configurable是config字典中的特殊字段,专门用来装载动态、因人而异、随时可配置的自定义参数。

存储着thread_id 和 checkpointer_id,一个是线程id,一个是节点id,精准定位。

makefile 复制代码
config = {
    # ------  config 层的"系统标准参数" ------
    "tags": ["v1.0", "production"],  # 给这次运行打标签,方便在 LangSmith 里搜索
    "metadata": {"source": "web"},   # 附加元数据
    "recursion_limit": 50,           # 【系统参数】:防止图陷入死循环,最多跑50步
    "callbacks": [my_custom_handler],# 【系统参数】:埋点监听器
    
    # ------  configurable (定制表单) ------
    "configurable": {
        # 【LangGraph 专属字段】
        "thread_id": "user_123",       # 抽屉钥匙
        "checkpoint_id": "1ef8...",    # 时光机钥匙
        
        # 【塞自己的自定义字段!】
        "user_vip_level": "gold",      # 比如传一个用户的 VIP 等级进去
        "llm_temperature": 0.7         # 动态决定这次大模型的温度
    }
}

Query 和 State:

Query:大门保安

python 复制代码
from pydantic import BaseModel
# 这是 FastAPI 的专属数据类型
class Query(BaseModel):
    question: str
    thread_id: str

State:厨房工单

python 复制代码
from typing import TypedDict, Annotated
from langgraph.graph.message import add_messages

# 这是 LangGraph 的专属数据类型
class AgentState(TypedDict):
    # messages 字段专门用来存聊天记录
    # Annotated[..., add_messages] 是魔法,代表新消息会自动追加,而不是覆盖
    messages: Annotated[list, add_messages] 
    
    # 你还可以随意加别的字段,比如大模型如果查了天气,就存在这里
    # current_weather: str

Query在FastAPI的路由函数中传给State

python 复制代码
@app.post("/chat/stream")
async def chat_stream(query: Query): # <--- 拿到 FastAPI 的 Query 对象
    
    # 1. 提取钥匙
    config = {"configurable": {"thread_id": query.thread_id}}
    
    # 2. 提取文本
    #    把 Query 里的纯文本 question,包装成 LangChain 标准的 HumanMessage,并塞进一个字典,这个字典的格式必须跟 AgentState 一模一样!
    initial_state_data = {
        "messages": [HumanMessage(content=query.question)]
    }
    
    # 3. 把初始的 state 数据交给 LangGraph 开始跑
    async for event in graph.astream_events(initial_state_data, config):
       

数据流转图

前后端流转

编排层流转

数据流转

相关推荐
IT_陈寒1 分钟前
JavaScript的异步地狱,我差点没爬出来
前端·人工智能·后端
AI木马人3 分钟前
20.人工智能实战:大模型项目如何从 Demo 走向生产?一套可落地的上线验收清单与工程治理方案
java·开发语言·人工智能
湘-枫叶情缘7 分钟前
穿透范畴的迷雾:从“四范式”到AI问题建模的现代认知框架
人工智能
@不误正业9 分钟前
OpenHarmony-A2A协议实战-多智能体跨应用协同架构与实现
人工智能·架构·harmonyos·开源鸿蒙
前端.火鸡10 分钟前
如何使用本地显卡算力给AI赋能(文生图、图生图等)分币不要、无限次数
人工智能
cyyt10 分钟前
深度学习周报(4.27~5.3)
人工智能·深度学习
圣殿骑士-Khtangc11 分钟前
大模型长任务自动化的迷思——信息熵定律的视角
人工智能
帅气的钟先生12 分钟前
OpenClaw + QQBot 实战:从 0 到 1 搭建你的消息自动化助手
运维·人工智能·自动化
王莎莎-MinerU18 分钟前
从 PDF 到知识资产:MinerU 文档解析如何成为企业 RAG 系统的“数据基石”
大数据·人工智能·pdf·个人开发
医工交叉实验工坊19 分钟前
PyMol插件自动可视化蛋白与配体(小分子药物)相互作用位点
人工智能