Node.js中基于node-schedule实现定时任务之详解

news2025/1/11 2:51:40

文章目录

      • 一、定时任务
      • 二、node-schedule、
        • 1、安装
        • 2、引入
        • 3、基于Cron表达式的规则
        • 4、基于Date的规则
        • 5、基于RecurrenceRule的规则
        • 6、API
        • 7、状态监听

一、定时任务

实际工作中,可能会遇到定时清除某个文件夹内容,定时发送消息或发送邮件给指定用户,定时导出某些数据等。借助setTimeout和setInterval来实现的化太过麻烦,node-schedule是一个非常不错的npm包,可以帮助我们快速的创建和管理定时任务。

定时任务是指在预定的时间点或时间间隔内执行的任务或操作。它们是自动化执行特定逻辑的一种方式,可用于执行重复性的、周期性的或计划性的任务。

定时任务通常用于以下情况:

  • 数据管理与备份:定时任务可以用于定期备份数据库中的数据,确保数据的安全性和可靠性。此外,还可以用于多个数据源之间的数据同步,保证数据的一致性。

  • 系统监控与维护:定时任务可以用于监控系统中的各种指标和状态,如服务器负载、数据库连接池的使用情况等,及时发现并解决潜在的问题。同时,也可以用于定期刷新缓存,保证缓存数据的及时性和准确性。

  • 执行定时任务:定时器可以用于在预定的时间间隔内执行特定的任务或代码块,例如数据备份、日志清理、缓存刷新等操作。

  • 定时提醒和通知:定时器可以用于实现定时提醒和通知功能,如闹钟、定时器应用等,通过设置定时器,在指定的时间点触发提醒或通知,帮助用户记住重要事件或完成特定任务。

  • 自动保存和自动提交:定时器可以用于自动保存或自动提交表单数据,通过设置定时器,在一定的时间间隔内自动将用户输入的数据保存到服务器或数据库,避免数据丢失或用户忘记保存的情况。

  • 定时刷新页面内容:定时器可以用于定时刷新页面的特定部分或整个页面,通过设置定时器,在一定的时间间隔内更新页面内容,如实时展示新闻、股票行情等。

  • 会话管理与心跳检测:在Web应用中,定时器可以用来检查并清理长时间未活动的用户会话,以及客户端和服务端之间利用定时器发送心跳包来维持长连接,及时发现连接异常。

  • 延迟执行与调度任务:定时器可以用于延迟发送消息或在非高峰时段执行批处理作业,减轻服务器负载。

二、node-schedule、

1、安装
npm install node-schedule
2、引入

CommonJS:

const schedule = require('node-schedule');

ES模块

import schedule from 'node-schedule'
3、基于Cron表达式的规则

Cron表达式是一种用于指定定时任务执行时间的字符串表示形式。它由6个字段组成,每个字段表示任务执行的时间单位和范围。

*    *    *    *    *    *
┬    ┬    ┬    ┬    ┬    ┬
│    │    │    │    │    │
│    │    │    │    │    └ 星期几(0 - 7) (0相对于周日) 
│    │    │    │    └───── 月 (1 - 12)
│    │    │    └────────── 日 (1 - 31)
│    │    └─────────────── 时 (0 - 23)
│    └──────────────────── 分 (0 - 59)
└───────────────────────── 秒 (0 - 59)

每个字段可以接受特定的数值、范围、通配符和特殊字符来指定任务的执行时间:

  • 数值:表示具体的时间单位,如1、2、10等。
  • 范围:使用-连接起始和结束的数值,表示一个范围内的所有值,如1-5表示1到5的所有数值。
  • 通配符:使用表示匹配该字段的所有可能值,如表示每分钟、每小时、每天等。
  • 逗号分隔:使用逗号分隔多个数值或范围,表示匹配其中任意一个值,如1,3表示1或3。
  • 步长:使用/表示步长,用于指定间隔的数值,如*/5表示每隔5个单位执行一次。
  • 特殊字符:Cron表达式还支持一些特殊字符来表示特定的含义,如?用于替代日和星期字段中的任意值,L表示最后一天,W表示最近的工作日等。

使用cron字符串作为rule时,建议写完整,可读性比较好。

以下是一些常见的Cron表达式示例:

* * * * * *     :每秒执行

*/5 * * * * *   :每5秒执行

* 30 * * * *    :每30分钟执行

*/10 30 * * * * :每30分钟的10秒执行

2,4,6 * * * * * :每个2秒,4秒和6秒执行

0 0 0 ? * 1     :每周一早上的零点执行

* * * 20 * ?    :每月的20日触发

4、基于Date的规则

当你需要在具体的时间执行一次,可以使用new Date来定义一个时间。

假设您非常希望在一个精确到某一个时间点上的秒数的仅触发一次的计划。

const schedule = require('node-schedule');
//2024年,6月,1日,6时,1分,0秒
//month 范围是 0~11 而非1~12
const date = new Date(2024, 5, 1, 6, 1, 0);
const job = schedule.scheduleJob(date, ()=>{
  console.log('Happy Children’s Day !');
});
5、基于RecurrenceRule的规则

