原文:Elasticsearch7.X 入门学习第九课笔记-----聚合分析Aggregation

版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。

什么是聚合(Aggregation)

1、 elasticsearch 除了搜索以外,提供的针对ES数据进行统计分析的功能

实时性高、Hadoop(T+1)

2、通过聚合,我们会得到一个数据的概览,是分析和总结全套的数据,而不是寻找单个文档

3、高性能,只需要一套语句,就可以从Elasticsearch得到分析结果(无需在客户端自己去实现分析逻辑)

集合的分类

Aggregation共分为三种:Metric Aggregations、Bucket Aggregations、 Pipeline Aggregations、Matrix Aggregations。

Metric Aggregations 主要是做 一系列的统计,Bucket Aggregations相当于分组。

准备测试数据:


  1. PUT zhifou/_doc/1
  2. {
  3. "name":"顾老二",
  4. "age":30,
  5. "from": "gu",
  6. "desc": "皮肤黑、武器长、性格直",
  7. "tags": ["黑", "长", "直"]
  8. }
  9. PUT zhifou/_doc/2
  10. {
  11. "name":"大娘子",
  12. "age":18,
  13. "from":"sheng",
  14. "desc":"肤白貌美,娇憨可爱",
  15. "tags":["白", "富","美"]
  16. }
  17. PUT zhifou/_doc/3
  18. {
  19. "name":"龙套偏房",
  20. "age":22,
  21. "from":"gu",
  22. "desc":"mmp,没怎么看,不知道怎么形容",
  23. "tags":["造数据", "真","难"]
  24. }
  25. PUT zhifou/_doc/4
  26. {
  27. "name":"石头",
  28. "age":29,
  29. "from":"gu",
  30. "desc":"粗中有细,狐假虎威",
  31. "tags":["粗", "大","猛"]
  32. }
  33. PUT zhifou/_doc/5
  34. {
  35. "name":"魏行首",
  36. "age":25,
  37. "from":"广云台",
  38. "desc":"仿佛兮若轻云之蔽月,飘飘兮若流风之回雪,mmp,最后竟然没有嫁给顾老二!",
  39. "tags":["闭月","羞花"]
  40. }

Bucket Aggregations  的api 介绍

下面例子使用 term是 进行分桶

分组查询

现在我想要查询所有人的年龄段,并且按照15~20,20~25,25~30分组,并且算出每组的平均年龄。

分析需求,首先我们应该先把分组做出来。


  1. GET zhifou/_search
  2. {
  3. "size": 0,
  4. "query": {
  5. "match_all": {}
  6. },
  7. "aggs": {
  8. "age_group": {
  9. "range": {
  10. "field": "age",
  11. "ranges": [
  12. {
  13. "from": 15,
  14. "to": 20
  15. },
  16. {
  17. "from": 20,
  18. "to": 25
  19. },
  20. {
  21. "from": 25,
  22. "to": 30
  23. }
  24. ]
  25. }
  26. }
  27. }
  28. }

Metric Aggregations  的api 介绍

Avg Aggregation  #计算出字段平均值

做聚合分析,应该讲size 设置为0,否则会返回查询结果。写20,aggs的相关结果会出现在比较后面而已

现在的需求是查询fromgu的人的平均年龄。


  1. POST zhifou/_search
  2. {
  3. "size": 0,
  4. "query": {
  5. "match": {
  6. "from": "gu"
  7. }
  8. },
  9. "aggs": {
  10. "age_ave": {
  11. "avg": {
  12. "field": "age"
  13. }
  14. }
  15. }
  16. }

上例中,首先匹配查询fromgu的数据。在此基础上做查询平均值的操作,这里就用到了聚合函数,其语法被封装在aggs中,而age_ave则是为查询结果起个别名,封装了计算出的平均值。那么,要以什么属性作为条件呢?是age年龄,查年龄的什么呢?是avg,查平均年龄。

2   Max Aggregation  #求最大值


  1. GET zhifou/_search
  2. {
  3. "aggs": {
  4. "my_max": {
  5. "max": {
  6. "field": "age"
  7. }
  8. }
  9. },
  10. "size": 0
  11. }

Min Aggregation #求最小值


  1. GET zhifou/_search
  2. {
  3. "aggs": {
  4. "my_min": {
  5. "min": {
  6. "field": "age"
  7. }
  8. }
  9. },
  10. "size": 0
  11. }

Sum Aggregation #求和


  1. "aggs" : {
  2. "intraday_return" : { "sum" : { "field" : "change" } }
  3. }

Stats Aggregation  #最大、最小、和、平均值。一起求出来


  1. GET zhifou/_search
  2. {
  3. "aggs": {
  4. "my_stats": {
  5. "stats": {
  6. "field": "age"
  7. }
  8. }
  9. },
  10. "size": 0
  11. }

