這篇文章跟大家介紹一下Node定時任務的實作方法,希望對大家有幫助!
目前我們遇到了這樣一個需求,每個使用者都可以自訂定時推送,定時任務的時間配置由使用者自己配置,隨時修改,而不是傳統的由伺服器設定好時間跑定時任務。 【推薦學習:《nodejs 教學》】
如果是已知定時任務循環週期,那麼Linux Crontab 定時任務即可實現。在node中也已經有相對成熟的方案。以下將我自己了解到的Node定時任務方案方案做一個介紹。
egg是阿里旗下的Node企業級應用框架,它提供了一套機制給開發者優雅的編寫定時任務,詳細參考官方文件:https://eggjs.org/zh-cn/basics/schedule.html ,這裡不對具體用法做詳細闡述,只簡單講一下它的配置用法。
1.靜態定時任務,即定時週期,處理邏輯寫死。
2.動態配置定時任務,這種相對來說靈活一點,開發者可以透過設定檔控制定時任務週期。
3.透過程式碼手動觸發定時任務,我們可以根據一些邏輯判斷是否觸發定時任務。
從上述三點看,egg提供的定時任務不能滿足我們需要用戶自行配置定時週期的需求,所以只能尋求其他方案,透過查詢資料我們發現了node-schedule的函式庫也提供了定時任務的功能。
在瀏覽了node-schudule的文件https://www.npmjs.com/package/node-schedule之後,他的用法如下:
const schedule = require('node-schedule'); const job = schedule.scheduleJob('42 * * * *', function(){ console.log('The answer to life, the universe, and everything!'); });
是的,他支持自訂定時週期,可以滿足我們的需求,可以作為我們的選擇,Nice!
#繼續瀏覽其他開發者的使用文章,發現有一個node-schedule的相關問題記錄,簡要說就是定時器在預定時間執行了2次,具體問題見原文:https://cnodejs.org/topic/5b58414b8d66b90b2b7384a7 。這是一個低機率的問題,我們沒有去做驗證,因為我們的需求,及時定時器執行兩次,對我們的結果並沒有影響,所以這不是阻礙我們使用它的障礙,有興趣的同學可以去測測bug。
最後這裡是對我們自己專案定時定時任務解決方案的總結,不感興趣的同學可略過。
我們的後端就是用的egg框架,所以最後我們的解決方案是在agent進程中加了node-schdule的計時器,用戶的計時器都會同步的agent進程中執行,目前我們的用戶量不大,暫時只想到了這種解決方式,後續起量後可能會分散部署後台。
這會是一個問題,量大的話單進程跑也會是一個問題,而egg本身不建議在agent進程中做太多業務相關的東西。還有個比較重要的是agent是輔助進程,一些work的公共工作實在agent中完成的,agent發生未捕獲的錯誤不會退出重啟,所以容錯處理必須要做,而且要做好。
更多程式相關知識,請造訪:程式設計影片! !
以上是淺談Nodejs中要怎麼做定時任務的詳細內容。更多資訊請關注PHP中文網其他相關文章!