跳到主要内容
在许多情况下,定期运行助手会很有用。 例如,假设您正在构建一个每日运行并发送当日新闻摘要电子邮件的助手。您可以使用 cron 作业每天晚上 8:00 运行该助手。 LangSmith Deployment 支持 cron 作业,这些作业按用户定义的计划运行。用户指定一个计划、一个助手和一些输入。之后,在指定的计划上,服务器将:
  • 使用指定的助手创建新线程
  • 将指定的输入发送到该线程
请注意,这每次都会向线程发送相同的输入。 LangGraph Server API 提供了几个用于创建和管理 cron 作业的端点。有关更多详细信息,请参阅API 参考 有时您不希望根据用户交互运行您的图,而是希望安排您的图定期运行——例如,如果您希望您的图组合并发送每周待办事项电子邮件给您的团队。LangSmith Deployment 允许您通过使用 Crons 客户端来完成此操作,而无需编写自己的脚本。要安排图作业,您需要传递一个cron 表达式来告知客户端您希望何时运行该图。Cron 作业在后台运行,不会干扰图的正常调用。

设置

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

client = get_client(url=<DEPLOYMENT_URL>)
# Using the graph deployed with the name "agent"
assistant_id = "agent"
# create thread
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
}

线程上的 Cron 作业

要创建与特定线程关联的 cron 作业,您可以编写
  • Python
  • Javascript
  • CURL
# This schedules a job to run at 15:27 (3:27PM) every day
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 作业
  • Python
  • Javascript
  • CURL
await client.crons.delete(cron_job["cron_id"])

无状态 Cron 作业

您还可以使用以下代码创建无状态 cron 作业
  • Python
  • Javascript
  • CURL
# This schedules a job to run at 15:27 (3:27PM) every day
cron_job_stateless = await client.crons.create(
    assistant_id,
    schedule="27 15 * * *",
    input={"messages": [{"role": "user", "content": "What time is it?"}]},
)
再次提醒,完成作业后请务必删除它!
  • Python
  • Javascript
  • CURL
await client.crons.delete(cron_job_stateless["cron_id"])

以编程方式连接这些文档到 Claude、VSCode 等,通过 MCP 获取实时答案。
© . This site is unofficial and not affiliated with LangChain, Inc.