Extended Stats Aggregation #字段的其他属性,包括最大最小,方差等等。


  1. GET zhifou/_search
  2. {
  3. "aggs": {
  4. "my_extended_stats": {
  5. "extended_stats": {
  6. "field": "age"
  7. }
  8. }
  9. },
  10. "size": 0
  11. }

Cardinality Aggregation#计算出字段的唯一值。相当于sql中的distinct


  1. {
  2. "aggs" : {
  3. "author_count" : {
  4. "cardinality" : {
  5. "field" : "author"
  6. }
  7. }
  8. }
  9. }

Geo Bounds Aggregation

计算出所有的地理坐标将会落在一个矩形区域。比如说朝阳区域有很多饭店,我就可以用一个矩形把这些饭店都圈起来,看看范围。


  1. {
  2. "query" : {
  3. "match" : { "business_type" : "shop" }
  4. },
  5. "aggs" : {
  6. "viewport" : {
  7. "geo_bounds" : {
  8. "field" : "location",
  9. "wrap_longitude" : true
  10. }
  11. }
  12. }
  13. }

Geo Centroid Aggregation

计算出所有文档的大概的中心点。比如说某个地区盗窃犯罪很多,那我这样就可以看到这片区域到底哪个点(街道)偷盗事件最猖狂。


  1. {
  2. "query" : {
  3. "match" : { "crime" : "burglary" }
  4. },
  5. "aggs" : {
  6. "centroid" : {
  7. "geo_centroid" : {
  8. "field" : "location"
  9. }
  10. }
  11. }
  12. }

10 Percentiles Aggregation

百分比统计。可以看出你网站的所有页面。加载时间的差异


  1. {
  2. "aggs" : {
  3. "load_time_outlier" : {
  4. "percentiles" : {
  5. "field" : "load_time"
  6. }
  7. }
  8. }
  9. }

11 Percentile Ranks Aggregation

看看15毫秒和30毫秒内大概有多少页面加载完。


  1. {
  2. "aggs" : {
  3. "load_time_outlier" : {
  4. "percentile_ranks" : {
  5. "field" : "load_time",
  6. "values" : [15, 30]
  7. }
  8. }
  9. }
  10. }

12 Top hits Aggregation


  1. {
  2. "aggs": {
  3. "top-tags": {
  4. "terms": {
  5. "field": "tags",
  6. "size": 3
  7. },
  8. "aggs": {
  9. "top_tag_hits": {
  10. "top_hits": {
  11. "sort": [
  12. {
  13. "last_activity_date": {
  14. "order": "desc"
  15. }
  16. }
  17. ],
  18. "_source": {
  19. "include": [
  20. "title"
  21. ]
  22. },
  23. "size" : 1
  24. }
  25. }
  26. }
  27. }
  28. }
  29. }

13 alue Count Aggregation  #数量统计,看看这个字段一共有多少个不一样的数值。


  1. {
  2. "aggs" : {
  3. "grades_count" : { "value_count" : { "field" : "grade" } }
  4. }
  5. }

嵌套

在kabana导入 航空信息


  1. #查看航班目的地的统计信息,增加平均,最高最低价格
  2. GET kibana_sample_data_flights/_search
  3. {
  4. "size": 0,
  5. "aggs":{
  6. "flight_dest":{
  7. "terms":{
  8. "field":"DestCountry"
  9. },
  10. "aggs":{
  11. "avg_price":{
  12. "avg":{
  13. "field":"AvgTicketPrice"
  14. }
  15. },
  16. "max_price":{
  17. "max":{
  18. "field":"AvgTicketPrice"
  19. }
  20. },
  21. "min_price":{
  22. "min":{
  23. "field":"AvgTicketPrice"
  24. }
  25. }
  26. }
  27. }
  28. }
  29. }
  30. #价格统计信息+天气信息
  31. GET kibana_sample_data_flights/_search
  32. {
  33. "size": 0,
  34. "aggs":{
  35. "flight_dest":{
  36. "terms":{
  37. "field":"DestCountry"
  38. },
  39. "aggs":{
  40. "stats_price":{
  41. "stats":{
  42. "field":"AvgTicketPrice"
  43. }
  44. },
  45. "wather":{
  46. "terms": {
  47. "field": "DestWeather",
  48. "size": 5
  49. }
  50. }
  51. }
  52. }
  53. }
  54. }

