Skip to content

使用定时任务(cron jobs)

有时你不想基于用户交互来运行你的图,而是希望按照计划定期运行图——例如,如果你希望图自动组合并发送团队每周待办事项的电子邮件。LangGraph 平台允许你通过使用 Crons 客户端来实现这一点,而无需编写自己的脚本。要安排一个图任务,你需要传递一个 cron 表达式 来通知客户端你希望在何时运行该图。Cron 任务在后台运行,不会干扰图的正常调用。

设置

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

from langgraph_sdk import get_client

client = get_client(url=<DEPLOYMENT_URL>)
# 使用名称为 "agent" 的图部署
assistant_id = "agent"
# 创建线程
thread = await client.threads.create()
print(thread)
import { Client } from "@langchain/langgraph-sdk";

const client = new Client({ apiUrl: <DEPLOYMENT_URL> });
// 使用名称为 "agent" 的图部署
const assistantId = "agent";
// 创建线程
const thread = await client.threads.create();
console.log(thread);
curl --request POST \
    --url <DEPLOYMENT_URL>/assistants/search \
    --header 'Content-Type: application/json' \
    --data '{
        "limit": 10,
        "offset": 0
    }' | jq -c 'map(select(.config == null or .config == {})) | .[0].graph_id' && \
curl --request POST \
    --url <DEPLOYMENT_URL>/threads \
    --header 'Content-Type: application/json' \
    --data '{}'

输出:

{
    '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
}

线程上的定时任务

要创建与特定线程关联的定时任务,你可以这样写:

# 这将安排一个任务每天在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": "现在几点了?"}]},
)
// 这将安排一个任务每天在15:27(下午3:27)运行
const cronJob = await client.crons.create_for_thread(
  thread["thread_id"],
  assistantId,
  {
    schedule: "27 15 * * *",
    input: { messages: [{ role: "user", content: "现在几点了?" }] }
  }
);
curl --request POST \
    --url <DEPLOYMENT_URL>/threads/<THREAD_ID>/runs/crons \
    --header 'Content-Type: application/json' \
    --data '{
        "assistant_id": <ASSISTANT_ID>,
    }'

请注意,**非常重要**的是删除不再需要的 Cron 任务。否则你可能会产生不必要的 LLM API 费用!你可以使用以下代码删除一个 Cron 任务:

await client.crons.delete(cron_job["cron_id"])
await client.crons.delete(cronJob["cron_id"]);
curl --request DELETE \
    --url <DEPLOYMENT_URL>/runs/crons/<CRON_ID>

Cron 任务无状态

你也可以使用以下代码创建无状态的 cron 任务:

# 这会安排一个任务在每天的 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?"}]},
)
// 这会安排一个任务在每天的 15:27(下午 3:27)运行
const cronJobStateless = await client.crons.create(
  assistantId,
  {
    schedule: "27 15 * * *",
    input: { messages: [{ role: "user", content: "What time is it?" }] }
  }
);
curl --request POST \
    --url <DEPLOYMENT_URL>/runs/crons \
    --header 'Content-Type: application/json' \
    --data '{
        "assistant_id": <ASSISTANT_ID>,
    }'

再次提醒,完成任务后请记得删除你的任务!

await client.crons.delete(cron_job_stateless["cron_id"])
await client.crons.delete(cronJobStateless["cron_id"]);
curl --request DELETE \
    --url <DEPLOYMENT_URL>/runs/crons/<CRON_ID>