Skip to main content
在许多情况下,按计划运行助手非常有用。 例如,假设你正在构建一个每天运行并发送每日新闻摘要邮件的助手。你可以使用定时任务在每天晚上8:00运行该助手。 LangSmith 部署支持定时任务,这些任务按用户定义的计划运行。用户指定一个计划、一个助手和一些输入。之后,在指定的时间表上,服务器将:
  • 使用指定的助手创建一个新线程
  • 将指定的输入发送到该线程
请注意,每次都会向线程发送相同的输入。 LangSmith 部署 API 提供了多个用于创建和管理定时任务的端点。有关更多详细信息,请参阅 API 参考 有时你不想基于用户交互来运行你的图,而是希望按计划安排你的图运行——例如,如果你希望你的图每周编写并发送一封包含团队待办事项的电子邮件。LangSmith 部署允许你通过使用 Crons 客户端来实现这一点,而无需编写自己的脚本。要安排一个图任务,你需要传递一个 cron 表达式 来告知客户端你希望何时运行该图。Cron 任务在后台运行,不会干扰图的正常调用。
所有定时计划均按 UTC 时间解释。在指定计划时,请确保将所需的执行时间转换为 UTC。

设置

首先,让我们设置我们的 SDK 客户端、助手和线程:
from langgraph_sdk import get_client

client = get_client(url=<DEPLOYMENT_URL>)
# 使用部署名称为 "agent" 的图
assistant_id = "agent"
# 创建线程
thread = await client.threads.create()
print(thread)
输出:
{
'thread_id': '9dde5490-2b67-47c8-aa14-4bfec88af217',
'created_at': '2024-08-30T23:07:38.242730+00:00',
'updated_at': '2024-08-30T23:07:38.242730+00:00',
'metadata': {},
'status': 'idle',
'config': {},
'values': None
}

线程上的定时任务

要创建与特定线程关联的定时任务,你可以编写:
# 这会安排一个任务在每天 UTC 15:27 (下午 3:27) 运行
cron_job = await client.crons.create_for_thread(
    thread["thread_id"],
    assistant_id,
    schedule="27 15 * * *",
    input={"messages": [{"role": "user", "content": "What time is it?"}]},
)
请注意,删除不再有用的 Cron 任务非常重要。否则,你可能会产生不必要的 LLM API 费用!你可以使用以下代码删除 Cron 任务:
await client.crons.delete(cron_job["cron_id"])

无状态定时任务

你也可以使用以下代码创建无状态定时任务。无状态定时任务为每次执行创建一个新线程:
# 这会安排一个任务在每天 UTC 15:27 (下午 3:27) 运行
cron_job_stateless = await client.crons.create(
    assistant_id,
    schedule="27 15 * * *",
    input={"messages": [{"role": "user", "content": "What time is it?"}]},
)
再次提醒,完成后请记得删除你的任务!
await client.crons.delete(cron_job_stateless["cron_id"])

无状态定时任务的线程清理

此功能需要 LangGraph API 版本 0.5.18 或更高版本,以及 Python SDK 0.3.2 或更高版本,或 JavaScript SDK 1.4.0 或更高版本。
每次触发无状态定时任务时,都会创建一个新线程。使用 on_run_completed 参数控制运行完成后该线程的处理方式:
  • "delete"(默认):运行完成后自动删除线程。
  • "keep":保留线程以供后续检索。你需要负责清理这些线程。有关推荐方法,请参阅 如何为你的应用添加 TTL

示例:保留线程以供后续检索

# 创建一个在执行后保留线程的无状态定时任务。
# 在 langgraph.json 中配置 checkpointer.ttl 以自动删除旧线程。
# 参见:https://docs.langchain.com/langsmith/configure-ttl
cron_job = await client.crons.create(
    assistant_id,
    schedule="27 15 * * *",
    input={"messages": [{"role": "user", "content": "Daily report"}]},
    on_run_completed="keep"
)

# 你稍后可以检索运行及其结果
runs = await client.runs.search(
    metadata={"cron_id": cron_job["cron_id"]}
)