| 方法 | 使用场景 |
|---|---|
list_threads / listThreads | 你想浏览项目中的所有线程 |
read_thread / readThread | 你已知线程 ID 并需要其运行数据 |
线程的工作原理
你创建的每个运行都可以在其元数据中携带一个thread_id。LangSmith 使用此 ID 将运行分组为线程。后端会在 metadata 中查找 thread_id(如果找不到,则回退到 session_id 或 conversation_id)。
我们建议使用 UUID v7 作为线程 ID。UUIDv7 嵌入了时间戳,这可以保持线程正确的时间顺序。LangSmith SDK 导出了一个 uuid7 辅助函数(Python v0.4.43+,JS v0.3.80+):
- Python:
from langsmith import uuid7 - JS/TS:
import { uuid7 } from 'langsmith'
thread_id:
列出项目中的所有线程
list_threads / listThreads 获取项目中的所有线程,并将它们的运行数据分组在一起。结果按最近活动时间排序。
Output
参数
| 参数 | 类型 | 默认值 | 描述 |
|---|---|---|---|
project_name / projectName | string | — | 项目名称。如果未设置 project_id,则此项为必填。 |
project_id / projectId | string | — | 项目 ID。如果未设置 project_name,则此项为必填。 |
limit | int | 全部 | 要返回的最大线程数。 |
offset | int | 0 | 要跳过的线程数(用于分页)。 |
filter | string | — | 获取运行时应用的过滤表达式,使用 LangSmith 追踪查询语法。 |
start_time / startTime | datetime / Date | 1 天前 | 仅包含在此时间之后开始的运行。扩大此时间窗口以显示更早的线程。 |
返回值
一个线程对象列表,每个对象包含:| 字段 | 类型 | 描述 |
|---|---|---|
thread_id | string | 线程标识符。 |
runs | [Run](https://reference.langchain.com/python/langsmith/schemas/Run)[] | 此线程中的根运行,按时间顺序排序(最早在前)。 |
count | int | 此线程中的运行数量。 |
min_start_time | string | null | 最早运行的 ISO 时间戳。 |
max_start_time | string | null | 最近运行的 ISO 时间戳。 |
list_threads 始终只返回根运行。如果你需要子运行(例如,工具调用、子链),请改用 read_thread,它接受一个 is_root / isRoot 参数,你可以将其设置为 false。读取单个线程的运行数据
当你已知thread_id 时,使用 read_thread / readThread。它直接返回线程运行数据的迭代器,无需先获取所有线程。
list_threads 不同,这里的每个项目都是一个 Run 对象本身——没有分组包装器。默认情况下,运行按时间升序返回。
Output
参数
| 参数 | 类型 | 默认值 | 描述 |
|---|---|---|---|
thread_id / threadId | string | — | 必填。 要查询的线程。 |
project_name / projectName | string | — | 项目名称。如果未设置 project_id,则此项为必填。 |
project_id / projectId | string | string[] | — | 项目 ID 或 ID 列表。如果未设置 project_name,则此项为必填。 |
is_root / isRoot | bool | true | 仅返回根运行。设置为 false 以包含子运行。 |
limit | int | 全部 | 要返回的最大运行数。 |
filter | string | — | 附加过滤表达式(与线程过滤器组合)。 |
order | "asc" | "desc" | "asc" | 排序顺序。"asc" 按时间升序返回运行(最早在前)。 |
select | string[] | 所有字段 | 要返回的特定运行字段,以减小响应大小。 |
返回值
一个Run 对象的迭代器(Python)或异步迭代器(TypeScript)。
示例
按运行属性过滤线程
传递过滤表达式以使用 LangSmith 追踪查询语法缩小结果范围。例如,仅显示包含至少一个失败运行的线程:回溯超过 24 小时
默认情况下,list_threads 仅显示过去一天内有运行的线程。传递 start_time 以扩大时间窗口:
重建对话
使用read_thread 并设置 order="asc" 以逐轮重放对话:
将这些文档通过 MCP 连接到 Claude、VSCode 等,以获取实时答案。

