es的replica&shard的机制

Posted siye1989

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了es的replica&shard的机制相关的知识,希望对你有一定的参考价值。

1、shard&replica机制再次梳理

(1)index包含多个shard
(2)每个shard都是一个最小工作单元,承载部分数据,lucene实例,完整的建立索引和处理请求的能力
(3)增减节点时,shard会自动在nodes中负载均衡
(4)primary shard和replica shard,每个document肯定只存在于某一个primary shard以及其对应的replica shard中,不可能存在于多个primary shard
(5)replica shard是primary shard的副本,负责容错,以及承担读请求负载
(6)primary shard的数量在创建索引的时候就固定了,replica shard的数量可以随时修改
(7)primary shard的默认数量是5,replica默认是1,默认有10个shard,5个primary shard,5个replica shard
(8)primary shard不能和自己的replica shard放在同一个节点上(否则节点宕机,primary shard和副本都丢失,起不到容错的作用),但是可以和其他primary shard的replica shard放在同一个节点上

 

技术图片

------------------------------------------------------------------------------------------------

2、图解单node环境下创建index是什么样子的

(1)单node环境下,创建一个index,有3个primary shard,3个replica shard
(2)集群status是yellow
(3)这个时候,只会将3个primary shard分配到仅有的一个node上去,另外3个replica shard是无法分配的
(4)集群可以正常工作,但是一旦出现节点宕机,数据全部丢失,而且集群不可用,无法承接任何请求

 

技术图片

 

PUT /test_index

"settings" :
"number_of_shards" : 3,
"number_of_replicas" : 1

以上是关于es的replica&shard的机制的主要内容,如果未能解决你的问题,请参考以下文章

ES容错机制:master选举,replica容错,数据恢复

es 容错机制

Elasticsearch的集群容错机制以及选举机制

ES-primary shard 和 replica shard

Elasticsearch 顶尖高手—_shard&replica机制再次梳理以及单node环境中创建index图解

ElasticSearch容错机制