createAgent
在 v1 中,预构建的 react agent 现在位于 langchain 包中。下表概述了功能的变化:
| 部分 | 变更内容 |
|---|---|
| 导入路径 | 包从 @langchain/langgraph/prebuilts 移动到 langchain |
| 提示 | 参数重命名为 systemPrompt,动态提示使用中间件 |
| 模型前钩子 | 由带有 beforeModel 方法的中间件替代 |
| 模型后钩子 | 由带有 afterModel 方法的中间件替代 |
| 自定义状态 | 在中间件中定义,仅限 zod 对象 |
| 模型 | 通过中间件动态选择,不支持预绑定模型 |
| 工具 | 工具错误处理移至带有 wrapToolCall 的中间件 |
| 结构化输出 | 提示输出已移除,使用 toolStrategy/providerStrategy |
| 流式节点名称 | 节点名称从 "agent" 更改为 "model" |
| 运行时上下文 | 使用 context 属性替代 config.configurable |
| 命名空间 | 简化为专注于 agent 构建块,旧版代码移至 @langchain/classic |
导入路径
react agent 预构建的导入路径已从@langchain/langgraph/prebuilts 更改为 langchain。函数名称已从 createReactAgent 更改为 createAgent:
提示
静态提示重命名
prompt 参数已重命名为 systemPrompt:
SystemMessage
如果在系统提示中使用 SystemMessage 对象,现在将直接使用字符串内容:
动态提示
动态提示是核心上下文工程模式——它们根据当前对话状态调整您告诉模型的内容。为此,请使用dynamicSystemPromptMiddleware:
模型前钩子
模型前钩子现在作为带有beforeModel 方法的中间件实现。这种模式更具可扩展性——您可以定义多个中间件在模型调用前运行,并在多个 agent 之间重用它们。
常见用例包括:
- 总结对话历史
- 裁剪消息
- 输入防护栏,如 PII 脱敏
模型后钩子
模型后钩子现在作为带有afterModel 方法的中间件实现。这允许您在模型响应后组合多个处理程序。
常见用例包括:
- 人工在环审批
- 输出防护栏
自定义状态
自定义状态现在在中间件中使用stateSchema 属性定义。使用 Zod 声明在 agent 运行期间传递的附加状态字段。
模型
动态模型选择现在通过中间件发生。使用wrapModelCall 根据状态或运行时上下文交换模型(和工具)。在 createReactAgent 中,这是通过传递给 model 参数的函数完成的。
此功能已移植到 v1 中的中间件接口。
动态模型选择
预绑定模型
为了更好地支持结构化输出,createAgent 应接收一个普通模型(字符串或实例)和一个单独的 tools 列表。使用结构化输出时,避免传递预绑定工具的模型。
工具
createAgent 的 tools 参数接受:
- 使用
tool创建的函数 - LangChain 工具实例
- 表示内置提供程序工具的对象
处理工具错误
您现在可以使用实现wrapToolCall 方法的中间件来配置工具错误的处理。
结构化输出
节点变更
结构化输出过去是在与主 agent 分离的节点中生成的。现在不再是这样。结构化输出在主循环中生成(无需额外的 LLM 调用),从而降低成本和延迟。工具和提供程序策略
在 v1 中,有两种策略:toolStrategy使用人工工具调用来生成结构化输出providerStrategy使用提供程序原生的结构化输出生成
提示输出已移除
通过responseFormat 中的自定义指令进行的提示输出已移除,转而使用上述策略。
流式节点名称重命名
当从 agent 流式传输事件时,节点名称已从"agent" 更改为 "model",以更好地反映节点的用途。
运行时上下文
调用 agent 时,通过context 配置参数传递静态、只读配置。这取代了使用 config.configurable 的模式。
旧的
config.configurable 模式仍然有效以实现向后兼容性,但建议在新应用程序或迁移到 v1 的应用程序中使用新的 context 参数。标准内容
在 v1 中,消息获得了与提供程序无关的标准内容块。通过message.contentBlocks 访问它们,以获得跨提供程序的一致、类型化视图。现有的 message.content 字段对于字符串或提供程序原生结构保持不变。
变更内容
- 消息上新增
contentBlocks属性,用于规范化内容。 ContentBlock下新增 TypeScript 类型,用于强类型化。- 通过
LC_OUTPUT_VERSION=v1或outputVersion: "v1"可选地将标准块序列化到content中。
读取标准化内容
创建多模态消息
示例块类型
序列化标准内容
默认情况下,标准内容块不会序列化到content 属性中。如果您需要在 content 属性中访问标准内容块(例如,在向客户端发送消息时),可以选择将它们序列化到 content 中。
简化包
langchain 包命名空间已简化,专注于 agent 构建块。旧版功能已移至 @langchain/classic。新包仅公开最有用和相关的功能。
导出
v1 包包括:| 模块 | 可用内容 | 备注 |
|---|---|---|
| Agents | createAgent, AgentState | 核心 agent 创建功能 |
| Messages | 消息类型、内容块、trimMessages | 从 @langchain/core 重新导出 |
| Tools | tool, 工具类 | 从 @langchain/core 重新导出 |
| Chat models | initChatModel, BaseChatModel | 统一模型初始化 |
@langchain/classic
如果您使用旧版链、索引 API 或先前从 @langchain/community 重新导出的功能,请安装 @langchain/classic 并更新导入:
破坏性变更
不再支持 Node 18
所有 LangChain 包现在都需要 Node.js 20 或更高版本。Node.js 18 已于 2025 年 3 月结束生命周期。新的构建输出
所有 langchain 包的构建现在使用基于捆绑器的方法,而不是使用原始 TypeScript 输出。如果您过去从dist/ 目录导入文件(不推荐),则需要更新导入以使用新的模块系统。
旧版代码移至 @langchain/classic
标准接口和 agent 重点之外的旧版功能已移至 @langchain/classic 包。有关核心 langchain 包中可用内容以及移至 @langchain/classic 的内容的详细信息,请参阅简化包部分。
移除已弃用的 API
已弃用并计划在 1.0 中删除的方法、函数和其他对象已被删除。查看已移除的已弃用 API
查看已移除的已弃用 API
以下已弃用的 API 已在 v1 中移除:
核心功能
TraceGroup- 改用 LangSmith 跟踪BaseDocumentLoader.loadAndSplit- 改用.load()后接文本分割器RemoteRunnable- 不再支持
提示
BasePromptTemplate.serialize和.deserialize- 直接使用 JSON 序列化ChatPromptTemplate.fromPromptMessages- 改用ChatPromptTemplate.fromMessages
检索器
BaseRetrieverInterface.getRelevantDocuments- 改用.invoke()
Runnables
Runnable.bind- 改用.bindTools()或其他特定绑定方法Runnable.map- 改用.batch()RunnableBatchOptions.maxConcurrency- 在配置对象中使用maxConcurrency
聊天模型
BaseChatModel.predictMessages- 改用.invoke()BaseChatModel.predict- 改用.invoke()BaseChatModel.serialize- 直接使用 JSON 序列化BaseChatModel.callPrompt- 改用.invoke()BaseChatModel.call- 改用.invoke()
LLM
BaseLLMParams.concurrency- 在配置对象中使用maxConcurrencyBaseLLM.call- 改用.invoke()BaseLLM.predict- 改用.invoke()BaseLLM.predictMessages- 改用.invoke()BaseLLM.serialize- 直接使用 JSON 序列化
流式处理
createChatMessageChunkEncoderStream- 直接使用.stream()方法
跟踪
BaseTracer.runMap- 改用 LangSmith 跟踪 APIgetTracingCallbackHandler- 改用 LangSmith 跟踪getTracingV2CallbackHandler- 改用 LangSmith 跟踪LangChainTracerV1- 改用 LangSmith 跟踪
内存和存储
BaseListChatMessageHistory.addAIChatMessage- 改用带有AIMessage的.addMessage()BaseStoreInterface- 改用特定的存储实现
实用程序
getRuntimeEnvironmentSync- 改用异步getRuntimeEnvironment()
通过 MCP 将这些文档连接到 Claude、VSCode 等,以获取实时答案。

