摘要:本篇文章探讨了Node.js教程之在Node.js中实现任务调度与执行,希望阅读本篇文章以后大家有所收获,帮助大家对相关内容的理解更加深入。
本篇文章探讨了Node.js教程之在Node.js中实现任务调度与执行,希望阅读本篇文章以后大家有所收获,帮助大家对相关内容的理解更加深入。
<
批处理是业务开发中经常会遇到的需求,比如银行对账单的处理,又比如广告邮件的推送。
Node.js在批处理方面也有一些优秀的库,node-schedule就是其中之一。
node-schedule是一个轻量级的、基于Node.js的、类似于cron的调度器工具。其介绍可查看: https://www.npmjs.com/package/node-schedule
node-schedule允许在指定的日期时间调度执行任意任务(任意的函数),还支持循环规则。node-schedule内部只使用了单个计时器。
node-schedule是基于时间的调度器,而不是基于时间间隔的调度器。假如你有这样的需求“每隔5分钟运行某个函数一次”,你会觉得使用基于时间间隔的调度方式更适合,比如setInterval(),使用非常方便。假如你的需求是“每小时的第5分钟和第50分钟运行某个函数一次”,那么你会觉得基于时间的调度方式更适合。
还要注意,与cron不同,node-schedule在Windows系统也能得到完美的支持。
需要注意的是,node-schedule的设计目标是用于进程间的调度,也即调度的作业在调度时会运行相关脚本,当脚本执行完成后调度将消失。如果希望在脚本未运行的时候持续调度作业,那么最好还是使用cron。
在node-schedule中,每一个被调度的作业都是使用Job对象来描述的。可以手动创建Job,然后执行schedule()方法来应用调度,或使用scheduleJob()。
Job对象是EventEmitter的,在每一次调度执行时发出一个运行事件。在调度的时间到来时,它还会发出被调度的事件。当调度开始之前,要取消调度,可以发取消事件。这些事件都接收JavaScript的日期对象作为参数。
要注意,作业在首次调度时是立即执行的,因此如果你使用scheduleJob()创建作业,会失去首次立即调度的事件。
还要注意,取消事件是canceled,表达方式采用了美国英语。
要安装node-schedule很简单,执行:
npm install node-schedule
如果你用过cron,了解cron表达式的格式,使用它则更简单。
Cron风格的调度
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)
下面来看一个例子:
var scheduler = require(‘node-schedule‘);
var montlyJob = scheduler.scheduleJob(‘0 0 1 * *‘, function(){
console.log(‘I run the first day of the month‘);
});
还有使用JavaScript对象的方法:
var scheduler = require(‘node-schedule‘);
var rule = new scheduler.RecurrenceRule();
rule.hour = 7
rule.dayOfWeek = new scheduler.Range(0,6)
var dailyJob = scheduler.scheduleJob(date, function(){
console.log(‘I run on days at 7:00‘);
});
scheduler.scheduleJob(rule,task);
还可以跳过指定日期来调度任务:
var scheduler = require(‘node-schedule‘);
var date = new Date(2017, 1, 1, 0, 0, 0);
var newYearJob = scheduler.scheduleJob(date, function() {
console.log("Happy new year");
});
要取消调度的作业也很简单,这样:
newYearJob.cancel();
$(function () {
$(‘pre.prettyprint code‘).each(function () {
var lines = $(this).text().split(‘\n‘).length;
var $numbering = $(‘<ul/>‘).addClass(‘pre-numbering‘).hide();
$(this).addClass(‘has-numbering‘).parent().append($numbering);
for (i = 1; i <= lines; i++) {
$numbering.append($(‘<li/>‘).text(i));
};
$numbering.fadeIn(1700);
});
});
本文由职坐标整理发布,学习更多的相关知识,请关注职坐标IT知识库!
您输入的评论内容中包含违禁敏感词
我知道了
请输入正确的手机号码
请输入正确的验证码
您今天的短信下发次数太多了,明天再试试吧!
我们会在第一时间安排职业规划师联系您!
您也可以联系我们的职业规划师咨询:
版权所有 职坐标-一站式IT培训就业服务领导者 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
沪公网安备 31011502005948号