9_ElasticSearch 多shard场景下relevance score不准确

9_ElasticSearch 多shard场景下relevance score不准确

更多干货

图解

如果你的一个index有多个shard的话,可能搜索结果会不准确

image

如何解决该问题

1、生产环境下,数据量大,尽可能实现均匀分配

  • 数据量很大的话,其实一般情况下,在概率学的背景下,es都是在多个shard中均匀路由数据的,路由的时候根据_id,负载均衡
  • 比如说有10个document,title都包含java,一共有5个shard,那么在概率学的背景下,如果负载均衡的话,其实每个shard都应该有2个doc,title包含java
  • 如果说数据分布均匀的话,其实就没有刚才说的那个问题了

2、测试环境下

  • 将索引的primary shard设置为1个,number_of_shards=1,index settings
  • 如果说只有一个shard,那么当然,所有的document都在这个shard里面,就没有这个问题了

3、测试环境下

  • 搜索附带search_type=dfs_query_then_fetch参数,会将local IDF取出来计算global IDF
  • 计算一个doc的相关度分数的时候,就会将所有shard对的local IDF计算一下,获取出来,在本地进行global IDF分数的计算,会将所有shard的doc作为上下文来进行计算,也能确保准确性。
  • 但是production生产环境下,不推荐这个参数,因为性能很差。


相关文章


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值