十条优化带你的ES飞起来
1、bool 查询的 filter 筛选
众所周知,ES中filter是不参与相关性评分的,所以查询子句可以被系统进行缓存,性能要高于普通的query查询。
bool查询中支持4种子句,分别是filter、must、must_not、should,其中filter和must_not属于过滤器,过滤器查询先于其它查询执行。
另外在function_score、constant_score中也可以使用filter子句进行查询缓存。
2、设置indices.memory.index_buffer_size
indices.memory.index_buffer_size默认是jvm大小的10% ,将该值调大到20%,经常查询的索引分片数据会被缓存,当该值足够大时缓存的数据就会更多,查询就会更快。
3、segment merge
增加 Index Refresh 间隔,目的是减少 Segment Merge 的次数,建议设置为30s-90s
定期将只读或写少的索引进行segment合并,降低segment数量对搜索性能提升帮组很大,合并过程中将only_expunge_deletes设置为true意思是将标记为删除的数据清除掉。
4、SearchType
SearchType默认是QUERY_THEN_FETCH,可在查询时指定为dfs_query_then_fetch,这样协调节点只需要请求一次数据节点就可以完成请求处理了。
5、预排序 IndexSorting
ES 6.x之后新增预排序功能,即索引在创建之前可以指定数据写入后的排序方式,当query时指定的排序方式和预排序逻辑一致时将能够很快获得排