createAgent() 提供了生产就绪的代理实现。
LLM 代理在循环中运行工具以实现目标。
代理运行直到满足停止条件——即,当模型发出最终输出或达到迭代限制时。
核心组件
模型
模型是代理的推理引擎。它可以以多种方式指定,支持静态和动态模型选择。静态模型
静态模型在创建代理时配置一次,并在整个执行过程中保持不变。这是最常见和直接的方法。 要从初始化静态模型:provider:model 格式(例如 "openai:gpt-5")。您可能希望对模型配置有更多控制权,在这种情况下,您可以直接使用提供商包初始化模型实例:
temperature、max_tokens、timeouts)或配置 API 密钥、base_url 和其他提供商特定设置时使用它们。请参阅API 参考以查看模型上的可用参数和方法。
动态模型
动态模型是根据当前和上下文在选择的。这使得复杂的路由逻辑和成本优化成为可能。 要使用动态模型,请使用wrapModelCall 创建修改请求中模型的中间件:
工具
工具赋予代理采取行动的能力。代理不仅仅是简单的模型工具绑定,还促进了:- 序列中的多个工具调用(由单个提示触发)
- 适当时并行调用工具
- 基于先前结果的动态工具选择
- 工具重试逻辑和错误处理
- 跨工具调用的状态持久性
静态工具
静态工具在创建代理时定义,并在整个执行过程中保持不变。这是最常见和直接的方法。 要定义具有静态工具的代理,请将工具列表传递给代理。动态工具
使用动态工具,代理可用的工具集是在运行时修改的,而不是全部预先定义的。并非每个工具都适合每种情况。太多的工具可能会压倒模型(过载上下文)并增加错误;太少则限制了能力。动态工具选择使得能够根据身份验证状态、用户权限、功能标志或对话阶段调整可用的工具集。 有两种方法,取决于工具是否提前已知:- 过滤预注册工具
- 运行时工具注册
当所有可能的工具在代理创建时已知时,您可以预注册它们,并根据状态、权限或上下文动态过滤向模型公开的工具。这种方法最适合:
- 状态
- Store
- 运行时上下文
仅在某些对话里程碑后启用高级工具:
- 所有可能的工具在编译/启动时已知
- 您希望基于权限、功能标志或对话状态进行过滤
- 工具是静态的,但其可用性是动态的
工具错误处理
要自定义工具错误的处理方式,请在自定义中间件中使用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 调用代理以获得最终响应。如果代理执行多个步骤,这可能需要一段时间。为了显示中间进度,我们可以在消息发生时流回它们。
中间件
中间件为在执行的不同阶段自定义代理行为提供了强大的可扩展性。您可以使用中间件来:- 在调用模型之前处理状态(例如,消息修剪、上下文注入)
- 修改或验证模型的响应(例如,护栏、内容过滤)
- 使用自定义逻辑处理工具执行错误
- 基于状态或上下文实现动态模型选择
- 添加自定义日志记录、监控或分析
将这些文档连接 到 Claude、VSCode 等,通过 MCP 获取实时答案。

