koa 定时任务

发布于 2022-09-11 19:44:44 字数 623 浏览 12 评论 0

定时任务用了node-scheduler,任务写在/scheduler/index.js
我想知道我在koaapp.js里面,
是像1一样,直接执行任务
还是像2一样,开个子进程执行任务
(还有一个问题,我要是使用cluster集群跑多核,怎么避免多个koa进程执行多次定时任务)

// app.js
const Koa = require('koa')
const app = new Koa()
const scheduler = require('./scheduler')
const cp = require('child_process')

// 1
scheduler()

// 2
cp.execFile('node', ['./scheduler/index.js'], function (err, stdout, stderr) {
  if (err) console.error(err)
})

app.listen(3000, () => {
  console.log('koa serve run http://localhost:3000')
})

=======

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

演多会厌 2022-09-18 19:44:44

我觉得定时任务是单独的服务,和普通的接口业务服务分开,用1就好,守护进程用别的库。
如果集群,得有个存储中心(比如redis的blocking list)做阻塞队列

Client publish:   LPUSH xxx
Client subscribe:   BLPOP xxx

另:定时任务最好有日志

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文