首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Hazelcast:如何确保集群启动完成

Hazelcast:如何确保集群启动完成
EN

Stack Overflow用户
提问于 2016-02-20 07:30:03
回答 1查看 1.4K关注 0票数 4

我有一个有3个节点的集群(在不同的机器中),我有一个“业务逻辑”,在启动时使用分布式锁

有时,当延迟较大时,每个节点都会使用E 211E 112成功E 213获取独占的锁,因为集群尚未“启动”,因此每个节点都看不到另一个节点。

随后,节点相互看到,集群被正确地配置为3个节点。我知道有一个"MemberShipListener“来捕获”成员“添加的事件,这样我就可以再次执行”业务逻辑“,但是我想知道是否有一种方法可以确保集群启动何时正确完成,以便等到集群开始运行时才执行”业务逻辑“。

我尝试使用hazelcast.initial.wait.seconds,但是配置正确的秒并不是确定性的,我不知道这是否也延迟了成员的联接操作。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-02-20 12:24:35

Afaik,哈泽尔卡斯特没有这样的事情。由于集群是动态的,节点可以随时离开,因此群集永远不会“完成”或“不完整”。

但是,你可以:

  1. 如您所述,配置初始等待,以帮助处理初始延迟。
  2. 使用hazelcast.initial.min.cluster.size定义开始时hazelcast等待的最小成员数
  3. 定义最小仲裁:集群的最小节点数被认为是可使用/健康的(参见群集法定人数)
  4. 使用PartitionService检查集群是否安全,或者是否存在挂起的迁移。
票数 7
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/35520423

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档