我正在设计一个系统,其中有一个主要的对象流,并且有多个从该对象产生一些结果的工作人员。最后,有一些特殊/独特的工作人员(就图论而言,有点像“接收器”),它获取所有结果,并将它们处理为写入某个数据库的最终对象。
一个工人可能依赖于其他一些工人的结果(因此,等待他们的结果)
现在,我面临几个问题:
- 可能是一名工人比另一名工人慢得多。你怎么处理那件事呢?添加更多较慢类型的工人(=缩放)?(也许是动态的)
- 假设 W_B 依赖于 W_A。如果 W_B 由于某种原因关闭,则流程将停止,系统将停止工作。所以我希望系统以某种方式绕过这个工人。
- 此外,最终工作人员如何决定何时对结果集进行操作?假设它有 A 和 B 的结果,但缺少 C 的结果。可能是 C 已关闭,或者目前非常慢。它如何做出决定?
值得一提的是,它不是一个实时应用程序,而是一个离线处理系统(即您可以访问数据库并更改记录),但同时它必须以“高速度”处理相对大量的对象”。
关于技术,
我正在使用 Java 开发系统,但我不受特定技术的限制。
如果您能帮助我进行系统的总体设计,我会很高兴。
非常感谢!