第九篇 elasticsearch的document数据路由原理

1. document是怎么路由到shard上的?

路由算法:shard = hash(routing) % number_of_primary_shards
假如一个index有3个primary shard,P0,P1,P2;
在每次增删改查一个document的时候都会带过来一个routing number,默认就是这个document的_id(可能是手动指定,也可以自动生成);
elasticsearch会将这个routing值传入到hash函数中,产生一个routing值的hash值,假定hash(routing) = 21,然后将hash函数产出的值对这个index的primary shard的数量求余数,21%3=0,这就决定了document放在P0上;

决定一个document在哪个shard上,最重要的一个值就是routing值,默认是_id,也可以手动指定,相同的routing值,每次过来,从hash函数中,产出的hash值一定是相同的

猜你喜欢

转载自blog.csdn.net/r_p_j/article/details/78392490
今日推荐