zoukankan      html  css  js  c++  java
  • discovery.zen.minimum_master_nodes对集群的稳定性至关重要,防止脑裂的出现。

    discovery.zen.minimum_master_nodes对集群的稳定性至关重要,防止脑裂的出现。

    脑裂:

    如果网络的故障导致一个集群被划分成两片,每片都有多个node,以及一个master。因为master是维护集群状态,以及shard的分配。如果出现了两个master,可能导致数据破损。

    discovery.zen.minimum_master_nodes的作用是只有足够的master候选节点时,才可以选举出一个master。该参数必须设置为集群中master候选节点的quorum数量。

    quorum的算法=master候选节点数量/2+1

    举例:

    1、如果有10个节点,都是data node,也是master的候选节点。则quorum=10/2+1=6

    2、如果有3个master候选节点,100个数据节点。则quorum=3/2+1=2   

    3、如果有2个节点,都是data node,也是master的候选节点。则quorum=2/2+1=2(有问题)

    如果其中一个节点挂了,那么master的候选节点只有一个,无法满足quorum数量。即无法选举出master。此时只能将quorum设置成1,但是设置为1有可能出现脑裂。

    总结:一般es集群的节点至少要有3个,quorum设置为2

    使用例2的场景说明quorum是如何防止脑裂

    假设集群中3个节点有一个节点与其他节点无法通信,

    1、如果master是单独的节点,另外2个节点是master候选节点。那么此时单独的master节点因为没有指定数量的候选master node在自己当前所在的集群里。因此会取消当前的master角色,尝试重新选举(无法选举成功)

    另外一个网络区域内的node因为无法连接到master,就会发起重新选举,有两个候选节点,满足quorum,成功选举出一个master。

    2、如果master和一个node在一个网络区域(A),另一个node单独在一个网络区域(B)。

    B区域只有一个node,因为连不上master,会尝试发起选举,但不满足quorum,无法选举

    A区域master继续工作,当前网络也满足quorum,不发起选举。

    discovery.zen.minimum_master_nodes除了在配置文件设置,也可以动态设置

    PUT /_cluster/settings
    {
       "persistent":{
          "discovery.zen.minimum_master_nodes":2
       }
    }

  • 相关阅读:
    Modified Mms.apkDiscontinued till I have free time
    文件管理器 Root Explorer v2.9.4 零售完全版
    QQREADEREFF8B4DFC3E8C03B
    CyanogenMod5 近乎完美的2.1ROM for G1 来了 感谢 cyanogen大神~~
    CyanogenMod5 Would you like a pony? (EXPERIMENTAL) [05/08 v5.0.7test3]
    商业周刊:摩托罗拉下注Android 不成功便成仁
    Cyanogen Updater 5.0 IS HERE!!!
    22个开源的PHP框架
    LotusPhp
    10 个免费超棒的编程用等宽字体
  • 原文地址:https://www.cnblogs.com/cheyunhua/p/14705409.html
Copyright © 2011-2022 走看看