如何在公共 IP 中设置不同的集群
How to setup different clusters in common IP
我有许多 IP 地址为 10.4 的 wildfly-8.2 节点。0.X。我需要将它们分为 2 个不同的集群。不幸的是,我收到了来自未包含在集群中的节点的消息。每个集群接收来自所有节点的消息,因为它们都低于 10.4.0。这是我在 Apache 中的 mod_cluster 配置:
# MOD_CLUSTER_ADDS
<IfModule manager_module>
Listen 10.4.0.1:10001
ManagerBalancerName testbalancer
<VirtualHost 10.4.0.1:10001>
<Location />
Order deny,allow
Deny from all
Allow from 10.4.0.
</Location>
KeepAliveTimeout 300
MaxKeepAliveRequests 0
#ServerAdvertise on http://10.4.0.1:10001
AdvertiseFrequency 5
#AdvertiseSecurityKey secret
#AdvertiseGroup 224.0.1.105:23364
EnableMCPMReceive
<Location /mod_cluster_manager>
SetHandler mod_cluster-manager
Order deny,allow
Deny from all
Allow from 10.4.0
</Location>
我认为这可能是在域 mode 中广泛使用的好方案,这样您就可以配置多个服务器组(子集群)并使用域控制器集中管理它们。此处提供了详细的教程:
http://blog.akquinet.de/2012/07/19/scalable-ha-clustering-with-jboss-as-7-eap-6/
本教程在 mod_cluster 上将多个服务器组拆分为多个负载均衡器组。
要为 mod_cluster 将各个节点配置到不同的负载均衡器组(我自己还没有尝试过!),您可以使用 mod-cluster-config 中的 lbgroup 参数:
<subsystem xmlns="urn:jboss:domain:modcluster:1.1">
<mod-cluster-config advertise-socket="modcluster"
balancer="myBalancer" load-balancing-group="myLBGroup"
connector="ajp">
<dynamic-load-provider>
<load-metric type="busyness"/>
</dynamic-load-provider>
</mod-cluster-config>
</subsystem>
参考:https://developer.jboss.org/thread/203907
要真正将野蝇实例分离到单独的集群中是另一回事。曾经有 属性 "jboss.partition.name" 但这已被为子网内的集群分区定义唯一的多播 address/port 组合所取代。
https://developer.jboss.org/thread/177877
因此假设您使用 udp 作为 jgroups 堆栈,您可以使用“-u”命令行参数更改多播地址:
另一种配置 mod_cluster 的方法可能是禁用广告(节点和 mod_cluster)并在 standalone.xml:
中使用静态配置
<mod-cluster-config proxy-list="10.0.1.2:6667"/>
这样,节点将不再做广告,并且分配给不同 mod_cluster apache 代理的任务将是静态的。
我有许多 IP 地址为 10.4 的 wildfly-8.2 节点。0.X。我需要将它们分为 2 个不同的集群。不幸的是,我收到了来自未包含在集群中的节点的消息。每个集群接收来自所有节点的消息,因为它们都低于 10.4.0。这是我在 Apache 中的 mod_cluster 配置:
# MOD_CLUSTER_ADDS
<IfModule manager_module>
Listen 10.4.0.1:10001
ManagerBalancerName testbalancer
<VirtualHost 10.4.0.1:10001>
<Location />
Order deny,allow
Deny from all
Allow from 10.4.0.
</Location>
KeepAliveTimeout 300
MaxKeepAliveRequests 0
#ServerAdvertise on http://10.4.0.1:10001
AdvertiseFrequency 5
#AdvertiseSecurityKey secret
#AdvertiseGroup 224.0.1.105:23364
EnableMCPMReceive
<Location /mod_cluster_manager>
SetHandler mod_cluster-manager
Order deny,allow
Deny from all
Allow from 10.4.0
</Location>
我认为这可能是在域 mode 中广泛使用的好方案,这样您就可以配置多个服务器组(子集群)并使用域控制器集中管理它们。此处提供了详细的教程: http://blog.akquinet.de/2012/07/19/scalable-ha-clustering-with-jboss-as-7-eap-6/
本教程在 mod_cluster 上将多个服务器组拆分为多个负载均衡器组。
要为 mod_cluster 将各个节点配置到不同的负载均衡器组(我自己还没有尝试过!),您可以使用 mod-cluster-config 中的 lbgroup 参数:
<subsystem xmlns="urn:jboss:domain:modcluster:1.1">
<mod-cluster-config advertise-socket="modcluster"
balancer="myBalancer" load-balancing-group="myLBGroup"
connector="ajp">
<dynamic-load-provider>
<load-metric type="busyness"/>
</dynamic-load-provider>
</mod-cluster-config>
</subsystem>
参考:https://developer.jboss.org/thread/203907
要真正将野蝇实例分离到单独的集群中是另一回事。曾经有 属性 "jboss.partition.name" 但这已被为子网内的集群分区定义唯一的多播 address/port 组合所取代。
https://developer.jboss.org/thread/177877
因此假设您使用 udp 作为 jgroups 堆栈,您可以使用“-u”命令行参数更改多播地址:
另一种配置 mod_cluster 的方法可能是禁用广告(节点和 mod_cluster)并在 standalone.xml:
中使用静态配置<mod-cluster-config proxy-list="10.0.1.2:6667"/>
这样,节点将不再做广告,并且分配给不同 mod_cluster apache 代理的任务将是静态的。