1、preference
决定了哪些shard
会被用来执行搜索操作_primary
, _primary_first
, _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
default:query_then_fetch
dfs_query_then_fetch,可以提升`revelance sort`精准度