node.js定时任务

require('node-schedule').scheduleJob('* * * * * *',function(){})

Posted by PanMin on June 4, 2017

node.js定时任务

定时任务可以用来导出某些数据,发送消息或者邮件,备份,抓取某些数据等。

安装node-schedule

npm install node-schedule

使用node-schedule

开启定时器

var schedule = require('node-schedule');
//每分钟的30秒时打印当前时间
schedule.scheduleJob('30 * * * * *',function(){
	console.log(new Date());
});

其他的写法:

var schedule = require('node-schedule');
//确认时间:2017年6月4日,15:40:00执行
var date = new Date(2017,6,4,15,40,0);
schedule.scheduleJob(date,function(){console.log(new Date());});

//固定时间
var rule = new schedule.RecurrenceRule();
rule.minute = 40;//每小时的40分钟时执行
schedule.scheduleJob(rule,function(){console.log(new Date());});

//另一种写法
schedule.scheduleJob({hour: 16, minute: 11, dayOfWeek: 1}, function(){
    console.log('scheduleObjectLiteralSyntax:' + new Date());
});

定时器时间通配符解析

* * * * * *
┬ ┬ ┬ ┬ ┬ ┬
│ │ │ │ │ |
│ │ │ │ │ └ 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)

6个占位符从左到右分别代表:秒、分、时、日、月、周几

*表示通配符,匹配任意,当秒是*时,表示任意秒数都触发,其它类推

下面可以看看以下传入参数分别代表的意思:
每分钟的第30秒触发: '30 * * * * *'
每小时的1分30秒触发 :'30 1 * * * *'
每天的凌晨1点1分30秒触发 :'30 1 1 * * *'
每月的1日1点1分30秒触发 :'30 1 1 1 * *'
2016年的1月1日1点1分30秒触发 :'30 1 1 1 2016 *'
每周1的1点1分30秒触发 :'30 1 1 * * 1'

'1-10 * * * * *':每分钟的1-10秒都会触发

取消定时器

var schedule = require('node-schedule');
//每秒打印当前时间
var j = schedule.scheduleJob('* * * * * *',function(){
	console.log(new Date())	;
});

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

后记

我后面会弄个微信公众号,然后通过node.js后台爬取一些小说的更新,抓到更新之后就通过公众号推送给自己 :smile: