Apache Ignite 2.7.0 在 Grid Future Adapter.get0() 中花费了大量时间

Apache Ignite 2.7.0 a loy of time spent in GridFutureAdapter.get0()

我正在使用具有以下设置的 Apache Ignite: 2 台服务器组成一个集群,其中有几个配置为 REPLICATED 模式的 Ignite 缓存。还有 10 个 Java 进程作为客户端连接到 Apache Ignite 集群并从这些缓存中获取数据。

在使用 VisualVM 分析客户端 JVM 时,我发现客户端将近一半的时间都花在了以下行的阻塞上

java.lang.Thread.State: WAITING (parking)
    at sun.misc.Unsafe.park(Native Method)
    at java.util.concurrent.locks.LockSupport.park(LockSupport.java:304)
    at org.apache.ignite.internal.util.future.GridFutureAdapter.get0(GridFutureAdapter.java:178)
    at org.apache.ignite.internal.util.future.GridFutureAdapter.get(GridFutureAdapter.java:141)
    at org.apache.ignite.internal.processors.cache.GridCacheAdapter.get0(GridCacheAdapter.java:4723)
    at org.apache.ignite.internal.processors.cache.GridCacheAdapter.get(GridCacheAdapter.java:4697)
    at org.apache.ignite.internal.processors.cache.GridCacheAdapter.get(GridCacheAdapter.java:1415)
    at org.apache.ignite.internal.processors.cache.IgniteCacheProxyImpl.get(IgniteCacheProxyImpl.java:928)
    at org.apache.ignite.internal.processors.cache.GatewayProtectedCacheProxy.get(GatewayProtectedCacheProxy.java:640)

我知道可能需要锁定才能正确处理给定缓存中给定键的 get()/put()。但在我的应用程序中,我首先将所有需要的参考数据加载到 Ignite 缓存中,然后客户端 JVM 仅从缓存中获取数据。这种行为(在 cache.get() 期间花费大量时间等待)是预期的吗?有没有什么方法可以不带锁地调用 cache.get() ,因为在我的情况下,初始加载后缓存中不会有更新?

通常这是意料之中的,因为您至少需要等待网络将缓存值传送到您的客户端节点。 REPLICATED 缓存模式意味着每个密钥都存在于每个服务器节点上,但仍需要一些时间将其拉到客户端节点。