es创建索引数量多了好还是少了好_ES优化看这10条就够了

本文分享了提高Elasticsearch性能的十条实用技巧,包括利用filter查询提升性能,调整indices.memory.index_buffer_size以优化缓存,合理设置Index Refresh间隔,选择合适的SearchType,利用预排序功能,优化磁盘使用,设置独立聚合节点,控制查询中断,调整聚合方式,以及实现索引冷热分离。这些措施能显著提升ES查询速度和整体效率。
摘要由CSDN通过智能技术生成

十条优化带你的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时指定的排序方式和预排序逻辑一致时将能够很快获得排

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值