我有多个虚拟机运行项目中的所有模块。用户创建的每个请求都必须由所有模块处理,但只需处理一次。因此,如果VM1接收到请求,则module1可以部分处理该请求,接下来VM1或VM2或群集中的任何其他虚拟机都可以接收并处理module2。诸若此类。
由于每个虚拟机的容量有限,我想使用负载均衡器在各个虚拟机之间分配工作。
有没有负载均衡器(java开源)可以解决这个问题,或者我需要使用几种负载均衡算法(循环调度,加权等)来解决我的需求?
编辑1:
每个模块都是一个java类,它本身是独立的,但需要在其started.Each Vm侦听消息总线之前完成之前的模块。当一条消息出现在总线上时,任何vm都可以拾取它并开始处理它。
发布于 2017-09-27 20:17:54
你可以试试HAProxy (TCP/HTTP loadbalancer ),它是开源的,功能丰富,应用相当广泛。除了好的文档之外,你还可以找到很多可用的信息。
发布于 2017-09-27 20:23:04
根据您试图并行化的问题的确切语义,您可以通过将问题分成一定大小的“工作包”并将它们放在中央队列中来获得好的结果。然后,只要每个VM一完成前一个分组,就从所述队列中轮询一个分组。这就是所谓的自我调度。
https://stackoverflow.com/questions/46447046
复制相似问题