Movatterモバイル変換


[0]ホーム

URL:


跳转至

追踪

Agents SDK 内置了追踪功能,可在智能体运行期间收集完整的事件记录:LLM 生成、工具调用、任务转移、安全防护措施,甚至自定义事件。借助Traces 仪表板,你可以在开发和生产环境中调试、可视化并监控工作流。

Note

追踪默认启用。可通过两种方式禁用追踪:

  1. 设置环境变量OPENAI_AGENTS_DISABLE_TRACING=1 全局禁用追踪
  2. agents.run.RunConfig.tracing_disabled 设置为True,仅对单次运行禁用追踪

对于在使用 OpenAI API 时采用 Zero Data Retention (ZDR) 政策的组织,追踪不可用。

追踪与 Span

  • 追踪(Traces) 表示一次“工作流”的端到端操作,由多个 Span 组成。追踪具有以下属性:
    • workflow_name:逻辑上的工作流或应用名称。例如 “Code generation” 或 “Customer service”。
    • trace_id:追踪的唯一 ID。如果未传入会自动生成。必须满足格式trace_<32_alphanumeric>
    • group_id:可选的分组 ID,用于关联同一会话中的多个追踪。例如可使用聊天线程 ID。
    • disabled:为 True 时,该追踪不会被记录。
    • metadata:追踪的可选元数据。
  • Span 表示具有开始和结束时间的操作。Span 具有:
    • started_atended_at 时间戳。
    • trace_id,表示其所属的追踪
    • parent_id,指向其父 Span(若有)
    • span_data,关于该 Span 的信息。例如,AgentSpanData 包含关于智能体的信息,GenerationSpanData 包含关于 LLM 生成的信息等。

默认追踪

默认情况下,SDK 会追踪以下内容:

  • 整个Runner.{run, run_sync, run_streamed}() 会被trace() 包裹。
  • 每次智能体运行都会被agent_span() 包裹
  • LLM 生成会被generation_span() 包裹
  • 工具调用会分别被function_span() 包裹
  • 安全防护措施会被guardrail_span() 包裹
  • 任务转移会被handoff_span() 包裹
  • 音频输入(语音转文字)会被transcription_span() 包裹
  • 音频输出(文字转语音)会被speech_span() 包裹
  • 相关音频 Span 可能会被归为speech_group_span() 的子级

默认情况下,追踪名称为 “Agent workflow”。如果使用trace,你可以设置该名称;或者通过RunConfig 配置名称和其他属性。

此外,你可以设置自定义追踪进程,将追踪推送到其他目标(作为替代或附加目标)。

更高层级的追踪

有时你可能希望多次调用run() 属于同一个追踪。可以通过将整段代码包裹在trace() 中实现。

fromagentsimportAgent,Runner,traceasyncdefmain():agent=Agent(name="Joke generator",instructions="Tell funny jokes.")withtrace("Joke workflow"):# (1)!first_result=awaitRunner.run(agent,"Tell me a joke")second_result=awaitRunner.run(agent,f"Rate this joke:{first_result.final_output}")print(f"Joke:{first_result.final_output}")print(f"Rating:{second_result.final_output}")
  1. 由于两次对Runner.run 的调用都包裹在with trace() 中,单次运行将并入整体追踪,而不是创建两个追踪。

创建追踪

可以使用trace() 函数来创建追踪。追踪需要显式启动和结束,你有两种方式:

  1. 推荐:将追踪作为上下文管理器使用,即with trace(...) as my_trace。这会在合适的时间自动开始和结束追踪。
  2. 也可以手动调用trace.start()trace.finish()

当前追踪通过 Python 的contextvar 进行跟踪。这意味着它会自动适配并发场景。如果你手动开始/结束追踪,需要在调用start()/finish() 时分别传入mark_as_currentreset_current 来更新当前追踪。

创建 Span

你可以使用多种*_span() 方法创建 Span。通常无需手动创建 Span。提供了custom_span() 函数以跟踪自定义 Span 信息。

Span 会自动加入当前追踪,并嵌套在最近的当前 Span 下;当前 Span 通过 Python 的contextvar 进行跟踪。

敏感数据

某些 Span 可能会捕获潜在的敏感数据。

generation_span() 会存储 LLM 生成的输入/输出,function_span() 会存储函数调用的输入/输出。这些可能包含敏感数据,因此你可以通过RunConfig.trace_include_sensitive_data 禁用这些数据的采集。

类似地,音频相关的 Span 默认会包含输入和输出音频的 base64 编码 PCM 数据。你可以通过配置VoicePipelineConfig.trace_include_sensitive_audio_data 来禁用音频数据的采集。

自定义追踪进程

追踪的高层架构如下:

若要自定义默认设置,以将追踪发送到替代或附加的后端,或修改导出器行为,你有两种选择:

  1. add_trace_processor() 允许添加一个“额外”的追踪进程,它会在追踪和 Span 准备就绪时接收它们。这样你可以在将追踪发送到 OpenAI 后端之外,执行自定义处理。
  2. set_trace_processors() 允许“替换”默认的进程为你自己的追踪进程。除非你包含一个会发送到 OpenAI 后端的TracingProcessor,否则追踪将不会发送到 OpenAI 后端。

使用非 OpenAI 模型进行追踪

你可以在非 OpenAI 模型中使用 OpenAI API key,在无需禁用追踪的前提下,在 OpenAI Traces 仪表板启用免费的追踪。

importosfromagentsimportset_tracing_export_api_key,Agent,Runnerfromagents.extensions.models.litellm_modelimportLitellmModeltracing_api_key=os.environ["OPENAI_API_KEY"]set_tracing_export_api_key(tracing_api_key)model=LitellmModel(model="your-model-name",api_key="your-api-key",)agent=Agent(name="Assistant",model=model,)

备注

  • 在 OpenAI Traces 仪表板查看免费追踪。

外部追踪进程清单


[8]ページ先頭

©2009-2025 Movatter.jp