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