node-schedule定时器

  |  

应用场景

定时导出某些数据、定时发送消息或邮件给用户、定时备份什么类型的文件等等

安装

npm install node-schedule

Cron风格定时器

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
通配符解释
* * * * * *
┬ ┬ ┬ ┬ ┬ ┬
│ │ │ │ │ |
│ │ │ │ │ └ 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'

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

Cron风格定时器-范围触发

1
2
3
4
schedule.scheduleJob('1-10 * * * * *', function(){
console.log('scheduleCronstyle:' + new Date());
});
每分钟的1-10秒都会触发

递归规则定时器

1
2
3
4
5
6
7
8
9
10
11
let rule = new schedule.RecurrenceRule();
// rule.dayOfWeek = 2;
// rule.month = 3;
// rule.dayOfMonth = 1;
// rule.hour = 1;
// rule.minute = 42;
rule.second = 0;

let j = schedule.scheduleJob(rule, function(){
console.log('scheduleRecurrenceRule:' + new Date());
})

每十分钟执行一次

1
2
3
4
5
let rule = new schedule.RecurrenceRule();
rule.minute = [ 0, 10, 20, 30, 40, 59 ];
let j = schedule.scheduleJob(rule, function(){
console.log('scheduleRecurrenceRule:' + new Date());
})

进阶用法

rule支持设置的值有secondminutehourdatedayOfWeekmonthyear

1
2
3
4
5
6
7
8
9
10
11
const schedule = require('node-schedule');

// 定义规则
let rule = new schedule.RecurrenceRule();
rule.minute = [0, 10, 20, 30, 40, 50]; // 每隔 10 分钟执行一次
rule.second = 0;

// 启动任务
let job = schedule.scheduleJob(rule, () => {
console.log(new Date());
});

每小时 30 分执行

1
2
rule.minute = 30;
rule.second = 0;

每天 0 点执行

1
2
3
rule.hour =0;
rule.minute =0;
rule.second =0;

每月 1 号的 10 点执行

1
2
3
4
rule.date = 1;
rule.hour = 10;
rule.minute = 0;
rule.second = 0;

每周一、周三、周五的 0 点和 12 点执行

1
2
3
4
rule.dayOfWeek = [1,3,5];
rule.hour = [0,12];
rule.minute = 0;
rule.second = 0;

取消定时器

1
j.cancel();
文章目录
  1. 1. 应用场景
  2. 2. 安装
  3. 3. Cron风格定时器
  4. 4. Cron风格定时器-范围触发
  5. 5. 递归规则定时器
  6. 6. 进阶用法
  7. 7. 取消定时器