我有一个有3个节点的集群(在不同的机器中),我有一个“业务逻辑”,在启动时使用分布式锁。
有时,当延迟较大时,每个节点都会使用E 211E 112成功E 213获取独占的锁,因为集群尚未“启动”,因此每个节点都看不到另一个节点。
随后,节点相互看到,集群被正确地配置为3个节点。我知道有一个"MemberShipListener“来捕获”成员“添加的事件,这样我就可以再次执行”业务逻辑“,但是我想知道是否有一种方法可以确保集群启动何时正确完成,以便等到集群开始运行时才执行”业务逻辑“。
我尝试使用hazelcast.initial.wait.seconds,但是配置正确的秒并不是确定性的,我不知道这是否也延迟了成员的联接操作。
发布于 2016-02-20 12:24:35
Afaik,哈泽尔卡斯特没有这样的事情。由于集群是动态的,节点可以随时离开,因此群集永远不会“完成”或“不完整”。
但是,你可以:
hazelcast.initial.min.cluster.size定义开始时hazelcast等待的最小成员数PartitionService检查集群是否安全,或者是否存在挂起的迁移。https://stackoverflow.com/questions/35520423
复制相似问题