我知道JBoss 集群Default 的设定就是UDP(JGroups),但在实际环境中的网络环境时常不允许UDP,在这种情况下,我们就需要使用TCP。
JBoss 7/WildFly 中负责集群的主要模块是JGroups 跟 Infinispan,而控制Cluster里面的node跟集群中其他节点通信沟通的就是JGroups,所以,不管你今天用的是Standalone或是domain,只要找到jgroups的subsystem修改,就OK了,如下:
- 将default-stack 由 udp 改为 tcp:
<subsystem default-stack="udp" xmlns="urn:jboss:domain:jgroups:1.1">
.....
</subsystem>
改为 tcp
<subsystem default-stack="tcp" xmlns="urn:jboss:domain:jgroups:1.1">
.....
</subsystem>
- 将原先使用MPING 的设定移除
<subsystem default-stack="tcp" xmlns="urn:jboss:domain:jgroups:1.1">
<