跳到内容

INVALID_CHAT_HISTORY

当预构建的 create_react_agent 中的 call_model 图节点收到格式错误的 messages 列表时,会引发此错误。具体来说,当存在带有 tool_calls(LLM 请求调用工具)的 AIMessages,但没有相应的 ToolMessage(工具调用结果返回给 LLM)时,列表格式错误。

您可能会看到此错误的原因有以下几种

  1. 您在调用图时手动传递了一个格式错误的 messages 列表,例如 graph.invoke({'messages': [AIMessage(..., tool_calls=[...])]})
  2. 图在收到来自 tools 节点(即 ToolMessages 列表)的更新之前被中断,并且您使用非 None 或 ToolMessage 的输入调用了它,例如 graph.invoke({'messages': [HumanMessage(...)]}, config)。此中断可能是由以下方式之一触发的
    • 您在 create_react_agent 中手动设置了 interrupt_before = ['tools']
    • 其中一个工具引发了 ToolNode ("tools") 未处理的错误

故障排除

要解决此问题,您可以执行以下操作之一

  1. 不要使用格式错误的 messages 列表调用图
  2. 如果发生中断(手动或由于错误),您可以

    • 提供与现有工具调用匹配的 ToolMessages 并调用 graph.invoke({'messages': [ToolMessage(...)]})注意:这会将消息附加到历史记录中,并从 START 节点运行图。
    • 手动更新状态并从中断处恢复图

      1. 使用 graph.get_state(config) 从图状态获取最新的消息列表
      2. 修改消息列表,以删除 AIMessages 中未应答的工具调用,或添加带有与未应答的工具调用匹配的 tool_call_ids 的 ToolMessages
      3. 使用修改后的消息列表调用 graph.update_state(config, {'messages': ...})
      4. 恢复图,例如调用 graph.invoke(None, config)

评论