当前位置: 首页 > news >正文

【基础篇】第5章 Elasticsearch 数据聚合与分析

在Elasticsearch的庞大功能体系中,数据聚合与分析扮演着至关重要的角色,它使我们能够从海量数据中提炼出有价值的信息,为决策提供依据。本章将深入探讨Elasticsearch的聚合功能,从基本概念到常见类型的实践,让你掌握如何高效地对数据进行分组、计数、统计和分析。

5.1 聚合简介

Elasticsearch的聚合功能允许用户对索引中的数据进行汇总和分析,它不仅仅是简单的计数或求和,而是涵盖了从基本统计到复杂数据分布分析的全方位能力。聚合操作通过在搜索请求中定义,可以在一次查询中同时返回搜索结果和聚合结果,极大地增强了数据探索的灵活性和效率。

5.2 常用聚合类型

Elasticsearch提供的聚合功能非常丰富,能够满足多种数据分析需求。以下是对几种常用聚合类型的详细说明,包括它们的工作原理、适用场景以及具体案例,帮助读者更好地理解和应用这些强大的数据处理工具。

5.2.1 Terms聚合

概念: terms聚合是最基础也是最常用的聚合类型,它根据指定字段的值进行分组,每个唯一的值对应一个桶(bucket),并统计每个桶内文档的数量。这种聚合非常适合进行分类统计,比如统计网站上不同类别的文章数量。

案例:
假设有一个博客文章索引,我们想统计每个作者的文章数量。

GET blog_posts/_search
{"size": 0,"aggs": {"authors": {"terms": {"field": "author.keyword","size": 10}}}
}

结果示例:

{"aggregations": {"authors": {"buckets": [{"key": "Alice", "doc_count": 35},{"key": "Bob", "doc_count": 22},{"key": "Charlie", "doc_count": 18},...]}}
}
5.2.2 Histogram聚合

概念: histogram聚合将数值型字段的值域分割成多个区间(桶),每个区间代表一个范围,然后统计落入每个区间内的文档数量。它适用于分析数值数据的分布情况,比如分析商品价格的分布。

案例:
分析商品价格区间内的销售分布,以100元为间隔。

GET sales/_search
{"aggs": {"price_histogram": {"histogram": {"field": "price","interval": 100}}}
}

结果示例:

{"aggregations": {"price_histogram": {"buckets": [{"key": 0, "doc_count": 50},{"key": 100, "doc_count": 30},{"key": 200, "doc_count": 20},...]}}
}
5.2.3 Date Histogram聚合

概念: date_histogram聚合与histogram相似,但专用于日期字段,按时间间隔(如天、周、月等)分组,用于分析时间序列数据。例如,分析网站每天的访问量。

案例:
分析每天的访问记录数量。

GET website_logs/_search
{"aggs": {"visits_per_day": {"date_histogram": {"field": "access_date","calendar_interval": "day"}}}
}

结果示例:

{"aggregations": {"visits_per_day": {"buckets": [{"key_as_string": "2023-04-01T00:00:00.000Z", "key": 1680230400000, "doc_count": 235},{"key_as_string": "2023-04-02T00:00:00.000Z", "key": 1680316800000, "doc_count": 250},...]}}
}
5.2.4 Metrics聚合

概念: 指标聚合用于计算单个数值指标,如平均值(avg)、最大值(max)、最小值(min)、总和(sum)等。它可以单独使用,但更多时候作为桶聚合内的子聚合,对每个桶中的数据进行进一步的数值分析。

案例:
在每个作者的文章数量统计基础上,进一步计算每个作者文章的平均评分。

GET blog_posts/_search
{"size": 0,"aggs": {"authors": {"terms": {"field": "author.keyword","size": 10},"aggs": {"average_rating": {"avg": {"field": "rating"}}}}}
}

结果示例:

{"aggregations": {"authors": {"buckets": [{"key": "Alice", "doc_count": 35, "average_rating": {"value": 4.2}},{"key": "Bob", "doc_count": 22, "average_rating": {"value": 3.8}},...]}}
}

通过这些案例,我们可以看到Elasticsearch的聚合功能不仅强大而且灵活,能够满足多样化的数据分析需求。掌握这些常用聚合类型及其应用场景,是进行高效数据探索和分析的重要基础。

5.3 桶与指标聚合

Elasticsearch的聚合功能之所以强大,很大程度上得益于其灵活的桶聚合(Bucket Aggregations)和指标聚合(Metric Aggregations)机制。这两种聚合类型相辅相成,共同构成了复杂数据分析的基础。本节将更深入地探讨这两类聚合的工作原理、相互作用方式以及在实际应用中的高级用法。

5.3.1 桶聚合(Bucket Aggregations)的深入解析

