React 前端导航

Node定时任务怎么做

Node定时任务怎么做

背景

目前我们遇到了这样一个需求,每个用户都可以自定义定时推送,定时任务的时间配置由用户自己配置,随时修改,而不是传统的由服务器设定好时间跑定时任务。

如果是已知定时任务循环周期,那么Linux Crontab 定时任务即可实现。在node中也已经有相对成熟的方案。下面将我自己了解到的Node定时任务方案方案做一个介绍。

egg框架提供的schduler定时任务

egg是阿里旗下的Node企业级应用框架,它提供了一套机制给开发者优雅的编写定时任务,详细参考官方文档:https://eggjs.org/zh-cn/basics/schedule.html ,这里不对具体用法做详细阐述,只简单讲一下它的配置用法。

1.静态定时任务,即定时周期,处理逻辑写死。

2.动态配置定时任务,这种相对来说灵活一点,开发者可以通过配置文件控制定时任务周期。

3.通过代码手动触发定时任务,我们可以根据一些逻辑判断是否触发定时任务。

从上述三点看,egg提供的定时任务不能满足我们需要用户自行配置定时周期的需求,所以只能寻求其他方案,通过查询资料我们发现了node-schedule的库也提供了定时任务的功能。

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发生未捕获的错误不会退出重启,所以容错处理必须要做,而且要做好。

如果你有更好的方案,欢迎 留言 告诉我们。

声明:本网站发布的内容(图片、视频和文字)以原创、转载和分享网络内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。邮箱:farmerlzj@163.com。 本站原创内容未经允许不得转载,或转载时需注明出处: 内容转载自: React前端网:https://qianduan.shop/blogs/detail/11

#node#egg#定时任务#node-schedule

相关推荐

NodeJs发起https请求报错:certificate has expired

在egg中发起https请求时提示证书过期错误(certificate has expired)问题记录

node事件循环(Event loop)

本文将简述浏览器中的js事件循环机制,帮助我们理解Node中代码是如何运行的。Javascript的一大特点是单线程,也就意味着同一时间他只能做一件事。那Node是如何支撑高并发呢?