Langchain开发过程中的注意事项

LangChain开发注意事项

核心问题

1. Token成本控制

  • 追踪Token使用:每次调用都会消耗Token,直接关联成本
  • 长对话问题:消息历史堆积会快速消耗Token和超出上下文窗口
  • 解决方案
    • 使用 SummarizationMiddleware 自动总结旧消息
    • 使用 ClearToolUsesMiddleware 清理旧工具输出
    • 定期检查 usage_metadata 字段追踪消耗
python 复制代码
# 监控Token使用
response = model.invoke("...")
print(response.usage_metadata)
# {'input_tokens': 8, 'output_tokens': 304, 'total_tokens': 312}

2. 消息历史管理

  • 不是所有消息都必需保存:历史消息应该有策略地清理或总结
  • 短期记忆vs长期记忆
    • 短期(State):当前对话的消息
    • 长期(Store):跨对话的用户信息
  • 实践:在多轮对话前设置最大消息数限制
python 复制代码
# 保留最近的N条消息
if len(messages) > 20:
    messages = messages[-20:]  # 只保留最近20条

3. 工具定义的关键性

  • 工具描述决定调用:Agent通过读工具的docstring来决定是否调用
  • 差的描述导致错误调用:Agent可能调用错误的工具或不调用工具
python 复制代码
# ❌ 不好:描述模糊
@tool
def do_something(x: str) -> str:
    """做某事"""
    pass

# ✅ 好:清晰说明何时使用
@tool
def search_user_database(name: str) -> str:
    """在用户数据库中搜索。用于查找特定用户信息时调用。"""
    pass

常见错误

4. 消息格式问题

  • 错误的消息类型 :混淆 HumanMessage, AIMessage, ToolMessage
  • 上下文窗口溢出INVALID_CHAT_HISTORY 错误
  • 解决:确保消息格式一致,定期检查总长度

5. API认证和速率限制

  • MODEL_AUTHENTICATION:API密钥无效或未设置
  • MODEL_RATE_LIMIT:超出速率限制,需要重试逻辑
  • 实践
    • 使用环境变量管理API密钥
    • 实现指数退避重试
python 复制代码
# 使用重试中间件
from langchain.agents.middleware import RetryMiddleware

agent = create_agent(
    model=llm,
    tools=[...],
    middleware=[RetryMiddleware(max_retries=3)]
)

6. 结构化输出问题

  • OUTPUT_PARSING_FAILURE:模型返回的数据不符合Schema
  • 解决 :使用 toolStrategyproviderStrategy 自动重试
python 复制代码
from langchain import toolStrategy
from pydantic import BaseModel

class ContactInfo(BaseModel):
    name: str
    email: str

agent = create_agent(
    model=llm,
    responseFormat=toolStrategy(ContactInfo)  # 自动验证和重试
)

性能最佳实践

7. 上下文工程(Context Engineering)

  • 动态选择工具:不要暴露所有工具,运行时选择相关工具
  • 动态选择模型:复杂问题用强模型,简单问题用便宜模型
  • 循序渐进:从静态Prompt开始,再加动态特性
python 复制代码
# 动态选择工具
from langchain.agents.middleware import create_middleware

dynamic_tools_mw = create_middleware({
    'wrapModelCall': lambda request, handler: (
        handler(request.override(tools=select_relevant_tools(request.state)))
    )
})

8. 中间件设计

  • 中间件执行顺序很重要before hooks顺序执行,after hooks逆序执行
  • 保持中间件专注:每个中间件只做一件事
  • 使用内置中间件:优先用官方提供的而不是自己写
python 复制代码
# 好的中间件设计
@wrap_model_call
def logging_middleware(request, handler):
    """只负责日志"""
    print(f"Model call: {len(request.messages)} messages")
    return handler(request)

9. 流式处理的坑

  • Token计数问题:某些provider(如OpenAI)流式模式需要opt-in获取Token
  • 部分响应处理:流式响应需要处理不完整的消息
  • 解决:检查provider文档中关于流式Token的说明

生产环境注意事项

10. 监控和告警

  • 追踪性能指标:latency、error rate、token成本
  • 监控限制:错误率、延迟峰值、成本异常
  • 使用LangSmith:自动追踪所有调用

11. 错误处理

  • 常见错误码
    • GRAPH_RECURSION_LIMIT:Agent陷入循环
    • INVALID_TOOL_RESULTS:工具返回格式错误
    • MODEL_NOT_FOUND:模型名称错误
python 复制代码
# 实现健壮的错误处理
try:
    response = agent.invoke(input)
except Exception as e:
    if hasattr(e, 'lc_error_code'):
        if e.lc_error_code == 'MODEL_RATE_LIMIT':
            # 实现重试
            pass

12. 成本优化

  • 追踪每个模型的成本 :使用 UsageMetadataCallbackHandler
  • 使用缓存:某些provider(如Anthropic)支持prompt缓存
  • 选择合适的模型:根据任务复杂度选cheap还是powerful
python 复制代码
# 追踪多个模型的成本
with get_usage_metadata_callback() as cb:
    model_1.invoke("...")
    model_2.invoke("...")
    print(cb.usage_metadata)  # 聚合统计

总结

最常见的问题按优先级:

  1. Token成本失控 - 必须监控和限制
  2. 消息历史爆炸 - 实现自动总结或清理
  3. 工具描述不清 - 直接影响Agent表现
  4. API速率限制 - 需要重试和延迟策略
  5. 中间件执行顺序 - 影响功能和性能
相关推荐
g32308631 小时前
Langchain mcp 可视化界面
langchain·mcp
m0_613856291 小时前
mysql如何利用事务隔离级别解决特定业务冲突_mysql隔离方案选型
jvm·数据库·python
AI_小站1 小时前
6个GitHub爆火的免费大模型教程,助你快速进阶AI编程
人工智能·langchain·github·知识图谱·agent·llama·rag
收获不止数据库1 小时前
达梦9发布会归来:AI 时代,我们需要一款什么样的数据库?
数据库·人工智能·ai·语言模型·数据分析
xskukuku2 小时前
VSCode中的Codex插件如何调用第三方API
vscode·ai·codex
我的xiaodoujiao2 小时前
API 接口自动化测试详细图文教程学习系列16--项目实战演练3
python·学习·测试工具·pytest
ID_180079054732 小时前
Python 实现亚马逊商品详情 API 数据准确性校验(极简可用 + JSON 参考)
java·python·json
时空系2 小时前
第10篇:继承扩展——面向对象编程进阶 python中文编程
开发语言·python·ai编程
胖墩会武术2 小时前
Obsidian 与 Obsidian Skills 小白入门
人工智能·ai·obsidian·obsidian skills
CHANG_THE_WORLD3 小时前
python 批量终止进程exe
开发语言·python