桶聚合,顾名思义,是将数据划分到不同的“桶”中,每个桶代表一个数据范围或类别。它的核心作用是将数据分组,为后续的分析提供结构框架。主要的桶聚合类型包括termshistogramdate_histogram等,前面已有介绍。更进一步地,桶聚合还可以嵌套,形成层级结构,使得数据细分和分析更为精细。

高级用法:

  • 嵌套桶聚合:通过在桶内嵌套其他桶聚合,可以实现多维度的数据分析。例如,在按月份统计销售量的同时,还可以按产品类别细分,即在date_histogram桶内嵌套一个terms桶。
  • 复合桶聚合:如range聚合,根据数值字段的范围划分桶,特别适用于价格区间分析等场景。
  • Missing桶:用于捕捉缺失值,单独分析没有特定字段数据的文档。
5.3.2 指标聚合(Metric Aggregations)的深化应用

指标聚合用于计算每个桶内文档的数值型指标,如平均值、总和、最大值、最小值等。它通常与桶聚合结合使用,为每个分组提供量化分析结果。主要的指标聚合类型有avgsumminmaxcardinality(唯一值计数)等。

高级用法:

  • 多指标聚合:在同一个桶内可以定义多个指标聚合,一次性获取多个统计指标,如同时计算每个类别的平均销售额和销售笔数。
  • Pipeline聚合:这是一种特殊的指标聚合,它允许使用先前桶或指标聚合的结果进行进一步的计算,如计算百分比变化、移动平均等。这为复杂数据分析提供了强大的支持。
  • Top Hits聚合:在每个桶内返回最相关的文档,这对于分析每个分组的代表性文档非常有用。
5.3.3 桶与指标聚合的协同工作

桶聚合与指标聚合的结合使用是Elasticsearch数据分析的核心所在。桶聚合负责数据的分组,为每个组创建一个上下文;指标聚合则在此上下文中进行数值计算,提供每个分组的统计信息。这种结构化的方法使得用户能够从宏观到微观,层层深入地探索数据。

小结

通过本章的学习,我们不仅认识到了Elasticsearch聚合功能的重要性,还深入探讨了多种常用聚合类型及其应用场景。桶聚合与指标聚合的结合使用,为我们提供了强大的数据分组和统计能力,是进行数据分析和报告制作的有力工具。掌握了这些基础,你将能够更加自信地面对数据海洋,从中挖掘出宝贵的信息宝藏。接下来的旅程,【高级篇】第6章《高级查询与搜索优化》,将带领大家探索更高级的查询技术与性能优化策略,进一步提升Elasticsearch的使用效能。

相关文章:

【基础篇】第5章 Elasticsearch 数据聚合与分析

在Elasticsearch的庞大功能体系中,数据聚合与分析扮演着至关重要的角色,它使我们能够从海量数据中提炼出有价值的信息,为决策提供依据。本章将深入探讨Elasticsearch的聚合功能,从基本概念到常见类型的实践,让你掌握如…...

【网络安全】修改Host文件实现域名解析

场景 开发一个网站或者服务,需要在本地测试时,可以将线上的域名指向本地开发环境的IP地址。从而模拟真实环境中的域名访问,方便调试和开发。 步骤 1、以管理员身份打开命令提示符 2、编辑hosts文件: 输入以下命令打开hosts文…...

Spring Boot 全面解析:从入门到实践案例

引言: Spring Boot 是由 Pivotal 团队提供的全新框架,旨在简化 Spring 应用的初始搭建以及开发过程。它基于 Spring 平台,通过“约定优于配置”的原则,尽可能自动化配置,减少XML配置,使得开发者能够快速启…...

222222222

2222222...

Boost 智能指针

scoped_ptr 不能被复制或赋值给其他 scoped_ptr 对象&#xff0c;不能与其他指针比较 (除了 nullptr) scoped_ptr 用例 template <typename T> class scoped_ptr { public:// 构造函数&#xff1a;初始化 scoped_ptr 并接管指针的所有权explicit scoped_ptr(T* ptr n…...

在WSL Ubuntu中启用root用户的SSH服务

在 Ubuntu 中&#xff0c;默认情况下 root 用户是禁用 SSH 登录的&#xff0c;这是为了增加系统安全性。 一、修改配置 找到 PermitRootLogin 行&#xff1a;在文件中找到 PermitRootLogin 配置项。默认情况下&#xff0c;它通常被设置为 PermitRootLogin prohibit-password 或…...

C语⾔数据类型和变量

C语⾔数据类型和变量 1.数据类型介绍1.1 字符型1.2 整型1.3 浮点型1.4 布尔类型1.5 各种数据类型的长度1.5.1 sizeof操作符1.5.2 数据类型长度1.5.3 sizeof中表达式不计算 2. signed 和 unsigned3. 数据类型的取值范围4. 变量4.1 变量的创建4.2 变量的分类 5. 算术操作符&#…...

