zoukankan      html  css  js  c++  java
  • (41)ElasticSearch写一致性原理和quorum机制

      1、任何一个增删改操作都可以跟上一个参数consistency

    PUT /myindex/article/4?consistency=one
    {
      "post_date":"2018-05-18",
      "title":"Java",
      "content":"java is the best language",
      "author_id":666
    }

      该参数指定的值有3个:

      one:(primary shard)只要有一个primary shard是活跃的就可以执行

      all:(all shard)所有的primary shard和replica shard都是活跃的才能执行

      qurom:(default)默认值,大部分shard都是活跃的才能执行(例如共有6个shard,至少有3个shard是活跃的才能执行写操作 )

      2、qurom怎样计算出大部分

      公式:int((primary+number_of_replica)/2)+1,其中number_of_replica是每一个primary的副本,不是整个的。

      例如:3个primary shard,1个replica,总共6个shard

      int((3+1)/2)+1=3,至少3个shard是活跃的,才能进行写操作。

      3、可能出现shard不能分配齐全的情况

      比如:1个primary shard,1个replica

      int((1+1)/2)+1=2,但是如果只有一个节点,因为primary shard和replica shard不能在同一个节点上,所以仍然不能执行写操作。

      再比如:1个primary shard,3个replica,2个节点

      int((1+3)/2)+1=3,但是只有两个节点,所以仍然不能执行写操作。注意:一个primary的相同副本不能在同一个节点上。

      4、es默认等待机制

      当活跃的shard的个数没有达到要求时,es默认会等待一分钟,如果在等待的期间活跃的shard的个数没有增加,则显示timeout,该值可以指定。

    put /index/type/id?timeout=60s
  • 相关阅读:
    Vue CLI Plugin Electron Builder 打包出现空白问题
    git 不小心提交大文件出错问题
    electron-vue创建项目
    electron ico文件问题
    多尺寸ico图标制作工具GIMP
    ps ico图标制作插件
    fluent-ffmpeg
    CopyWebpackPlugin 拷贝某个文件夹的文件到某个文件夹
    electron-vue 目录有中文打包报错问题
    js 给控件新增class
  • 原文地址:https://www.cnblogs.com/javasl/p/12652096.html
Copyright © 2011-2022 走看看