1
This commit is contained in:
@@ -1,33 +1,30 @@
|
||||
import { schedule_task } from '../models/index.js';
|
||||
import { safe_json_parse } from './json_utils.js';
|
||||
import cron from 'node-cron';
|
||||
import { cron_task_list } from '../config/cron_tasks.js';
|
||||
import { execute_action_and_record } from './task_executor.js';
|
||||
import { remove_cron_job, upsert_cron_job } from './cron_manager.js';
|
||||
|
||||
export async function reload_all_schedules() {
|
||||
const rows = await schedule_task.findAll();
|
||||
const cron_jobs = [];
|
||||
|
||||
for (const row of rows) {
|
||||
if (!row.enabled) {
|
||||
remove_cron_job(row.id);
|
||||
continue;
|
||||
}
|
||||
|
||||
upsert_cron_job(row.id, row.cron_expression, async () => {
|
||||
export function start_all_cron_tasks() {
|
||||
for (const task of cron_task_list) {
|
||||
const job = cron.schedule(task.cron_expression, async () => {
|
||||
try {
|
||||
await schedule_task.update(
|
||||
{ last_run_at: new Date() },
|
||||
{ where: { id: row.id } }
|
||||
);
|
||||
|
||||
await execute_action_and_record({
|
||||
action_name: row.action_name,
|
||||
action_payload: safe_json_parse(row.payload_json) || {},
|
||||
source: 'cron',
|
||||
schedule_task_id: row.id
|
||||
action_name: task.action_name,
|
||||
action_payload: task.action_payload || {},
|
||||
source: 'cron'
|
||||
});
|
||||
} catch (err) {
|
||||
// cron 执行失败已在 crawl_run_record 落库,避免重复抛出影响其它任务
|
||||
// 失败会在 crawl_run_record 落库
|
||||
}
|
||||
});
|
||||
|
||||
cron_jobs.push(job);
|
||||
}
|
||||
}
|
||||
|
||||
export function stop_all_cron_tasks() {
|
||||
for (const job of cron_jobs) {
|
||||
job.stop();
|
||||
}
|
||||
cron_jobs.length = 0;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user