Skip to main content
Trace(追踪)是您的应用程序从输入到输出所采取的一系列步骤。这些步骤中的每一个都由一个 run(运行)表示。您可以使用 LangSmith 可视化这些执行步骤。要使用它,请 为您的应用程序启用追踪。这使您能够执行以下操作:

先决条件

在开始之前,请确保您拥有以下内容:

启用追踪

要为您的应用程序启用追踪,请设置以下环境变量:
export LANGSMITH_TRACING=true
export LANGSMITH_API_KEY=<your-api-key>
默认情况下,trace 将记录到名为 `default` 的项目中。要配置自定义项目名称,请参阅 记录到项目 有关更多信息,请参阅 使用 LangGraph 进行追踪

选择性追踪

您可以选择使用 LangSmith 的 `tracing_context` 上下文管理器来追踪特定的调用或应用程序的部分:
import { LangChainTracer } from "@langchain/core/tracers/tracer_langchain";

// 这将被追踪
const tracer = new LangChainTracer();
await agent.invoke(
  {
    messages: [{role: "user", content: "Send a test email to alice@example.com"}]
  },
  { callbacks: [tracer] }
);

// 这将不会被追踪(如果未设置 LANGSMITH_TRACING)
await agent.invoke(
  {
    messages: [{role: "user", content: "Send another email"}]
  }
);

记录到项目

您可以通过设置 `LANGSMITH_PROJECT` 环境变量为整个应用程序设置自定义项目名称:
export LANGSMITH_PROJECT=my-agent-project
您可以为特定操作以编程方式设置项目名称:
import { LangChainTracer } from "@langchain/core/tracers/tracer_langchain";

const tracer = new LangChainTracer({ projectName: "email-agent-test" });
await agent.invoke(
  {
    messages: [{role: "user", content: "Send a test email to alice@example.com"}]
  },
  { callbacks: [tracer] }
);

向 trace 添加元数据

您可以使用自定义元数据和标签注释您的 trace:
import { LangChainTracer } from "@langchain/core/tracers/tracer_langchain";

const tracer = new LangChainTracer({ projectName: "email-agent-test" });
await agent.invoke(
  {
    messages: [{role: "user", content: "Send a test email to alice@example.com"}]
  },
  config: {
    tags: ["production", "email-assistant", "v1.0"],
    metadata: {
      userId: "user123",
      sessionId: "session456",
      environment: "production"
    }
  },
);

这些自定义元数据和标签将附加到 LangSmith 中的 trace 上。
要了解更多关于如何使用 trace 来调试、评估和监控您的 Agent,请参阅 LangSmith 文档

使用匿名器防止在 trace 中记录敏感数据

您可能希望屏蔽敏感数据以防止其被记录到 LangSmith。您可以创建 匿名器 并通过配置将其应用于 您的图。此示例将从发送到 LangSmith 的 trace 中编辑任何匹配社会安全号码格式 XXX-XX-XXXX 的内容。
TypeScript
import { StateGraph } from "@langchain/langgraph";
import { LangChainTracer } from "@langchain/core/tracers/tracer_langchain";
import { StateAnnotation } from "./state.js";
import { createAnonymizer } from "langsmith/anonymizer"
import { Client } from "langsmith"

const anonymizer = createAnonymizer([
  // 匹配 SSN
  { pattern: /\b\d{3}-?\d{2}-?\d{4}\b/, replace: "<ssn>" }
])

const langsmithClient = new Client({ anonymizer })
const tracer = new LangChainTracer({
  client: langsmithClient,
});

export const graph = new StateGraph(StateAnnotation)
  .compile()
  .withConfig({ callbacks: [tracer] });