createAgent() 提供了一个生产就绪的代理实现。
一个 LLM 代理在循环中运行工具以实现目标。
代理会一直运行,直到满足停止条件——即当模型发出最终输出或达到迭代限制时。
核心组件
模型
模型 是您代理的推理引擎。可以通过多种方式指定,支持静态和动态模型选择。静态模型
静态模型在创建代理时配置一次,并在整个执行过程中保持不变。这是最常见且最直接的方法。 要从 初始化静态模型:provider:model(例如 "openai:gpt-5")。如果您需要对模型配置有更多控制,可以直接使用提供者包初始化模型实例:
temperature、max_tokens、timeouts)或配置 API 密钥、base_url 和其他提供者特定设置时,请使用它们。请参阅 API 参考 以查看模型上可用的参数和方法。
动态模型
动态模型在 根据当前 和上下文进行选择。这支持复杂的路由逻辑和成本优化。 要使用动态模型,请使用wrapModelCall 创建一个中间件来修改请求中的模型:
工具
工具赋予代理采取行动的能力。代理通过促进以下功能,超越了简单的仅模型工具绑定:- 按顺序进行多次工具调用(由单个提示触发)
- 在适当时进行并行工具调用
- 基于先前结果的动态工具选择
- 工具重试逻辑和错误处理
- 跨工具调用的状态持久化
静态工具
静态工具在创建代理时定义,并在整个执行过程中保持不变。这是最常见且最直接的方法。 要定义具有静态工具的代理,请将工具列表传递给代理。动态工具
使用动态工具时,代理可用的工具集在运行时修改,而不是全部预先定义。并非每个工具都适用于每种情况。工具太多可能会使模型不堪重负(上下文过载)并增加错误;工具太少会限制功能。动态工具选择支持根据身份验证状态、用户权限、功能标志或对话阶段调整可用工具集。 根据工具是否提前已知,有两种方法:- 过滤预注册工具
- 运行时工具注册
当所有可能的工具在代理创建时已知时,您可以预先注册它们,并根据状态、权限或上下文动态过滤暴露给模型的工具。此方法在以下情况下最佳:
- 状态
- 存储
- 运行时上下文
仅在达到特定对话里程碑后启用高级工具:
- 所有可能的工具在编译/启动时已知
- 您希望基于权限、功能标志或对话状态进行过滤
- 工具是静态的,但其可用性是动态的
工具错误处理
要自定义工具错误的处理方式,请在自定义中间件中使用wrapToolCall 钩子:
ToolMessage。
ReAct 循环中的工具使用
代理遵循 ReAct(“推理 + 行动”)模式,在简短的推理步骤和有针对性的工具调用之间交替进行,并将结果观察结果输入后续决策,直到可以提供最终答案。ReAct 循环示例
ReAct 循环示例
提示: 识别当前最受欢迎的无线耳机并验证库存。
- 推理:“流行度是时间敏感的,我需要使用提供的搜索工具。”
- 行动:调用
search_products("wireless headphones")
- 推理:“我需要在回答之前确认排名靠前的项目的库存。”
- 行动:调用
check_inventory("WH-1000XM5")
- 推理:“我有了最受欢迎的型号及其库存状态。我现在可以回答用户的问题了。”
- 行动:生成最终答案
系统提示
您可以通过提供提示来塑造代理处理任务的方式。systemPrompt 参数可以作为字符串提供:
systemPrompt 时,代理将直接从消息中推断其任务。
systemPrompt 参数接受 string 或 SystemMessage。使用 SystemMessage 可让您更好地控制提示结构,这对于提供者特定功能(如 Anthropic 的提示缓存)非常有用:
{ type: "ephemeral" } 的 cache_control 字段告诉 Anthropic 缓存该内容块,从而减少使用相同系统提示的重复请求的延迟和成本。
动态系统提示
对于更高级的用例,您需要根据运行时上下文或代理状态修改系统提示,您可以使用中间件。名称
为代理设置一个可选的name。当将代理作为子图添加到多代理系统时,这用作节点标识符:
调用
您可以通过向其State 传递更新来调用代理。所有代理的状态中都包含一个消息序列;要调用代理,请传递一条新消息:
stream 和 invoke。
高级概念
结构化输出
在某些情况下,您可能希望代理以特定格式返回输出。LangChain 提供了一种简单、通用的方法,使用responseFormat 参数来实现这一点。
内存
代理通过消息状态自动维护对话历史记录。您还可以配置代理使用自定义状态模式,以在对话期间记住附加信息。 存储在状态中的信息可以被认为是代理的短期记忆:流式传输
我们已经看到如何使用invoke 调用代理以获取最终响应。如果代理执行多个步骤,这可能需要一段时间。为了显示中间进度,我们可以在消息发生时流式传回消息。
中间件
中间件 为在不同执行阶段自定义代理行为提供了强大的可扩展性。您可以使用中间件来:- 在调用模型之前处理状态(例如,消息修剪、上下文注入)
- 修改或验证模型的响应(例如,护栏、内容过滤)
- 使用自定义逻辑处理工具执行错误
- 基于状态或上下文实现动态模型选择
- 添加自定义日志记录、监控或分析

