使用node-cron实现Node.js定时任务

1. 简介

node-cron 是一个轻量级的Node.js库,用于在指定时间或间隔执行任务。它是Unix系统cron工具的JavaScript实现,适用于需要定时执行脚本的场景(如数据备份、定期爬虫等)。

2. 安装

bash 复制代码
npm install node-cron
# 或
yarn add node-cron

3. 基础用法

javascript 复制代码
import cron from 'node-cron';

// 每分钟执行
cron.schedule('* * * * *', () => {
  console.log('每分钟触发');
});

4. Cron表达式详解

表达式由5个字段组成:

复制代码
*    *    *    *    *
┬    ┬    ┬    ┬    ┬
│    │    │    │    │
│    │    │    │    └── 星期几 (0 - 7) (0和7代表周日)
│    │    │    └────── 月份 (1 - 12)
│    │    └────────── 日期 (1 - 31)
│    └────────────── 小时 (0 - 23)
└─────────────────── 分钟 (0 - 59)

常用示例:

表达式 说明
*/5 * * * * 每5分钟
0 * * * * 每小时整点
0 0 * * * 每天午夜
0 9 * * 1-5 工作日早上9点
30 3 15 * * 每月15日凌晨3:30

5. 高级功能

5.1 带参数配置

javascript 复制代码
const task = cron.schedule('*/10 * * * *', () => {
  console.log('每10分钟执行');
}, {
  scheduled: true,       // 是否立即启动
  timezone: 'Asia/Shanghai' // 时区设置
});

5.2 任务控制

javascript 复制代码
// 暂停任务
task.stop();

// 恢复任务
task.start();

// 检查任务状态
console.log(task.getStatus()); // 返回 'running' 或 'stopped'

6. 实际应用示例

示例1:每日数据清理

javascript 复制代码
import cron from 'node-cron';
import cleanupDatabase from './cleanup.js';

// 每天凌晨3点清理
cron.schedule('0 3 * * *', () => {
  console.log('开始数据库清理...');
  cleanupDatabase();
});

示例2:API定时请求

javascript 复制代码
import axios from 'axios';

// 每30分钟获取天气数据
cron.schedule('*/30 * * * *', async () => {
  const res = await axios.get('https://api.weather.com/data');
  console.log('天气数据:', res.data);
});

7. 注意事项

  1. 精度问题:Node.js事件循环可能导致最多几毫秒的延迟
  2. 错误处理:务必在任务函数中添加try/catch
  3. 长任务:避免任务执行时间超过间隔时间
  4. 集群环境:在多进程部署时需要额外处理防止重复执行

8. 替代方案

  • node-schedule:更复杂的调度规则
  • bull:分布式任务队列
  • 系统级cron:通过child_process调用

🚀 提示 :在生产环境中建议添加日志记录和监控,可以使用winstonbunyan记录任务执行情况。

参考资料:

点个收藏,关注前端结城,一起用代码点亮前端世界!🚀

相关推荐
天下代码客11 小时前
使用electronc框架调用dll动态链接库流程和避坑
前端·javascript·vue.js·electron·node.js
weixin1997010801612 小时前
【性能提升300%】仿1688首页的Webpack优化全记录
前端·webpack·node.js
不倒翁玩偶14 小时前
npm : 无法将“npm”项识别为 cmdlet、函数、脚本文件或可运行程序的名称。请检查名称的拼写,如果包括路径,请确保路径正确,然后再试一次。
前端·npm·node.js
一心赚狗粮的宇叔15 小时前
03.Node.js依赖包补充说明及React&Node.Js项目
前端·react.js·node.js
-嘟囔着拯救世界-16 小时前
【2026 最新版】OpenAI 祭出王炸 GPT-5.3-Codex!Win11 + VSCode 部署保姆级教程
vscode·gpt·chatgpt·node.js·node·codex·gpt5
全栈前端老曹1 天前
【MongoDB】Node.js 集成 —— Mongoose ORM、Schema 设计、Model 操作
前端·javascript·数据库·mongodb·node.js·nosql·全栈
行者无疆_ty1 天前
什么是Node.js,跟OpenCode/OpenClaw有什么关系?
人工智能·node.js·openclaw
-凌凌漆-1 天前
【npm】npm的-D选项介绍
前端·npm·node.js
lucky67071 天前
Windows 上彻底卸载 Node.js
windows·node.js
Android系统攻城狮1 天前
鸿蒙系统Openharmony5.1.0系统之解决编译时:Node.js版本不匹配问题(二)
node.js·鸿蒙系统·openharmony·编译问题·5.1