ES运维(五)聚合分析流程及精准度

二龙3年前技术文章1680

1、 概述

ES是一个近实时的搜索引擎,提供近实时海量数据的聚合分析功能,但这个海量数据聚合分析是会损失一定的精准度来满足实时性能需要的。

 

2、 分布式系统的近似统计算法

如下图,在分布式数据分析平台,当同时考虑到数据量,分析精准度及分析实时性的话,最多只能满足其中的两点:

001.png

3、 聚合分析的执行流程

aMin最小值聚合(可准确返回)

002.png

如上图,是对一个索引做Min值聚合,数据分布在三个节点的三个分片上,Coordinating节点接收到请求后就会同时到这三个分片上找到每个分片的最小值,然后在Coordinating节点对返回的三个值再次求最小值。此时聚合是精准的。

bTerms聚合分析(不一定准确)

003.png

如上图,此次取索引top3,与a流程相同,在每个分配上同时取到top3,然后汇总再次取top3,但此次聚合分析结果不一定精确。c案例及可说明此问题。

cTerms聚合不准确案例

004.png

如上图,此次top3聚合由于在每个分配只取top3,导致在第二次汇总分析时结论不准确(非全局top3

Terms Aggregation的返回值

Terms Aggregation 的返回中有两个特殊的数值

doc_count_error_upper_bound:被遗漏的 term 分桶,包含的文档,有可能的最大值

sum_other_doc_count: 处理返回结果 bucket terms 以外,其他 terms 的文档总数(总数 - 返回的总数)

 

4、 聚合不精确问题分析与解决

解决Terms不准的问题:

        不准的原因:Terms 聚合分析不准的原因,数据分散在多个分片上,Coordinating Node 无法获取数据全貌

解决方案 1:当数据量不大时,设置 Primary Shard 1;实现准确性

解决方案 2:在分布式数据上,设置 shard_size 参数,提高精确度(每次从 Shard 上额外多获取数据,提升准确率)

相关文章

dolphinscheduler部署-FAQ

dolphinscheduler部署-FAQ

如果是cdh集群会遇到一个问题5678端口被占用这是因为cdh的agent用了5678那我们改下配置文件文件:/opt/apache-dolphinscheduler-3.1.8-bin/st...

ES运维(八)添加IK分词器

ES运维(八)添加IK分词器

一、概述ES自带standard analyzer、simple analyzer、whitespace analyzer、stop analyzer、language analyzer、patter...

Hive优化之监控(四)

Hive优化之监控(四)

    Hive是大数据领域常用的组件之一,主要是大数据离线数仓的运算,关于Hive的性能调优在日常工作和面试中是经常涉及的一个点,因此掌握一些Hive调优是必...

Sentry管理Hive目录acl -setacl不生效

Sentry管理Hive目录acl -setacl不生效

CDH在启动Sentry后/user/hive/warehouse这个目录 hdfs手动setacl会不生效首先确保hdfs参数dfs.namenode.acls.enabled=true;还有另一个...

ES运维(三)架构与规划(阿里云)

ES运维(三)架构与规划(阿里云)

1、 阿里云Elasticsearch架构图阿⾥云Elasticsearch和Kibana容器化运⾏在ECS中,监控agent(独⽴进程)负责收集监控指标,通过SLS发送给云监控完成监控报警。实例之间...

haproxy服务无法正常启动

haproxy服务无法正常启动

【局点信息】测试环境【集群信息】【问题现象】haproxy设置配置文件后,无法正常启动,查看服务状态显示失败配置增加内容#增加如下配置 listen ApiApplicationServer   ...

发表评论    

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。