node.js - 在无状态 Node.js 应用程序中调度函数调用
问题描述
我试图找出一种设计模式,用于在多个实例同时运行的无状态节点后端中调度事件。
用例示例:
- 创建具有发布日期/时间的消息对象并将其保存到数据库
- 可选择更新发布时间或删除对象
- 到达发布时间后,消息内容将发送到第 3 方 API 端点
现在我最好的想法是使用 bee-queue 或 Bull 来排队延迟的工作。它应该能够存储状态并确保作业只执行一次。但是,我觉得它可能会引入单点故障,尤其是在 Redis 上维护状态数月,然后希望队列库的未来版本仍在工作时。
另一种选择是每 n 分钟轮询一次数据库以了解即将发生的事件的服务工作者,但这似乎是多租户 SaaS 的潜在扩展问题。
是否有更强大的设计模式来解决这个问题?
解决方案
不用担心redis坏了。它非常稳定,最终您可以决定冻结该版本。
如果将来有要执行的作业,我建议使用带有磁盘存储的数据库,例如 Mongo 或 Redis。因此,您将在重新启动后幸存下来,您不必重新发明轮子,并且已经拥有一套很好的可扩展性工具。
推荐阅读
- javascript - 计算所需的高度以使缩小的 div 到达底部视口
- arrays - 如何使用带有俄语字母的数组?
- azure - 如果存在分支标记,Azure Devops 会排除作业
- mongoose - 猫鼬:查询,我怎样才能从结果中解析出一个字段?
- c - 如何从 DER 或 PEM 文件中获取字符数组或字节数组中的值?
- google-sheets-formula - Google 表格 - 特定日期的化合物 FV
- flutter - Flutter 主异常超时
- django - 序列化对象字段Django的问题
- sql-server - 播放框架进化脚本错误行号
- c++ - 计算一系列数字中 3 的数量