首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >集群中运行的java应用程序的负载均衡

集群中运行的java应用程序的负载均衡
EN

Stack Overflow用户
提问于 2017-09-27 19:45:26
回答 2查看 308关注 0票数 0

我有多个虚拟机运行项目中的所有模块。用户创建的每个请求都必须由所有模块处理,但只需处理一次。因此,如果VM1接收到请求,则module1可以部分处理该请求,接下来VM1或VM2或群集中的任何其他虚拟机都可以接收并处理module2。诸若此类。

由于每个虚拟机的容量有限,我想使用负载均衡器在各个虚拟机之间分配工作。

有没有负载均衡器(java开源)可以解决这个问题,或者我需要使用几种负载均衡算法(循环调度,加权等)来解决我的需求?

编辑1:

每个模块都是一个java类,它本身是独立的,但需要在其started.Each Vm侦听消息总线之前完成之前的模块。当一条消息出现在总线上时,任何vm都可以拾取它并开始处理它。

EN

回答 2

Stack Overflow用户

发布于 2017-09-27 20:17:54

你可以试试HAProxy (TCP/HTTP loadbalancer ),它是开源的,功能丰富,应用相当广泛。除了好的文档之外,你还可以找到很多可用的信息。

票数 0
EN

Stack Overflow用户

发布于 2017-09-27 20:23:04

根据您试图并行化的问题的确切语义,您可以通过将问题分成一定大小的“工作包”并将它们放在中央队列中来获得好的结果。然后,只要每个VM一完成前一个分组,就从所述队列中轮询一个分组。这就是所谓的自我调度。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/46447046

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档