如果你的任务是定时重复执行的,并且你希望有比cron更高的可读性,你可以尝试使用RecurrenceRule对象作为rule。

function Recurrence(year, month, date, dayOfWeek, hour, minute, second, tz)

dayOfWeek 范围是 0~6
month 范围是 0~11 而非1~12
如果是连续的值,node-schedule提供了一个Range函数用于创建连续的元素

  • 每分钟的15、30、45秒执行
const rule = new schedule.RecurrenceRule();
//每个15、30、45秒执行
rule.second = [15, 30, 45];
const job = schedule.scheduleJob(rule, () => {
    console.log(`每次计划执行的时间:${new Date().toLocaleString()}`);
});

在这里插入图片描述

  • 每分钟的第10秒
rule.second = 10;

在这里插入图片描述

  • 每小时的第10分钟
rule.minute = 10;
  • 每周四,周五,周六,周天的17点
rule.dayOfWeek = [0, new schedule.Range(4, 6)];
rule.hour = 17;
rule.minute = 0;
6、API
  • 开启定时任务

需要用到scheduleJob函数,会返回一个Job实例对象:

function scheduleJob(name: string, rule: ..., callback: function): schedule.Job

参数

参数名参数类型参数描述
name任务名,当你没有指定时,它将以时间戳作为名字。
rule任务调度的规则,支持多种形式的rule:
string - Cron表达式
number
schedule.RecurrenceRule
Date
callback创建任务时的回调函数

可以通过scheduleJob(name, rule, callback)或者scheduleJob(rule, callback)创建计划。

const rule = '* * * * * *';
const job = schedule.scheduleJob(rule,()=>{});
  • 取消定时任务
schedule.cancelJob(id)
7、状态监听
import schedule from 'node-schedule';

//设置规则
const rule = "*/10 * * * * *"

//设置任务
const job = schedule.scheduleJob(rule, () => {
    console.log('2、每次计划执行中的事件。');
});


job.on("scheduled", () => {
    console.log("1、每次计划执行前的事件。");
});


job.on("run", () => {
    console.log("3、每次计划执行后的事件。");
});


job.on("success", () => {
    console.log(`4、每次计划执行成功事件。`);
});


job.on("error", (err) => {
    console.log(`[error][${new Date().toLocaleString()}]${err.message}`);
});


job.on("canceled", () => {
    console.log("计划取消!");
})

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1834150.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

与Citrix桌面的共存期,如何保障一致体验?

在用户实际的应用场景中,从Citrix到深信服桌面云的替换并不是一蹴而就的过程。特别是对于已经投资购买Citrix桌面云的用户来说,如何最大限度地利用现有设备,实现成本效益最大化,是他们面临的一个重要问题。 为了应对这一需求&…

智慧工厂监控可视化解决方案(160页WORD)

方案介绍: 本智慧工厂监控可视化解决方案通过集成先进的物联网和大数据技术,为制造业企业提供了全面的数字化转型支持。通过实时监控、数据分析、可视化展示等功能,帮助企业提升生产效率、降低运营成本、优化产品质量和能源利用率&#xff0…

高考志愿填报,理科生如何分析选专业?

理科生选择专业的范围更大一些,相比文科说理工科的院校也更多,如何选择适合自己的专业,这是一个比较重要的课题,毕竟大学专业直接关系到职业,是一辈子的大事。 那么理科究竟如何选择专业呢?需要从什么地方…

【单片机毕业设计选题24013】-基于STM32的城市垃圾分类引导系统

系统功能: 1、系统具有语音识别功能,可以对厨余垃圾、其他垃圾、有害垃圾、可回收垃圾进行语音识别; 2、系统可根据语音识别结果直接开启对应类别的垃圾桶,引导分类投放; 3、系统具有语音播报功能,可以语音播报出识…

备忘录怎么插入文件和附件 备忘录插入文件附件方法

在繁忙的工作与生活中,我们时常需要记录各种信息,而备忘录则成为了我们不可或缺的得力助手。然而,当备忘录中需要包含的文件或附件越来越多时,如何高效、便捷地管理这些文件,便成为了一个亟待解决的问题。 想象一下&a…

STM32学习笔记(八)--DMA直接存储器存取详解