运行时类型信息(RTTI)

在计算机编程中,运行时类型信息(Runtime Type Information,简称RTTI)或运行时类型标识(Runtime Type Identification)是某些编程语言(如C++、Object Pascal、Ada)的一个特性,它允许在程序运行时获取对象的数据类型信息。RTTI可以用于所有类型,也只能用于显式启用RTTI…...

使用 NVivo 定性数据分析软件指导癌症护理研究

您是否曾因进行全面文献综述所需的大量研究而感到不知所措&#xff1f;在比较和整理大量冗长的出版物时&#xff0c;您是否不知道从哪里开始&#xff1f;幸运的是&#xff0c;这正是定性研究专家 Heidi Rishel Brakey 硕士擅长的领域&#xff0c;我们将在本案例研究中介绍这一点…...

R语言 | 使用ggplot绘制柱状图,在柱子中显示数值和显著性

原文链接&#xff1a;使用ggplot绘制柱状图&#xff0c;在柱子中显示数值和显著性 本期教程 获得本期教程示例数据&#xff0c;后台回复关键词&#xff1a;20240628。&#xff08;PS&#xff1a;在社群中&#xff0c;可获得往期和未来教程所有数据和代码&#xff09; 往期教程…...

第十四届蓝桥杯省赛C++B组D题【飞机降落】题解(AC)

解题思路 这道题目要求我们判断给定的飞机是否都能在它们的油料耗尽之前降落。为了寻找是否存在合法的降落序列&#xff0c;我们可以使用深度优先搜索&#xff08;DFS&#xff09;的方法&#xff0c;尝试所有可能的降落顺序。 首先&#xff0c;我们需要理解题目中的条件。每架…...

容器化spring boot应用程序

容器化spring boot应用程序有多种方式&#xff0c;如基于简单的Dockerfile&#xff0c;多阶段Dockerfile以及基于Docker Compose等&#xff0c;我们将逐步给大家介绍&#xff0c;本节主要介绍基于简单的Dockerfile进行容器化spring boot的应用程序。 创建Spring boot应用程序 …...

掌握智慧校园:资产来源功能解析

在智慧校园的资产管理框架下&#xff0c;资产来源管理是确保资产数据完整性和合规性的重要一环。这一功能通过数字化手段&#xff0c;详尽记录每一项资产从何而来&#xff0c;无论是采购、捐赠、内部调拨&#xff0c;还是自制与改造&#xff0c;均需经过严格记录与追踪&#xf…...

基于公有云部署wordpress

云平台选择 腾讯云 阿里云 华为云 项目部署 一、架构讲解 1.1、定义与组成 LNMP是Linux、Nginx、MySQL&#xff08;或MariaDB&#xff09;和PHP&#xff08;或Perl、Python&#xff09;的首字母缩写&#xff0c;代表在Linux系统下使用Nginx作为Web服务器&#xff0c;MySQL作为…...

vite+vue集成cesium

1、创建项目、选择框架vuejs pnpm create vite demo_cesium 2、进入项目安装依赖 cd demo_cesium pnpm install3、安装cesium及插件 3、pnpm i cesium vite-plugin-cesium 4、修改vite-config.js import { defineConfig } from vite import vue from vitejs/plugin-vue impo…...

2024 年江西省研究生数学建模竞赛A题:交通信号灯管理问题分析、实现代码及参考论文

2024 年江西省研究生数学建模竞赛题目交通信号灯管理 1 题目 交通信号灯是指挥车辆通行的重要标志&#xff0c;由红灯、绿灯、 黄灯组成。红灯停、绿灯行&#xff0c;而黄灯则起到警示作用。交通 信号灯分为机动车信号灯、非机动车信号灯、人行横道信号 灯、方向指示灯等。 一…...

华为机试HJ1字符串最后一个单词的长度

华为机试HJ1字符串最后一个单词的长度 题目&#xff1a; 计算字符串中最后一个单词的长度 想法&#xff1a; 利用空格将字符串中的单词进行切分&#xff0c;返回最后一个单词的长度 input_str input() # 字符串输入 result input_str.split(" ")[-1] # 选取…...

排序(冒泡排序、选择排序、插入排序、希尔排序)-->深度剖析(一)

欢迎来到我的Blog&#xff0c;点击关注哦&#x1f495; 前言 排序是一种基本的数据处理操作&#xff0c;它涉及将一系列项目重新排列&#xff0c;以便按照指定的标准&#xff08;通常是数值大小&#xff09;进行排序。在C语言中&#xff0c;排序算法是用来对元素进行排序的一系…...

(2024)docker-compose实战 (6)部署前端项目(react, vue)

