ElasticSearch47:初识搜索引擎_搜索相关参数梳理以及bouncing results问题解决方法

1.preference
决定了哪些shard会被用来执行搜索操作
_primary(只搜索primary shard),  _primary_first(primary shard优先), _local, _only_node:xyz, _prefer_node:xyz, _shards:2,3
bouncing results问题:两个document排序,field值相同,不同的shard上,可能排序不同,每次请求轮训到不同的replica shard上,每次页面上看到的搜索结果的排序都不一样,这就是bouncing result,也就是跳跃的结果。
搜索的时候,是轮训将搜索请求发送到每一个replica shard(primary shard),但是在不同的shard上,可能document的排序不同
解决方案是将preference设置为一个字符串,比如说user_id,让每个user每次搜索的时候,都使用同一个replica shard去执行,就不会看到bouncing results了


2.timeout:主要是限定在一定时间内,将部分获取到的数据直接返回,避免查询耗时过长
3.routing:document文档路由,默认_id路由。可以指定路由:routing=user_id,这样的话可以让同一个user对应的数据到同一个shard上去
4.search_type:默认query_then_fetch
如果设置成dfs_query_then_fetch,可以提升revelance sort的精准度
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值