NodeJs入門教程之定時器和隊(duì)列
一,介紹與需求
1.1,介紹
定時任務(wù)(node-schedule),是針對Node.js的一種靈活的cron-like和not-cron-like作業(yè)調(diào)度程序。它允許您使用可選的遞歸規(guī)則將作業(yè)(任意函數(shù))安排在特定日期執(zhí)行。它在任何給定的時間只使用一個計時器(而不是每秒鐘/分鐘重新評估即將到來的作業(yè))。
Async是一個實(shí)用模塊,它為異步JavaScript提供了直接、強(qiáng)大的功能。async流程控制器--queue(隊(duì)列),queue流程控制器是一個并行的流程控制器,但是它與parallel的區(qū)別在于queue可以控制一次執(zhí)行幾個函數(shù),而parallel只是讓所有函數(shù)并行執(zhí)行.
1.2,需求
實(shí)際開發(fā)項(xiàng)目中,會遇到很多定時任務(wù)的工作。比如:定時導(dǎo)出某些數(shù)據(jù)、定時發(fā)送消息或郵件給用戶、定時備份什么類型的文件等等。在當(dāng)時給用戶發(fā)送消息時,可能要發(fā)送的用戶就不只有一兩個,二是多個,這是可能就會用到隊(duì)列順序執(zhí)行。
二,定時器
第一步:安裝node-schedule
npm install node-schedule --save
第二步:封裝定時器模塊
const schedule = require('node-schedule');//定時器 const nodeTimer = {}; let cancelTimer = '' /** *Cron風(fēng)格定時器/對象文本語法定時器 * @param executionTime :定時器字符串'30 * * * * *'/定時器對象{hour: 16, minute: 11, dayOfWeek: 1} * @param callback :回調(diào)函數(shù) */ nodeTimer.scheduleTimer = (executionTime = '30 * * * * *', callback) => { // 每分鐘的第30秒觸發(fā): '30 * * * * *' // 每小時的1分30秒觸發(fā) :'30 1 * * * *' // 每天的凌晨1點(diǎn)1分30秒觸發(fā) :'30 1 1 * * *' // 每月的1日1點(diǎn)1分30秒觸發(fā) :'30 1 1 1 * *' // 2016年的1月1日1點(diǎn)1分30秒觸發(fā) :'30 1 1 1 2016 *' // 每周1的1點(diǎn)1分30秒觸發(fā) :'30 1 1 * * 1' cancelTimer = schedule.scheduleJob(executionTime, () => { if (typeof callback === 'function') { callback() } }); } module.exports = nodeTimer;
第三步:調(diào)用
在回調(diào)函數(shù)中寫入要執(zhí)行的任務(wù)代碼,一個定時器就完成了!
引入定時器模塊:
const nodeTimer = require('./node_timer.js');
1,Cron風(fēng)格定時器
規(guī)則參數(shù)講解 *代表通配符
* * * * * *
┬ ┬ ┬ ┬ ┬ ┬
│ │ │ │ │ │
│ │ │ │ │ └ 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個占位符從左到右分別代表:秒、分、時、日、月、周幾
*表示通配符,匹配任意,當(dāng)秒是*時,表示任意秒數(shù)都觸發(fā),其它類推
// 每分鐘的第30秒觸發(fā): '30 * * * * *' // 每小時的1分30秒觸發(fā) :'30 1 * * * *' // 每天的凌晨1點(diǎn)1分30秒觸發(fā) :'30 1 1 * * *' // 每月的1日1點(diǎn)1分30秒觸發(fā) :'30 1 1 1 * *' // 2016年的1月1日1點(diǎn)1分30秒觸發(fā) :'30 1 1 1 2016 *' // 每周1的1點(diǎn)1分30秒觸發(fā) :'30 1 1 * * 1' // 每分鐘的1-10秒都會觸發(fā),其它通配符依次類推 :'1-10 * * * * *'
調(diào)用定時器:
nodeTimer.scheduleTimer('30 * * * * *',function(err){ if(!err){ console.log('scheduleTimer:' + new Date()); } });
效果:
2、對象文本語法定時器
- second (0-59)
- minute (0-59)
- hour (0-23)
- date (1-31)
- month (0-11)
- year
- dayOfWeek (0-6) Starting with Sunday
//每周一的下午15:03:30觸發(fā),其它組合可以根據(jù)我代碼中的注釋參數(shù)名自由組合 nodeTimer.scheduleTimer({hour: 15, minute: 3, second: 30},function(err){ if(!err){ console.log('scheduleTimer:' + new Date()); } });
效果:
3、基于日期的定時器
var date = new Date(2019, 01, 07, 15, 03, 30); nodeTimer.scheduleTimer(date,function(err){ if(!err){ console.log('scheduleTimer:' + new Date()); } });
4、遞歸規(guī)則定時器
參數(shù)與對象文本語法定時器的參數(shù)類似
var rule = new schedule.RecurrenceRule(); rule.dayOfWeek = [0, new schedule.Range(4, 6)];//每周四,周五,周六執(zhí)行 rule.hour = 15; rule.minute = 0; nodeTimer.scheduleTimer(rule,function(err){ if(!err){ console.log('scheduleTimer:' + new Date()); } });
5、取消定時器
// 取消定時器 // 調(diào)用 定時器對象的cancl()方法即可 nodeTimer.scheduleCancel = () => { // 定時器取消 cancelTimer.cancel(); console.log('定時器成功取消'); }
調(diào)用:
nodeTimer.scheduleCancel()
效果:
三,隊(duì)列
第一步:安裝async
npm install --save async
第二步:封裝方法
queue相當(dāng)于一個加強(qiáng)版的parallel,主要是限制了worker數(shù)量,不再一次性全部執(zhí)行。當(dāng)worker數(shù)量不夠用時,新加入的任務(wù)將會排隊(duì)等候,直到有新的worker可用。
該函數(shù)有多個點(diǎn)可供回調(diào),如worker用完時、無等候任務(wù)時、全部執(zhí)行完時等。
const async = require('async'); /** *隊(duì)列 * @param obj :obj對象 包含執(zhí)行時間 * @param callback :回調(diào)函數(shù) */ const nodeQueue = async.queue(function (obj, callback) { setTimeout(function () { // 需要執(zhí)行的代碼的回調(diào)函數(shù) if(typeof callback==='function'){ callback(); } }, obj.time) }, 1) // worker數(shù)量將用完時,會調(diào)用saturated函數(shù) nodeQueue.saturated = function() { console.log('all workers to be used'); } // 當(dāng)最后一個任務(wù)交給worker執(zhí)行時,會調(diào)用empty函數(shù) nodeQueue.empty = function() { console.log('no more tasks wating'); } // 當(dāng)所有任務(wù)都執(zhí)行完時,會調(diào)用drain函數(shù) nodeQueue.drain = function() { console.log('all tasks have been processed'); } module.exports = nodeQueue;
第三步:調(diào)用方法
const nodeQueue = require('./node_queue.js'); for (let i = 0; i < 10; i++) { nodeQueue.push({ name: 1, time: 2000 }, function (err) { console.log('隊(duì)列執(zhí)行錯誤信息==',err); if(!err){ // 需要執(zhí)行的代碼或函數(shù) console.log('需要執(zhí)行的代碼或函數(shù)第',i+1,'個') } }) };
效果:
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關(guān)文章
NodeJs搭建本地服務(wù)器之使用手機(jī)訪問的實(shí)例講解
今天小編就為大家分享一篇NodeJs搭建本地服務(wù)器之使用手機(jī)訪問的實(shí)例講解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-05-05Node.js實(shí)現(xiàn)解析post請求的方法詳解
這篇文章主要為大家詳細(xì)介紹了Node.js實(shí)現(xiàn)解析post請求方法的相關(guān)知識,文中的示例代碼講解詳細(xì),具有一定的學(xué)習(xí)價值,有需要的小伙伴可以了解下2024-04-04Nodejs?Sequelize手冊學(xué)習(xí)快速入門到應(yīng)用
這篇文章主要為大家介紹了Nodejs?Sequelize手冊學(xué)習(xí)快速入門到應(yīng)用,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-10-10