前言 本次仅使用nginx搭建单一的前端项目, 前端项目可以是html, react, vue.项目目录中需要携带nginx的配置文件(conf/default.conf).前端文件直接拷贝到项目目录中即可.如果不确定镜像的配置文件目录, 可以通过 docker inspect 镜像名 来查看具体的配置信息.使用docker-compos…...

python 中的 下划线_ 是啥意思

在 Python 中&#xff0c;_&#xff08;下划线&#xff09;通常用作占位符&#xff0c;表示一个变量名&#xff0c;但程序中不会实际使用这个变量的值。 目录 忽略循环变量&#xff1a;忽略函数返回值&#xff1a;在解释器中使用&#xff1a;举例子1. 忽略循环变量2. 忽略不需…...

OkHttp 中实现断点续传 demo

在 OkHttp 中实现断点续传主要通过以下步骤完成&#xff0c;核心是利用 HTTP 协议的 Range 请求头指定下载范围&#xff1a; 实现原理 Range 请求头&#xff1a;向服务器请求文件的特定字节范围&#xff08;如 Range: bytes1024-&#xff09; 本地文件记录&#xff1a;保存已…...

[10-3]软件I2C读写MPU6050 江协科技学习笔记(16个知识点)

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16...

前端开发面试题总结-JavaScript篇(一)

文章目录 JavaScript高频问答一、作用域与闭包1.什么是闭包&#xff08;Closure&#xff09;&#xff1f;闭包有什么应用场景和潜在问题&#xff1f;2.解释 JavaScript 的作用域链&#xff08;Scope Chain&#xff09; 二、原型与继承3.原型链是什么&#xff1f;如何实现继承&a…...

如何在最短时间内提升打ctf(web)的水平?

刚刚刷完2遍 bugku 的 web 题&#xff0c;前来答题。 每个人对刷题理解是不同&#xff0c;有的人是看了writeup就等于刷了&#xff0c;有的人是收藏了writeup就等于刷了&#xff0c;有的人是跟着writeup做了一遍就等于刷了&#xff0c;还有的人是独立思考做了一遍就等于刷了。…...

08. C#入门系列【类的基本概念】:开启编程世界的奇妙冒险

C#入门系列【类的基本概念】&#xff1a;开启编程世界的奇妙冒险 嘿&#xff0c;各位编程小白探险家&#xff01;欢迎来到 C# 的奇幻大陆&#xff01;今天咱们要深入探索这片大陆上至关重要的 “建筑”—— 类&#xff01;别害怕&#xff0c;跟着我&#xff0c;保准让你轻松搞…...

【JVM】Java虚拟机(二)——垃圾回收

目录 一、如何判断对象可以回收 &#xff08;一&#xff09;引用计数法 &#xff08;二&#xff09;可达性分析算法 二、垃圾回收算法 &#xff08;一&#xff09;标记清除 &#xff08;二&#xff09;标记整理 &#xff08;三&#xff09;复制 &#xff08;四&#xff…...

基于Springboot+Vue的办公管理系统

角色&#xff1a; 管理员、员工 技术&#xff1a; 后端: SpringBoot, Vue2, MySQL, Mybatis-Plus 前端: Vue2, Element-UI, Axios, Echarts, Vue-Router 核心功能&#xff1a; 该办公管理系统是一个综合性的企业内部管理平台&#xff0c;旨在提升企业运营效率和员工管理水…...

GO协程(Goroutine)问题总结

在使用Go语言来编写代码时&#xff0c;遇到的一些问题总结一下 [参考文档]&#xff1a;https://www.topgoer.com/%E5%B9%B6%E5%8F%91%E7%BC%96%E7%A8%8B/goroutine.html 1. main()函数默认的Goroutine 场景再现&#xff1a; 今天在看到这个教程的时候&#xff0c;在自己的电…...

Chromium 136 编译指南 Windows篇:depot_tools 配置与源码获取(二)

引言 工欲善其事&#xff0c;必先利其器。在完成了 Visual Studio 2022 和 Windows SDK 的安装后&#xff0c;我们即将接触到 Chromium 开发生态中最核心的工具——depot_tools。这个由 Google 精心打造的工具集&#xff0c;就像是连接开发者与 Chromium 庞大代码库的智能桥梁…...

探索Selenium:自动化测试的神奇钥匙

目录 一、Selenium 是什么1.1 定义与概念1.2 发展历程1.3 功能概述 二、Selenium 工作原理剖析2.1 架构组成2.2 工作流程2.3 通信机制 三、Selenium 的优势3.1 跨浏览器与平台支持3.2 丰富的语言支持3.3 强大的社区支持 四、Selenium 的应用场景4.1 Web 应用自动化测试4.2 数据…...