nodejs的定时任务模块(node-schedule)

node-schedule模块介绍

定时触发某个任务,去完成类似导出数据,定时发送消息等.

安装

npm i node-schedule

Cron风格定时器

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

function scheduleCronstyle(){
    schedule.scheduleJob('30 * * * * *', function(){
        console.log('scheduleCronstyle:' + new Date());
    }); 
}

scheduleCronstyle();
Cron参数说明

┬ ┬ ┬ ┬ ┬ ┬
│ │ │ │ │ |
│ │ │ │ │ └ day of week (0 - 7) (0 or 7 is Sun)
│ │ │ │ └───── month (1 - 12)
│ │ │ └────────── day of month (1 - 31)
│ │ └─────────────── hour (0 - 23)
│ └──────────────────── minute (0 - 59)
└───────────────────────── second (0 - 59, OPTIONAL)

RecurrenceRule实例规则定时器

比如你需要传递一个参数,在每5或者10分钟执行一次,那么就可以这样来处理。

const schedule=require('node-schedule');
const esDb=require('./terminusEs');
function getRuleTimes(period){
    const times=[];
    for (let i = 0; i < 60; i=i+period) {
        times.push(i);
    }
    return times;
}

async function writeEsTask(period){
    //每period周期执行一次
    const rule=new schedule.RecurrenceRule();
    const times=getRuleTimes(period);
    rule.minute=times;
    // rule.second=times;
    schedule.scheduleJob(rule,async function(){
        await esDb.writeDataToEs();
    })
}

module.exports={
    writeEsTask,getRuleTimes
}
RecurrenceRule实例属性:

second
minute
hour
data
month
year
dayOfWeek

实力属性中未显示设置的属性值将默认为null(除了second属性默认为0)

取消定时器

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

function scheduleCancel(){
    var counter = 1;
    var j = schedule.scheduleJob('* * * * * *', function(){
        console.log('定时器触发次数:' + counter);
        counter++;
    });

    setTimeout(function() {
        console.log('定时器取消')
        j.cancel();   
    }, 5000);
}
scheduleCancel();

原理

定时任务是利用setTimeOut和event事件进行管理的,对所有加入的时间进行排序,并且计算当前时间和最近一个时间发生时间的时间间隔,然后调用setTimeOut设置回调。总的来说分两种时间,一种是一次性的,一种是周期性的,一次性任务调用完就结束,周期性的会不断循环调用,当一个周期性事件被调用后,会根据周期生成下一个周期任务,并添加到任务列表中,重新排序。每个任务调用结束,都会计算并准备下一个任务。

注意

在循环任务中,每个任务需要单独new Schedule.RecurrenceRule对象,不能公用。如果我们对循环中的时间成员木有设置,源码中,未设置的时间成员为null,循环结构的匹配采用是从分钟开始的逐步累加,如果发现某成员是null,那么就直接匹配,如果不是null,就从0开始,逐渐累加,直到完全匹配。

git地址:
https://github.com/node-schedule/node-schedule

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用 `node-schedule` 模块可以很方便地测试一个时间是否满足 cron 表达式。 首先需要安装 `node-schedule` 模块,可以使用以下命令进行安装: ``` npm install node-schedule ``` 接下来,可以使用 `schedule.cronJob()` 方法创建一个 cron 任务,并设置它的 cron 表达式。然后,可以使用 `job.nextInvocation()` 方法获取下一次任务执行的时间,或者使用 `job.pendingInvocations()` 方法获取未来若干个执行时间。 以下是一个示例代码: ```javascript const schedule = require('node-schedule'); // 创建一个 cron 任务 const job = schedule.cronJob('0 0 * * * *', function() { console.log('执行任务'); }); // 获取下一次任务执行的时间 console.log(job.nextInvocation().toString()); // 判断一个时间是否满足 cron 表达式 const date = new Date('2022-01-01T00:00:00Z'); // 设置一个时间 if (job.schedule(date)) { console.log(`${date} 满足 cron 表达式`); } else { console.log(`${date} 不满足 cron 表达式`); } ``` 在上面的示例中,创建了一个 cron 任务,它的 cron 表达式为每秒执行一次。然后使用 `nextInvocation()` 方法获取了下一次任务执行的时间,并输出了结果。接下来,设置了一个时间,并使用 `schedule()` 方法判断它是否满足 cron 表达式,最后输出了结果。 注意,`schedule()` 方法会返回一个布尔值,表示给定的时间是否满足 cron 表达式。如果返回 `true`,则表示满足;如果返回 `false`,则表示不满足。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值