以为我会把这个告诉任何有类似问题的人。
信息:运行 linux (ubuntu)、x64、最新的 java 版本 (1.7.25)、最新的 tomcat (7.40)。
我在本地设置了两个 apache tomcat,并在两个 tomcat 上设置了相同的 webapp,以测试一些 ehcache 功能并复制了缓存,一切都很好。
一旦我使用第二个 tomcat 实例设置了专用服务器,EhCache 就不会在我的 PC 和服务器之间复制(仍处于测试阶段)。
所有配置都基本相同,当然IP地址不同。由于我没有使用来自 DNS 的服务器和计算机的主机名,因此我将主机名添加到了 pc 和服务器上的 /etc/hosts 文件中——我认为这样就足够了。
经过几个小时的仇恨 - 咬牙切齿 - 我决定删除所有添加到 /etc/hosts 的条目,而是使用我们公司的 DNS 中无聊的主机名 (pc-103-15-87.xxxxx.com和 pc-104-15-87.xxxxx.com )然后一切正常。
在我得到解决方案之前运行“wireshark”,它向我显示两个 ehcache 实例都在聊天,但是 ip 地址“127.0.0.1”(可能用作某种回调地址)在通信中被“提及”两个 ehcache 实例。
这导致我删除了我在 /etc/hosts 中添加的所有内容,并使用了 DNS 可解析名称。现在,“wireshark”中的所有内容都向我显示了所有正确的 IP 地址,而且一切都是黄金。
希望这会帮助任何有类似问题的人。
XML:
对等方的信息:
<cacheManagerPeerProviderFactory
class="net.sf.ehcache.distribution.RMICacheManagerPeerProviderFactory"
properties="peerDiscovery=manual,
rmiUrls=//pc-103-15-87.xxxxx.com:40002/persons|//pc-103-15-87.xxxxx.com:40002/wordCache"/>
和此服务器上的侦听器:
<cacheManagerPeerListenerFactory
class="net.sf.ehcache.distribution.RMICacheManagerPeerListenerFactory"
properties="hostname=pc-104-15-87.xxxxx.com, port=40002, socketTimeoutMillis=3000"/>