(1)配置步骤1.配置RCC外设时钟 开启DMA外设2.初始化DMA外设 调用DMA_Init 外设存储器站点的起始地址 数据宽度 地址是否自增 方向 传输计数器 是否需要自动重装 选择触发源 通道优先级3.开启DMA控制 4.开启触发信号输出(如果需要硬件触发&…

点云格网过程可视化(C++ PCL)

1、背景介绍 在以往的博客中,介绍过利用格网统计平面点云面积(具体参考博客:详解基于格网法统计平面点云面积_点云格网法计算xy投影面积-CSDN博客),其实点云格网化可以做其他内容,如边缘检测、格网关系拓扑…

「51媒体」食品展览展会活动,媒体邀约资源有哪些?

传媒如春雨,润物细无声,大家好,我是51媒体网胡老师。 食品展览展会活动在媒体邀约方面拥有丰富的资源,可以吸引各类媒体的关注和报道。以下是一些常见的媒体邀约资源: 1. 行业媒体: 专业食品杂志&#xff…

黑马苍穹外卖2 员工的增查改+异常处理+ThreadLocal

员工管理 新增员工 Controller: PostMapping//post类型的请求ApiOperation("添加员工")public Result save(RequestBody EmployeeDTO employeeDTO) {log.info("新增员工{}", employeeDTO);employeeService.save(employeeDTO);return Result.su…

ASN.1语言详解(编码规则、关键字、符号、数据类型)

目录 一. ASN.1基本信息 ▐ ASN.1编码规则 二. ASN.1语法规范 ▐ ASN.1的关键字 ▐ ASN.1的符号 ▐ ASN.1的数据类型 ▐ 示例 一. ASN.1基本信息 ASN.1(Abstract Syntax Notation One)是一种国际标准(由ITU-T X.680系列建议定义&#…

elasticsearch hanlp插件远程词典配置

elasticsearch hanlp插件远程词典配置 背景远程词典配置新增远程词典文件修改hanlp-remote.xml自动加载词典 远程词典测试 背景 在使用elasticsearch的过程中,总会遇到与分词相关的需求,这里将针对常用的elasticsearch hanlp(后面统称为 es …

表单中的常用元素

10.图像形式上传文件 <input type“image”>定义图像形式的提交。 src 属性和alt属性必须与<input type“image””>结合使用。 input type"image"src"img/l.jpg"alt"submit"/> 11.下拉列表框 <select>标签定义下拉列表框…

java基础-IDEA环境基础用法自动导包等设置

IDEA&#xff1a; 是用于Java语言开发的集成环境&#xff0c;它是业界公认的目前用于Java程序开发最好的工具。 把代码编写&#xff0c;编译&#xff0c;执行&#xff0c;调试等多种功能综合到一起的开发工具。 IDEA项目结构&#xff1a; 多级包用 . 链接。 快速生成 快…

解锁工业自动化:通过CANopen转Profinet的无缝对接

通过开疆智能CanOpen转ProfiNet网关&#xff08;KJ-PNG-205&#xff09;实现&#xff0c;上位机能够直接与CANopen总线驱动器进行通信&#xff0c;以实时获取设备运行状态信息。具体过程为&#xff1a;上位机通过发送CanOpen协议命令到CanOpen转ProfiNet网关&#xff0c;然后由…

华为手环9省电设置

1、 手环开启熄屏显示续航约3天&#xff0c;原因为屏幕持续常亮显示&#xff1b;如不需要可通过手环“设置->表盘->熄屏显示”路径进行关闭&#xff1b; 2、 手环具备后台健康自动检测功能&#xff0c;您可根据需要选择是否使用或关闭&#xff1a; &#xff08;1&#x…

怎么将文档翻译免费导出?这些工具让你写论文更轻松

对于许多学生&#xff0c;啃下外文文献的难度有时甚至超过了写论文。查词费时&#xff0c;段落翻译又常受限于字数。 在线翻译工具&#xff0c;作为语言间的桥梁&#xff0c;正在学术和商业领域变得越来越重要。 下面&#xff0c;让我们快速浏览一些免费的文档翻译软件app&am…

css之浏览器兼容性

css之浏览器兼容性 内核 内核代表作品 兼容的概念和原因 Hack的副作用 常见的CSS Bug 多个图片在一起&#xff0c;图片套个盒子 图片在IE浏览器上有蓝色边框 解决办法&#xff1a;给img加上 border:0 表单元素中距离顶部元素不一样 左边input 右边button 解决办法&#x…

四款让人大开眼界的高质量软件,个个实力超群,使用起来爱不释手

电脑里的Windows软件&#xff0c;简直多得数不清&#xff0c;啥都有。 像那个电子表格、写文章的、玩游戏聊天的、还有修图的&#xff0c;这些都太常见了&#xff0c;它们确实给咱们生活带来方便&#xff0c;但有时候也会让那些不太懂电脑的小伙伴们头疼不已。 讲真&#xff0…

物联网协议应用

目录 前言一、NTP协议1.1 NTP简介1.2 NTP实现 二、HTTP协议2.1 HTTP协议简介2.2 HTTP服务器 三、MQTT协议3.1 MQTT协议简介3.1.1 MQTT通信模型3.1.2 MQTT协议实现原理3.1.3 MQTT 控制报文 3.2 移植MQTT协议 前言 本文主要介绍一下物联网协议如NTP协议、HTTP协议和MQTT协议的接口…

elementPlus渲染需要权限校验的图片

技术栈&#xff1a;elementPlusvue3 html部分&#xff1a; <el-image :style"{width:width,height:height}" ref"previewimg" :src"previewSrc"></el-image> js部分 /*** 预览图片* param {String} url [图片的地址]*/const showP…