0
点赞
收藏
分享

微信扫一扫

Elasticsearch 路由计算


作为一个没有额外依赖的简单的分布式方案,ES 在这个问题上同样选择了一个非常简洁的处理方式,对任一条数据计算其对应分片的方式如下:

shard = hash(routing) % number_of_primary_shards

每个数据都有一个 routing 参数,默认情况下,就使用其 _id 值。将其 _id 值计算哈希后,对索引的主分片数取余,就是数据实际应该存储到的分片 ID。

由于取余这个计算,完全依赖于分母,所以导致 ES 索引有一个限制,索引的主分片数,不可以随意修改。因为一旦主分片数不一样,所以数据的存储位置计算结果都会发生改变,索引数据就完全不可读了。

本文整理自:​​《elk-stack-guide-cn》​​

个人微信公众号:

Elasticsearch 路由计算_elasticsearch

作者:jiankunking


举报

相关推荐

0 条评论