我对Apache Ignite很新,所以请温和。我的问题很简单。 如果我有使用Apache Ignite的复制缓存。我写这个缓存键123.我的集群有10个节点。Apache Ignite复制缓存竞争条件?
第一个问题是:
是否复制缓存意味着之前的“放”呼回来钥匙123必须写入所有10个节点?或者电话立即回来,复制是在幕后完成的?
第二个问题是: 假设键123写在节点1上。它现在被复制到所有其他节点。然而,几微秒后,节点2尝试写入具有不同值的密钥123。我现在有比赛条件吗?或者Ignite以某种方式处理这种情况,节点2尝试写入密钥123的尝试不会发生,直到节点1的“put”跨所有节点复制?
对于某些上下文,我试图构建的是跨API应用程序集群的重复数据删除系统。我希望能够创建我的API请求的散列(只有使请求唯一的值)并将其写入Ignite Cache。只有当缓存中尚未包含唯一散列(可能由不同的API实例创建)时,API请求才会继续。当然,高速缓存将有一个驱逐策略,在几秒钟后驱逐这些高速缓存密钥,因为它们不再需要。