Elasticsearch7.X 入门学习第九课笔记-----聚合分析Aggregation的更多相关文章

  1. Elasticsearch7.X 入门学习第一课笔记----基本概念

    原文:Elasticsearch7.X 入门学习第一课笔记----基本概念 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链接:https: ...

  2. Elasticsearch7.X 入门学习第二课笔记----基本api操作和CRUD

    原文:Elasticsearch7.X 入门学习第二课笔记----基本api操作和CRUD 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链 ...

  3. Es学习第九课, 聚合查询和复合查询

    ES除了实现前几课的基本查询,也可以实现类似关系型数据库的聚合查询,如平均值sum.最小值min.最大值max等等 我们就用上一课的数据作为参考来举例 聚合查询 sum聚合 sum是一个求累加值的聚合 ...

  4. Elasticsearch7.X 入门学习第八课笔记-----索引模板和动态模板

    原文:Elasticsearch7.X 入门学习第八课笔记-----索引模板和动态模板 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链接: ...

  5. Elasticsearch7.X 入门学习第七课笔记-----Mapping多字段与自定义Analyzer

    原文:Elasticsearch7.X 入门学习第七课笔记-----Mapping多字段与自定义Analyzer 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处 ...

  6. Elasticsearch7.X 入门学习第五课笔记---- - Mapping设定介绍

    原文:Elasticsearch7.X 入门学习第五课笔记---- - Mapping设定介绍 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本 ...

  7. Elasticsearch7.X 入门学习第四课笔记---- Search API之(Request Body Search 和DSL简介)

    原文:Elasticsearch7.X 入门学习第四课笔记---- Search API之(Request Body Search 和DSL简介) 版权声明:本文为博主原创文章,遵循CC 4.0 BY ...

  8. Elasticsearch7.X 入门学习第三课笔记----search api学习(URI Search)

    原文:Elasticsearch7.X 入门学习第三课笔记----search api学习(URI Search) 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出 ...

  9. iOS 阶段学习第九天笔记(内存管理)

    iOS学习(C语言)知识点整理 一.内存管理 1)malloc , 用于申请内存; 结构void *malloc(size_t),需要引用头文件<stdlib.h>:在堆里面申请内存,si ...

随机推荐

  1. vue开发移动端总结

    1.app.vue组件中,外层只能有一个div块,不能多个并列在一起. 正确: 错误: 2.main.js文件 3. app.vue文件 4. stroe.js 文件 5. router.js

  2. PageOffice修改注册码升级版本

    java: 删除pageoffice.jar所在目录(一般是WEB-INF/lib)下的license.lic文件(若服务器运行时找不到该文件,可在浏览器地址栏里面通过localhost方式访问pos ...

  3. 数据结构--排序--快排and冒泡(python)

    听说大厂面试,限时两分钟写出来快排... 闲着没事,写了一下... def Partition(L,low,high): pivotkey = L[low] while low<high: wh ...

  4. linux运维、架构之路-Kubernetes集群部署TLS双向认证

    一.kubernetes的认证授权       Kubernetes集群的所有操作基本上都是通过kube-apiserver这个组件进行的,它提供HTTP RESTful形式的API供集群内外客户端调 ...

  5. mybatis配eclise模板,mybatis快速生成模板

    eclipse中mybatis得mapper文件不提示(mybatis-3-mapper.dtd,mybatis-3-config.dtd) 1.下载该文件到你的硬盘文件夹下 2.windows -- ...

  6. 【rust】Rust 的构建系统和包管理工具Cargo认识并初步使用(2)

    Cargo 是 Rust 的构建系统和包管理工具,同时 Rustacean 们使用 Cargo 来管理它们的 Rust 项目.Cargo 负责三个工作:构建你的代码,下载你代码依赖的库并编译这些库.我 ...

  7. python 指定画图分辨率

    from IPython.core.pylabtools import figsize # import figsize figsize(12.5, 4) # 设置 figsize plt.rcPar ...

  8. [CSP-S模拟测试]:骆驼(模拟+构造)

    题目描述 我们都熟悉走马步,现在我们定义一种新的移动方式——骆驼步,它在一个国际棋盘上的移动规则是这样的. 以看出,骆驼步可以向八个方向走动,且不能走出棋盘范围. 现在给出一个$N\times N$的 ...

  9. 解决 ffmpeg 在avformat_find_stream_info执行时间太长

    用ffmpeg做demux,网上很多参考文章.对于网络流,avformt_find_stream_info()函数默认需要花费较长的时间进行流格式探测,那么,如何减少探测时间内? 可以通过设置AVFo ...

  10. CBAM: Convolutional Block Attention Module

    1. 摘要 作者提出了一个简单但有效的注意力模块 CBAM,给定一个中间特征图,我们沿着空间和通道两个维度依次推断出注意力权重,然后与原特征图相乘来对特征进行自适应调整. 由于 CBAM 是一个轻量级 ...