问题描述
我想在我的服务器中有一个函数,用户可以从 API 路由创建一个“jobScan”,例如“/create-scan-job”,它基本上在创建一个 scanJob 时它会被保存在 mongodb 数据库中带有“scanDueDate”,它将用于将一项任务排队,该任务将在用户输入的 DueDate 上将扫描状态更改为“已完成”。
我怎样才能构建这样的东西?我在将数据保存在数据库中没有问题,但是我如何“排队”它以在作为输入给出的 DueDate 上触发?
解决方法
- Agenda 将作业保存在 MongoDB 数据库中
- Bull 在 Redis 中节省了工作。
两者都支持 cron 作业。
,Agenda 正在使用 MongoDB 进行队列调度,但它有点不稳定,as you may see on the issues page。您也可以使用 Bree,但它确实将作业队列存储在内存中。
至于Bull或BullMQ,这里已经通知了,它确实使用Redis作为队列存储。但它的文档描述似乎并不完整。我记得,Redis 不支持开箱即用的 Windows。因此,如果您想在本地运行它,我强烈建议您使用 the Redis Docker image。
另外,不要忘记用于任务队列的 GUI。您可以使用:
- Agendash,(带有 Agenda)允许从界面手动创建作业。
- Bull-board(使用 Bull 或 BullMQ),仅提供有关任务的只读数据。