日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 综合教程 >内容正文

综合教程

ES aggregation详解

發布時間:2023/12/19 综合教程 35 生活家
生活随笔 收集整理的這篇文章主要介紹了 ES aggregation详解 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

aggregation分類

aggregations —— 聚合,提供了一種基于查詢條件來對數據進行分桶、計算的方法。有點類似于 SQL 中的 group by 再加一些函數方法的操作。

聚合可以嵌套,由此可以組成復雜的操作(Bucketing聚合可以包含sub-aggregation)。

聚合整體上可以分為 3 類:

1. Bucketing:桶分聚合:

此類聚合執行的是對文檔分組的操作,把滿足相關特性的文檔分到一個桶里,即桶分。輸出結果往往是一個個包含多個文檔的桶。
此類聚合會有一個關鍵字(field、script),以及一些桶分(分組)的判斷條件。執行聚合操作時候,文檔會判斷每一個分組條件,如果滿足某個,該文檔就會被分為該組(fall in)。

2. Metric:指標聚合:

此類聚合是對文檔進行一些權值計算(比如求所有文檔某個字段的max值)。輸出結果往往是文檔的權值,相當于為文檔添加了一些統計信息。
此類聚合基于特定字段(field)或腳本值(generated using scripts),計算聚合中文檔的權值。

3. Pipeline:管道聚合:

對其它聚合操作的輸出及其關聯指標進行聚合。
此類聚合的作用對象往往是桶,而不是文檔,是一種后期對每個分桶的一些計算操作。

應用場景

對于 3 中聚合,常見的應用場景如下流程:

buckets 聚合對文檔進行必要的歸類(桶分) ——> metric 聚合對每個桶進行一些額外的信息計算(如:max) ——> pipeline 聚合針對所有桶做一些桶層面的統計或計算應用示例:




{
    "aggs" : {
        "sales_per_month" : {
            "date_histogram" : {              // bucket 聚合,按照月份進行分桶,每個月的歸屬一個桶
                "field" : "date",
                "interval" : "month"
            },
            "aggs": {
                "sales": {
                    "sum": {                       // metric 聚合,對每個桶類的 price 求和,即每月的銷售額
                        "field": "price"
                    }
                }
            }
        },
        "max_monthly_sales": {
            "max_bucket": {                 // pipeline 聚合,求所有桶中銷售額 sales 最大的值
                "buckets_path": "sales_per_month>sales" 
            }
        }
    }
}


aggregation結構

聚合可以是父子(嵌套)關系聚合,buckets 聚合作為父,metric 聚合作為子。

聚合也可以是兄弟關系聚合,buckets 聚合在前,pipeline 聚合在后。

結構如下:


"aggregations" : {                                //定義聚合對象,也可用 "aggs"
      "<aggregation_name>" : {                    //聚合的名稱,用戶自定義
          "<aggregation_type>" : {                //聚合類型,比如 "histogram"
              <aggregation_body>                  //每個聚合類型都有其自己的結構定義
          }
          [,"meta" : {  [<meta_data_body>] } ]?
          [,"aggregations" : { [<sub_aggregation>]+ } ]?    //可以定義多個 sub-aggregation
      }
      [,"<aggregation_name_2>" : { ... } ]*       //定義額外的多個平級 aggregation,只有 Bucketing 類型才有意義
}

2 metrics aggregations

概述

權值聚合類型從需要聚合的文檔中取一個值(value)來計算文檔的相應權值(比如該值在這些文檔中的max、sum等)。

用于計算的值(value)可以是文檔的字段(field),也可以是腳本(script)生成的值。

數值權值聚合是特殊的權值聚合類型,因為它的輸出權值也是數字。

數值權值聚合(注意分類只針對數值權值聚合,非數值的無此分類)輸出單個權值的,叫做 single-value numeric metrics,其它生成多個權值(比如:stats)的被叫做 multi-value numeric metrics。

單值和多值數字權值聚合,在它們作為一些 Bucket 聚合的直接子聚合的時候會有明顯區別。

Avg Aggregation(single-value numeric metrics)

均值聚合——基于文檔的某個值,計算該值在聚合文檔中的均值。

用于計算的值可以是特定的數值型字段,也可以通過腳本計算而來。

配置參數

field:用于計算的字段
script:由腳本生成用來計算的 value
missing:文檔缺省字段時的默認值


{
    "aggs" : {
        "avg_grade" : { "avg" : { "field" : "grade" } }    //計算字段 grade 在文檔中的平均值
    }
}
//輸出
{
    ...

    "aggregations": {
        "avg_grade": {
            "value": 75
        }
    }
}


Cardinality Aggregation(single-value)

基數聚合——基于文檔的某個值,計算文檔非重復的個數(去重計數)。

用于計算的值可以是特定的字段,也可以通過腳本計算而來。

配置參數

field:用于計算的字段
script:由腳本生成用來計算的 value
precision_threshold:
missing:文檔缺省字段時的默認值


{
    "aggs" : {
        "author_count" : {
            "cardinality" : {
                "field" : "author"  //count the unique authors that match a query
            }
        }
    }
}


stats aggregation(multi-value)

統計聚合——基于文檔的某個值,計算出一些統計信息(min、max、sum、count、avg)。

用于計算的值可以是特定的數值型字段,也可以通過腳本計算而來。

配置參數

field:用于計算的字段
script:由腳本生成用來計算的 value
missing:文檔缺省字段時的默認值


{
    "aggs" : {
        "grades_stats" : { "stats" : { "field" : "grade" } }
    }
}
//輸出
{
    ...
    "aggregations": {
        "grades_stats": {
            "count": 6,
            "min": 60,
            "max": 98,
            "avg": 78.5,
            "sum": 471
        }
    }
}


Extended Stats Aggregation(multi-value)

擴展統計聚合——基于文檔的某個值,計算出一些統計信息(比普通的stats聚合多了sum_of_squares、variance、std_deviationstd_deviation_bounds)。

用于計算的值可以是特定的數值型字段,也可以通過腳本計算而來。

配置參數

field:用于計算的字段
script:由腳本生成用來計算的 value
missing:文檔缺省字段時的默認值
sigma:標準差界限


{
    ...

    "aggregations": {
        "grade_stats": {
           "count": 9,
           "min": 72,
           "max": 99,
           "avg": 86,
           "sum": 774,
           //輸出比 stats 聚合多了一些值
           "sum_of_squares": 67028,
           "variance": 51.55555555555556,
           "std_deviation": 7.180219742846005,
           "std_deviation_bounds": {
            "upper": 100.36043948569201,
            "lower": 71.63956051430799
           }
        }
    }
}


Geo Bounds Aggregation

地理邊界聚合——基于文檔的某個字段(geo-point類型字段),計算出該字段所有地理坐標點的邊界(左上角/右下角坐標點)。

配置參數

field:用于計算的字段
wrap_longitude:是否允許地理邊界與國際日界線存在重疊


{
    "query" : {
        "match" : { "business_type" : "shop" }
    },
    "aggs" : {
        "viewport" : {
            "geo_bounds" : {
                "field" : "location", 
                "wrap_longitude" : true 
            }
        }
    }
}
//輸出
{
    ...
    "aggregations": {
        "viewport": {
            "bounds": {
                "top_left": {                    //左上角經緯度
                    "lat": 80.45,
                    "lon": -160.22
                },
                "bottom_right": {               //右下角經緯度
                    "lat": 40.65,
                    "lon": 42.57
                }
            }
        }
    }
}


Geo Centroid Aggregation

地理重心聚合——基于文檔的某個字段(geo-point類型字段),計算所有坐標的加權重心。

配置參數

field:用于計算的字段(geo-point類型)


{
    "query" : {
        "match" : { "crime" : "burglary" }
    },
    "aggs" : {
        "centroid" : {
            "geo_centroid" : {
                "field" : "location" 
            }
        }
    }
}
//輸出
{
    ...
    "aggregations": {
        "centroid": {
            "location": {      //重心經緯度
                "lat": 80.45,
                "lon": -160.22
            }
        }
    }
}


Max Aggregation(single)

最大值聚合——基于文檔的某個值,求該值在聚合文檔中的最大值。

用于計算的值可以是特定的數值型字段,也可以通過腳本計算而來。

配置參數

field:用于計算的字段
script:由腳本生成用來計算的 value
missing:文檔缺省字段時的默認值

Min Aggregation(single)

最小值聚合——基于文檔的某個值,求該值在聚合文檔中的最小值。

用于計算的值可以是特定的數值型字段,也可以通過腳本計算而來。

配置參數

field:用于計算的字段
script:由腳本生成用來計算的 value
missing:文檔缺省字段時的默認值

Sum Aggregation(single-value)

求和聚合——基于文檔的某個值,求該值在聚合文檔中的統計和。

用于計算的值可以是特定的數值型字段,也可以通過腳本計算而來。

配置參數

field:用于計算的字段
script:由腳本生成用來計算的 value
missing:文檔缺省字段時的默認值


//最大值,field
{
    "aggs" : {
        "max_price" : { "max" : { "field" : "price" } }      // field 
    }
}
//最小值,script
{
    "aggs" : {
        "min_price" : {
            "min" : {
                "script" : {                            //script 計算 value
                    "file": "my_script",
                    "params": {
                        "field": "price"
                    }
                }
            }
        }
    }
}
//總和,value script 
{
    "aggs" : {
        ...
        "aggs" : {
            "daytime_return" : {
                "sum" : {
                    "field" : "change",                  // field
                    "script" : "_value * _value"        // 基于 field 用 script 計算 value
                }
            }
        }
    }
}


Percentiles Aggregation(multi-value)

百分百聚合——基于聚合文檔中某個數值類型的值,求這些值中

用于計算的值可以是特定的數值型字段,也可以通過腳本計算而來。

配置參數

field:用于計算的字段
script:由腳本生成用來計算的 value
missing:文檔缺省字段時的默認值

Script Metric Aggregation

基于腳本的權值聚合——用腳本來計算出一個權值

配置參數

init_script:用于計算的字段
map_script:由腳本生成用來計算的 value
combine_script:文檔缺省字段時的默認值
reduce_script:


{
    "query" : {
        "match_all" : {}
    },
    "aggs": {
        "profit": {
            "scripted_metric": {
                "init_script" : "_agg['transactions'] = []",
                "map_script" : "if (doc['type'].value == "sale") { _agg.transactions.add(doc['amount'].value) } else { _agg.transactions.add(-1 * doc['amount'].value) }", 
                "combine_script" : "profit = 0; for (t in _agg.transactions) { profit += t }; return profit",
                "reduce_script" : "profit = 0; for (a in _aggs) { profit += a }; return profit"
            }
        }
    }
}


Top hits Aggregation

最高匹配權值聚合——跟蹤聚合中相關性最高的文檔。

該聚合一般用做 sub-aggregation,以此來聚合每個桶中的最高匹配的文檔。

配置參數

from:最匹配的結果中的文檔個數偏移
size:top matching hits 返回的最大文檔個數(default 3)
sort:最匹配的文檔的排序方式




{
    "aggs": {
        "top-tags": {
            "terms": {
                "field": "tags",
                "size": 3
            },
            "aggs": {
                "top_tag_hits": {
                    "top_hits": {                  //用 tags 字段分組,每個 tag(即一個分組)只顯示最后一個問題,并且只在 _source 中保留 title 字段
                        "sort": [
                            {
                                "last_activity_date": {
                                    "order": "desc"
                                }
                            }
                        ],
                        "_source": {
                            "include": [
                                "title"
                            ]
                        },
                        "size" : 1
                    }
                }
            }
        }
    }
}
//輸出
"top_tags_hits": {
     "hits": {
          "total": 25365,
          "max_score": 1,
          "hits": [
              {
                 "_index": "stack",
                 "_type": "question",
                 "_id": "602679",
                 "_score": 1,
                 "_source": {
                      "title": "Windows port opening"
                 },
                 "sort": [
                      1370143231177
                  ]
               }
           ]
     }
}


Value Count Aggregation(single-value)

值計數聚合——計算聚合文檔中某個值的個數。

用于計數的值可以是特定的數值型字段,也可以通過腳本計算而來。

該聚合一般域其它 single-value 聚合聯合使用,比如在計算一個字段的平均值的時候,可能還會關注這個平均值是由多少個值計算而來。

配置參數

field:用于計算的字段
script:由腳本生成用來計算的 value


{
    "aggs" : {
        "grades_count" : { "value_count" : { "field" : "grade" } }    //計算 grade 字段共有多少個值,和 cardinality 聚合不同的
    }
}

3 bucket aggregation

概述

桶分聚合不進行權值的計算,他們對文檔根據聚合請求中提供的判斷條件(比如:{"from":0, "to":100})來進行分組(桶分)。

桶分聚合還會額外返回每一個桶內文檔的個數。

桶分聚合可以包含子聚合——sub-aggregations(權值聚合不能包含子聚合,可以作為子聚合),子聚合操作將會應用到由父(parent)聚合產生的每一個桶上。

桶分聚合根據聚合條件,可以只定義輸出一個桶;也可以輸出多個;還可以在根據聚合條件動態確定桶個數(比如:terms aggregation)。

Histogram Aggregation(multi-bucket)

直方圖聚合——基于文檔中的某個【數值類型】字段,通過計算來動態的分桶。

一個文檔屬于某個桶,計算過程大致如下:

rem = value % interval
if (rem < 0) {
    rem += interval
}
bucket_key = value - rem

配置參數

field:字段,必須為數值類型
interval:分桶間距
min_doc_count:最少文檔數桶過濾,只有不少于這么多文檔的桶才會返回
extended_bounds:范圍擴展
order:對桶排序,如果 histogram 聚合有一個權值聚合類型的"直接"子聚合,那么排序可以使用子聚合中的結果
offset:桶邊界位移,默認從0開始
keyed:hash結構返回,默認以數組形式返回每一個桶
missing:配置缺省默認值


{
    "aggs" : {
        "prices" : {
            "histogram" : {
                "field" : "price",
                "interval" : 50,
                "min_doc_count" : 1,
                "extended_bounds" : {
                    "min" : 0,
                    "max" : 500
                },
                "order" : { "_count" : "desc" },
                "keyed":true,
                "missing":0
            }
        }
    }
}

Data Histogram Aggregation(multi-bucket)

日期直方圖聚合——基于日期類型,以【日期間隔】來桶分聚合。

可用的時間間隔類型為:year、quarter、month、week、day、hour、minute、second,其中,除了year、quarter 和 month,其余可用小數形式。

配置參數

field:
interval:
format:定義日期的格式,配置后會返回一個 key_as_string 的字符串類型日期(默認只有key)
time_zone:定義時區,用作時間值的調整
offset:
missing:


{
    "aggs" : {
        "articles_over_time" : {
            "date_histogram" : {
                "field" : "date",
                "interval" : "month",
                "format" : "yyyy-MM-dd",
                "time_zone": "+08:00"
            }
        }
    }
}

Range Aggregation(multi-bucket)

范圍聚合——基于某個值(可以是 field 或 script),以【字段范圍】來桶分聚合。

范圍聚合包括 from 值,不包括 to 值(區間前閉后開)。

配置參數

ranges:配置區間,數組,每一個元素是一個區間。例如:[{from:0}, {from:50, to:100}, {to:200}]
keyed:以一個關聯的唯一字符串作為鍵,以 HASH 形式返回,而不是默認的數組
script:利用 script 執行結果替代普通的 field 值進行聚合。script可以用file給出,還可以對其它 field 進行求值計算。


{
    "aggs" : {
        "price_ranges" : {
            "range" : {
                "field" : "price",
                "ranges" : [                       //包含 3 個桶
                    { "to" : 50 },
                    { "from" : 50, "to" : 100 },
                    { "from" : 100 }
                ],
                "keyed" : true
            }
        }
    }
}

Date Range Aggregation(multi-bucket)

日期范圍聚合——基于日期類型的值,以【日期范圍】來桶分聚合。

日期范圍可以用各種Date Math表達式。

同樣的,包括 from 的值,不包括 to 的值。

配置參數

format:定義日期格式,配置后會返回一個 [to/from]_as_string 的字符串類型日期,默認是 to/from 的數值表示


{
    "aggs": {
        "range": {
            "date_range": {
                "field": "date",
                "format": "MM-yyy",               
                "ranges": [                            //包含 3 個桶
                    { "to": "now-10M/M" }, 
                    { "from": "now-10M/M" },
                    {"from":"1970-1-1", "to":"2000-1-1"}
                ]
            }
        }
    }
}

Terms Aggregation(multi-bucket)

詞元聚合——基于某個field,該 field 內的每一個【唯一詞元】為一個桶,并計算每個桶內文檔個數。

默認返回順序是按照文檔個數多少排序。

當不返回所有 buckets 的情況,文檔個數可能不準確。

配置參數

size:size用來定義需要返回多個 buckets(防止太多),默認會全部返回。(注意,如果只返回部分buckets,統計的文檔個數不一定準確(每個分片各自的top size個)。size 越大,count 會越精確。)
order:排序方式
min_doc_count:只返回文檔個數不小于該值的 buckets
script:用基本來生成詞元
include:包含過濾
exclude:排除過濾
execution_hint:
collect_mode:
missing:


{
    "aggs" : {
        "genders" : {
            "terms" : { 
              "field" : "gender",
              "size" : 5,
              "order" : { "_count" : "asc" },
              "min_doc_count": 10,
              "include" : ".*sport.*",
              "exclude" : "water_.*",
              "missing": "N/A"
            }
        }
    }
}

Filters Aggregation(multi-bucket)

多過濾聚合——基于多個過濾條件,來對當前文檔進行【過濾】的聚合,每個過濾都包含所有滿足它的文檔(多個bucket中可能重復)。

配置參數

filters: 配置過濾條件,支持 HASH 或 數組格式
other_bucket: 是否計算不滿足任何匹配條件的文檔
other_bucket_key: 作為不匹配所有過濾條件的文檔的 bucket 名稱


{
  "aggs" : {
    "messages" : {
      "filters" : {
        "other_bucket_key": "other_messages",                //不在過濾條件范圍內的文檔都歸屬于 other_messages 桶
        "filters" : {                                        //過濾條件
          "errors" :   { "term" : { "body" : "error"   }},   
          "warnings" : { "term" : { "body" : "warning" }}
        }
      },
      "aggs" : {
        "monthly" : {
          "histogram" : {
            "field" : "timestamp",
            "interval" : "1M"
          }
        }
      }
    }
  }
}

Filter Aggregation(single-bucket)

過濾聚合——基于一個條件,來對當前的文檔進行過濾的聚合。


{
    "aggs" : {
        "red_products" : {
            "filter" : { "term": { "color": "red" } },
            "aggs" : {
                "avg_price" : { "avg" : { "field" : "price" } }
            }
        }
    }
}

IPv4 Range Aggregation(multi-bucket)

IP4聚合——基于一個 IPv4 字段,對文檔進行【IPv4范圍】的桶分聚合。

和 Range Aggregation 類似,只是應用字段必須是 IPv4 數據類型。


{
    "aggs" : {
        "ip_ranges" : {
            "ip_range" : {
                "field" : "ip",
                "ranges" : [                                //包含 3 個桶,各個桶之間可能有文檔重復
                    { "to" : "10.0.0.5" },
                    { "from" : "10.0.0.5" },
                    { "from":"1.1.1.1", "to" : "10.0.0.5" },
                ]
            }
        }
    }
}

Nested Aggregation(single-bucket)

嵌套類型聚合——基于嵌套(nested)數據類型,把該【嵌套類型的信息】聚合到單個桶里,然后就可以對嵌套類型做進一步的聚合操作。


// resellers 是一個嵌套類型
{
    ...
    "product" : {
        "properties" : {
            "resellers" : { 
                "type" : "nested",
                "properties" : {
                    "name" : { "type" : "string" },
                    "price" : { "type" : "double" }
                }
            }
        }
    }
}
// 對 nested 對象里面的信息做其它聚合操作
{
    "query" : {
        "match" : { "name" : "led tv" }
    },
    "aggs" : {
        "resellers" : {
            "nested" : {                           //"嵌套類型聚合"把所有嵌套信息都包含在單一的桶里,以供進一步處理
                "path" : "resellers"
            },
            "aggs" : {
                "min_price" : { "min" : { "field" : "resellers.price" } }   //對嵌套類型聚合輸出的桶做進一步處理,這里是計算其 price 的 average
            }
        }
    }
}

4 pipeline aggregations

概述

管道聚合處理的對象是其它聚合的輸出(桶或者桶的某些權值),而不是直接針對文檔。

管道聚合的作用是為輸出增加一些有用信息。

管道聚合大致分為兩類:

parent

此類聚合的"輸入"是其【父聚合】的輸出,并對其進行進一步處理。一般不生成新的桶,而是對父聚合桶信息的增強。

sibling

此類聚合的輸入是其【兄弟聚合】的輸出。并能在同級上計算新的聚合。

管道聚合通過 buckets_path 參數指定他們要進行聚合計算的權值對象,buckets_path 參數有其自己的使用語法。

管道聚合不能包含子聚合,但是某些類型的管道聚合可以鏈式使用(比如計算導數的導數)。

bucket_path語法

1. 聚合分隔符 ==>">",指定父子聚合關系,如:"my_bucket>my_stats.avg"

2. 權值分隔符 ==>".",指定聚合的特定權值

3. 聚合名稱 ==> <name of the aggregation> ,直接指定聚合的名稱

4. 權值 ==> <name of the metric> ,直接指定權值

5. 完整路徑 ==>agg_name[> agg_name]*[. metrics] ,綜合利用上面的方式指定完整路徑

6. 特殊值 ==>"_count",輸入的文檔個數

特殊情況

1. 要進行 pipeline aggregation 聚合的對象名稱或權值名稱包含小數點

"buckets_path": "my_percentile[99.9]"

2. 處理對象中包含空桶(無文檔的桶分)

參數 gap_policy,可選值有 skip、insert_zeros

Avg Bucket Aggregation(sibliing)

桶均值聚合——基于兄弟聚合的某個權值,求所有桶的權值均值。

用于計算的兄弟聚合必須是多桶聚合。

用于計算的權值必須是數值類型。

配置參數

buckets_path:用于計算均值的權值路徑
gap_policy:空桶處理策略(skip/insert_zeros)
format:該聚合的輸出格式定義


{
    "aggs" : {
        "sales_per_month" : {
            "date_histogram" : {
                "field" : "date",
                "interval" : "month"
            },
            "aggs": {
                "sales": {
                    "sum": {
                        "field": "price"
                    }
                }
            }
        },
        "avg_monthly_sales": {
            "avg_bucket": {             //對所有月份的銷售總 sales 求平均值
                "buckets_path": "sales_per_month>sales" 
            }
        }
    }
}

Derivative Aggregation(parent)

求導聚合——基于父聚合(只能是histogram或date_histogram類型)的某個權值,對權值求導。

用于求導的權值必須是數值類型。

封閉直方圖(histogram)聚合的 min_doc_count 必須是 0。

配置參數

buckets_path:用于計算均值的權值路徑
gap_policy:空桶處理策略(skip/insert_zeros)
format:該聚合的輸出格式定義


{
    "aggs" : {
        "sales_per_month" : {
            "date_histogram" : {
                "field" : "date",
                "interval" : "month"
            },
            "aggs": {
                "sales": {
                    "sum": {
                        "field": "price"
                    }
                },
                "sales_deriv": {       //對每個月銷售總和 sales 求導
                    "derivative": {
                        "buckets_path": "sales"  //同級,直接用 metric 值
                    }
                }
            }
        }
    }
}


Max Bucket Aggregation(sibling)

桶最大值聚合——基于兄弟聚合的某個權值,輸出權值最大的那一個桶。

用于計算的權值必須是數值類型。

用于計算的兄弟聚合必須是多桶聚合類型。

配置參數

buckets_path:用于計算均值的權值路徑
gap_policy:空桶處理策略(skip/insert_zeros)
format:該聚合的輸出格式定義

Min Bucket Aggregation(sibling)

桶最小值聚合——基于兄弟聚合的某個權值,輸出權值最小的一個桶。

用于計算的權值必須是數值類型。

用于計算的兄弟聚合必須是多桶聚合類型。

配置參數

buckets_path:用于計算均值的權值路徑
gap_policy:空桶處理策略(skip/insert_zeros)
format:該聚合的輸出格式定義

Sum Buchet Aggregation(sibling)

桶求和聚合——基于兄弟聚合的權值,對所有桶的權值求和。

用于計算的權值必須是數值類型。

用于計算的兄弟聚合必須是多桶聚合類型。

配置參數

buckets_path:用于計算均值的權值路徑
gap_policy:空桶處理策略(skip/insert_zeros)
format:該聚合的輸出格式定義


{
    "aggs" : {
        "sales_per_month" : {
            "date_histogram" : {
                "field" : "date",
                "interval" : "month"
            },
            "aggs": {
                "sales": {
                    "sum": {
                        "field": "price"
                    }
                }
            }
        },
        "max_monthly_sales": {        //輸出兄弟聚合 sales_per_month 的每月銷售總和 sales 的最大一個桶
            "max_bucket": {
                "buckets_path": "sales_per_month>sales" 
            }
        },
        "min_monthly_sales": {         //輸出兄弟聚合 sales_per_month 的每月銷售總和 sales 的最小一個桶
            "min_bucket": {
                "buckets_path": "sales_per_month>sales" 
            }
        },
        "sum_monthly_sales": {         //輸出兄弟聚合 sales_per_month 的每月銷售總和 sales 的最小一個桶
            "sum_bucket": {
                "buckets_path": "sales_per_month>sales" 
            }
        }
    }
}

Stats Bucket Aggregation(sibling)

桶統計信息聚合——基于兄弟聚合的某個權值,對【桶的信息】進行一些統計學運算(總計多少個桶、所有桶中該權值的最大值、最小等)。

用于計算的權值必須是數值類型。

用于計算的兄弟聚合必須是多桶聚合類型。

配置參數

buckets_path:用于計算均值的權值路徑
gap_policy:空桶處理策略(skip/insert_zeros)
format:該聚合的輸出格式定義


{
    "aggs" : {
        "sales_per_month" : {
            "date_histogram" : {
                "field" : "date",
                "interval" : "month"
            },
            "aggs": {
                "sales": {
                    "sum": {
                        "field": "price"
                    }
                }
            }
        },
        "stats_monthly_sales": {               // 對父聚合的每個桶(每月銷售總和)的一些基本信息進行聚合
            "stats_bucket": {
                "buckets_paths": "sales_per_month>sales" 
            }
        }
    }
}
//輸出結果
{
   "aggregations": {
      "sales_per_month": {
         "buckets": [
            {
               "key_as_string": "2015/01/01 00:00:00",
               "key": 1420070400000,
               "doc_count": 3,
               "sales": {
                  "value": 550
               }
            },
            {
               "key_as_string": "2015/02/01 00:00:00",
               "key": 1422748800000,
               "doc_count": 2,
               "sales": {
                  "value": 60
               }
            },
            {
               "key_as_string": "2015/03/01 00:00:00",
               "key": 1425168000000,
               "doc_count": 2,
               "sales": {
                  "value": 375
               }
            }
         ]
      },
      "stats_monthly_sales": {        //注意,統計的是桶的信息
         "count": 3,
         "min": 60,
         "max": 550,
         "avg": 328.333333333,
         "sum": 985
      }
   }
}

Extended Stats Bucket Aggregation(sibling)

擴展桶統計聚合——基于兄弟聚合的某個權值,對【桶信息】進行一系列統計學計算(比普通的統計聚合多了一些統計值)。

用于計算的權值必須是數值類型。

用于計算的兄弟聚合必須是多桶聚合類型。

配置參數

buckets_path:用于計算均值的權值路徑
gap_policy:空桶處理策略(skip/insert_zeros)
format:該聚合的輸出格式定義
sigma:偏差顯示位置(above/below)

Percentiles Bucket Aggregation(sibling)

桶百分比聚合——基于兄弟聚合的某個權值,計算權值的百分百。

用于計算的權值必須是數值類型。

用于計算的兄弟聚合必須是多桶聚合類型。

對百分百的計算是精確的(不像Percentiles Metric聚合是近似值),所以可能會消耗大量內存

配置參數

buckets_path:用于計算均值的權值路徑
gap_policy:空桶處理策略(skip/insert_zeros)
format:該聚合的輸出格式定義
percents:需要計算的百分百列表(數組形式)

Moving Average Aggregation(parent)

窗口平均值聚合——基于已經排序過的數據,計算出處在當前出口中數據的平均值。

比如窗口大小為 5 ,對數據 1—10 的部分窗口平均值如下:

(1 + 2 + 3 + 4 + 5) / 5 = 3
(2 + 3 + 4 + 5 + 6) / 5 = 4
(3 + 4 + 5 + 6 + 7) / 5 = 5

配置參數

buckets_path:用于計算均值的權值路徑
gap_policy:空桶處理策略(skip/insert_zeros)
window:窗口大小
model:移動模型
minimize:
settings:


{
    "the_movavg":{
        "moving_avg":{
            "buckets_path": "the_sum",
            "window" : 30,
            "model" : "simple"
        }
    }
}

Cumulative Sum Aggregation(parent)

累計和聚合——基于父聚合(只能是histogram或date_histogram類型)的某個權值,對權值在每一個桶中求所有之前的桶的該值累計的和。

用于計算的權值必須是數值類型。

封閉直方圖(histogram)聚合的 min_doc_count 必須是 0。

配置參數

buckets_path:用于計算均值的權值路徑
format:該聚合的輸出格式定義


{
    "aggs" : {
        "sales_per_month" : {
            "date_histogram" : {
                "field" : "date",
                "interval" : "month"
            },
            "aggs": {
                "sales": {
                    "sum": {
                        "field": "price"
                    }
                },
                "cumulative_sales": {
                    "cumulative_sum": {
                        "buckets_path": "sales" 
                    }
                }
            }
        }
    }
}
//輸出
{
   "aggregations": {
      "sales_per_month": {
         "buckets": [
            {
               "key_as_string": "2015/01/01 00:00:00",
               "key": 1420070400000,
               "doc_count": 3,
               "sales": {
                  "value": 550
               },
               "cumulative_sales": {
                  "value": 550                //總計 sales = 550
               }
            },
            {
               "key_as_string": "2015/02/01 00:00:00",
               "key": 1422748800000,
               "doc_count": 2,
               "sales": {
                  "value": 60
               },
               "cumulative_sales": {
                  "value": 610               //總計 sales = 550 + 60
               }
            },


Bucket Script Aggregation(parent)

桶腳本聚合——基于父聚合的【一個或多個權值】,對這些權值通過腳本進行運算。

用于計算的父聚合必須是多桶聚合。

用于計算的權值必須是數值類型。

執行腳本必須要返回數值型結果。

配置參數

script:用于計算的腳本,腳本可以是 inline,也可以是 file,還可以是Scripting指定的
buckets_path:用于計算均值的權值路徑
gap_policy:空桶處理策略(skip/insert_zeros)
format:該聚合的輸出格式定義


{
    "aggs" : {
        "sales_per_month" : {
            "date_histogram" : {
                "field" : "date",
                "interval" : "month"
            },
            "aggs": {
                "total_sales": {
                    "sum": {
                        "field": "price"
                    }
                },
                "t-shirts": {
                  "filter": {
                    "term": {
                      "type": "t-shirt"
                    }
                  },
                  "aggs": {
                    "sales": {
                      "sum": {
                        "field": "price"
                      }
                    }
                  }
                },
                "t-shirt-percentage": {
                    "bucket_script": {
                        "buckets_path": {                    //對兩個權值進行計算
                          "tShirtSales": "t-shirts>sales",
                          "totalSales": "total_sales"
                        },
                        "script": "tShirtSales / totalSales * 100"
                    }
                }
            }
        }
    }
}


Bucket Selector Aggregation(parent)

桶選擇器聚合——基于父聚合的【一個或多個權值】,通過腳本對權值進行計算,并決定父聚合的哪些桶需要保留,其余的將被丟棄。

用于計算的父聚合必須是多桶聚合。

用于計算的權值必須是數值類型。

運算的腳本必須是返回 boolean 類型,如果腳本是腳本表達式形式給出,那么允許返回數值類型。

配置參數

script:用于計算的腳本,腳本可以是 inline,也可以是 file,還可以是Scripting指定的
buckets_path:用于計算均值的權值路徑
gap_policy:空桶處理策略(skip/insert_zeros)


{
    "bucket_selector": {
        "buckets_path": {
            "my_var1": "the_sum", 
            "my_var2": "the_value_count"
        },
        "script": "my_var1 > my_var2"    // true 則保留該桶;false 則丟棄
    }
}

Serial Differencing Aggregation(parent)

串行差分聚合——基于父聚合(只能是histogram或date_histogram類型)的某個權值,對權值值進行差分運算,(取時間間隔,后一刻的值減去前一刻的值:f(X) = f(Xt) – f(Xt-n))。

用于計算的父聚合必須是多桶聚合。

配置參數

lag:滯后間隔(比如lag=7,表示每次從當前桶的值中減去其前面第7個桶的值)
buckets_path:用于計算均值的權值路徑
gap_policy:空桶處理策略(skip/insert_zeros)
format:該聚合的輸出格式定義


{
   "aggs": {
      "my_date_histo": {                  
         "date_histogram": {
            "field": "timestamp",
            "interval": "day"
         },
         "aggs": {
            "the_sum": {
               "sum": {
                  "field": "lemmings"     
               }
            },
            "thirtieth_difference": {
               "serial_diff": {                
                  "buckets_path": "the_sum",
                  "lag" : 30                        //差分間隔為 30 day
               }
            }
         }
      }
   }
}


正因為當初對未來做了太多的憧憬,所以對現在的自己尤其失望。生命中曾經有過的所有燦爛,終究都需要用寂寞來償還。

總結

以上是生活随笔為你收集整理的ES aggregation详解的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

中文字幕免费高清在线观看 | 国产欧美精品一区二区三区四区 | 亚洲特级片 | 成人国产精品久久久春色 | 久久精品国产成人精品 | 精品福利片 | 国产精品免费在线 | www在线免费观看 | 91久久精品一区 | japanesefreesex中国少妇 | 亚洲高清视频在线 | 天天色天天干天天 | 久久91网 | 超碰人在线 | 国产精品久久久久久妇 | 久久九九久久 | 国产精品综合在线观看 | 中文字幕在线观看视频一区二区三区 | 欧美一级黄色网 | 日韩一区在线播放 | 国产伦理久久精品久久久久_ | 一区二区不卡高清 | 免费人人干 | 丁香婷婷综合激情 | 日韩特级片 | 日韩免费电影一区二区三区 | 免费三级在线 | 精品久久1 | 成全在线视频免费观看 | 成年人免费看片网站 | 国产一区二区在线免费观看 | 在线视频一区二区 | 日韩免费三区 | 97超碰色偷偷 | 五月婷婷激情 | 91大片网站 | 精品福利av| 久久激情久久 | 久草视频资源 | 久久在线视频在线 | 国产一区在线播放 | 成x99人av在线www | 国色天香第二季 | 免费观看www小视频的软件 | av黄色亚洲 | 国产剧情一区二区在线观看 | 成人黄色av网站 | 国产高清绿奴videos | 99中文在线 | 玖玖国产精品视频 | 在线观看午夜av | 狠狠色丁香婷婷综合久小说久 | 国产 一区二区三区 在线 | 精壮的侍卫呻吟h | 久久精品看片 | 国产成人精品一区二区三区在线观看 | 国产一二区免费视频 | 天天色婷婷 | 91免费网址| 色婷婷骚婷婷 | 免费观看国产视频 | 成人91在线 | 亚洲最新视频在线播放 | 丁香六月在线 | 日韩成人免费在线观看 | 91精品免费在线 | 免费观看日韩av | 黄色毛片在线看 | 在线看黄色的网站 | 日韩精品一区二区免费视频 | 久久激情久久 | 丁香六月激情婷婷 | 又黄又爽的视频在线观看网站 | 国产999免费视频 | 成人av久久 | 日韩中文字幕在线看 | 香蕉影院在线播放 | 国产精品久久久久久久久久久久久久 | 亚洲色图美腿丝袜 | 日本黄色片一区二区 | 97韩国电影 | 亚洲精品视频在线观看网站 | 国产精品毛片久久蜜 | 人人爽人人爽人人爽人人爽 | 国产三级午夜理伦三级 | 亚洲精品在线一区二区三区 | 免费涩涩网站 | 精品在线播放视频 | 国产色啪| 欧美激情h | av三级在线播放 | 91免费看黄 | 狠狠狠狠狠狠天天爱 | 中文字幕一区二 | 在线观看av麻豆 | 国内精品久久久久影院一蜜桃 | 91麻豆看国产在线紧急地址 | 伊人久久在线观看 | 一区二区三区中文字幕在线观看 | 精品99在线 | 伊人资源视频在线 | 欧美91精品 | 国产精品嫩草在线 | 丝袜制服天堂 | 日日夜夜骑 | 97超碰国产精品女人人人爽 | 日韩在线免费小视频 | 五月婷婷另类国产 | 青青久视频 | 99精品视频在线播放观看 | 色噜噜在线观看 | 欧美人人 | 黄色在线成人 | 色偷偷人人澡久久超碰69 | 精品不卡av | 色小说av| 日韩一区二区三区免费电影 | 丁香高清视频在线看看 | 国产手机视频在线 | 精品国精品自拍自在线 | 日韩一区二区三区免费视频 | 成年人视频免费在线播放 | 天天操夜夜叫 | 国产一区二区精品 | 国产精品3| 日韩综合精品 | 日韩欧美精选 | 欧美巨乳波霸 | 久久手机在线视频 | 成人动漫一区二区 | 国产精品久久av | 午夜精品一区二区三区在线 | 亚洲精品视频在线播放 | 成人a在线| 青春草视频在线播放 | 午夜三级大片 | 久久成人综合视频 | 久久久伦理 | 婷婷五天天在线视频 | 91高清完整版在线观看 | av色图天堂网| 欧美一区免费观看 | 狠狠狠狠狠狠狠干 | 久久曰视频| 在线国产欧美 | 欧美一区二区在线免费看 | 操碰av | 性色av免费观看 | 国产黄色一级片在线 | av在线免费播放 | 国产精品原创av片国产免费 | 97视频免费在线看 | 日本中文不卡 | 久久久久亚洲国产 | 黄色三级免费网址 | 欧美另类69 | 亚洲精欧美一区二区精品 | .国产精品成人自产拍在线观看6 | 日韩免费一区 | 国产精品久久久久永久免费观看 | 天天干天天干天天射 | 热久久99这里有精品 | 中文免费| 国产精品久久久久久久婷婷 | 成人av高清| 91激情视频在线 | 国产亚洲精品久久久久久网站 | 亚洲一级片av | 久久视频精品在线观看 | www.在线观看视频 | 久久久精品 一区二区三区 国产99视频在线观看 | 黄网站色欧美视频 | 欧美一级特黄aaaaaa大片在线观看 | 国产成人久久精品 | 五月婷婷.com| 激情五月婷婷激情 | 99re久久资源最新地址 | 午夜精品剧场 | 一本大道久久精品懂色aⅴ 五月婷社区 | 中文国产字幕在线观看 | 日韩在线观看视频免费 | 中文字幕在线观看一区二区三区 | 一区二区视频在线播放 | 国产精品国产自产拍高清av | 精品久久久网 | 久久久久久国产一区二区三区 | 欧美一级看片 | 日韩激情在线视频 | 在线黄色av电影 | 在线免费观看国产精品 | 国产精品2019 | 日韩av区 | 精品视频区 | 日韩三级.com | 日韩动漫免费观看高清完整版在线观看 | 久久新视频 | 综合天天网 | 国产精品2020 | 国产精品久久久久久久免费观看 | 久久婷亚洲五月一区天天躁 | 国产专区一 | 亚州精品在线视频 | 成人app在线免费观看 | 国产精品美 | 国产精品区在线观看 | 免费av福利 | 亚洲精品乱码久久久久v最新版 | 波多野结衣理论片 | 中文视频在线 | 少妇精品久久久一区二区免费 | 日韩欧美在线观看一区二区 | 亚洲综合视频在线 | 国产精品久久久久久一区二区 | 国产精品普通话 | 永久免费的av电影 | 国产在线高清精品 | 97超碰人人干 | 国产淫片| 欧美日韩亚洲在线 | 在线观看日韩视频 | 国产二级视频 | 性色av免费看 | 激情开心网站 | 成人午夜黄色 | 日韩精品在线播放 | 波多野结衣一区二区 | av网站免费看 | av片在线观看免费 | 日韩羞羞| 操操操日日 | 国产精品一区二区三区四区在线观看 | 国产手机视频在线观看 | 欧美激情视频在线免费观看 | 国产精品久久久久国产精品日日 | 中文字幕亚洲欧美日韩 | 日韩精品一二三 | 久久国内视频 | 91人人揉日日捏人人看 | 美女精品国产 | 五月婷在线观看 | 久草资源在线观看 | 国产婷婷久久 | 亚洲最新精品 | 中文字幕区| 97超视频免费观看 | 99精品国产99久久久久久97 | 久久视频在线视频 | 久久视频二区 | 久草视频在 | 在线观看不卡视频 | 国产伦理久久 | 99在线观看免费视频精品观看 | 好看的国产精品视频 | 久草av在线播放 | 国产免码va在线观看免费 | 天天天天爽 | 在线免费观看涩涩 | 久久国产一区 | 992tv在线| 成人午夜电影在线观看 | 色五婷婷 | 久久久噜噜噜久久久 | 波多野结衣网址 | 日韩高清无线码2023 | 亚洲天堂网视频在线观看 | 国产精品入口麻豆www | 欧美日韩一区二区在线 | 久久99亚洲精品久久久久 | 精品黄色片 | 国产精品久久久 | 天天操天天射天天爽 | 国产中文字幕视频在线观看 | 91漂亮少妇露脸在线播放 | 天天操天天综合网 | 91成人天堂久久成人 | 草在线视频 | 92精品国产成人观看免费 | 亚洲成人免费观看 | 久久精品亚洲综合专区 | 91完整版 | 性色xxxxhd | 日韩av免费观看网站 | 色资源二区在线视频 | 国产最新福利 | 日本中文字幕在线视频 | 日韩啪啪小视频 | 欧美成人手机版 | 久久天天躁狠狠躁亚洲综合公司 | 麻豆果冻剧传媒在线播放 | 日本资源中文字幕在线 | 97久久精品午夜一区二区 | 最近中文字幕免费观看 | 成人在线视频你懂的 | 久久综合免费视频影院 | 亚洲欧美日韩一二三区 | 狠狠躁日日躁夜夜躁av | 国产精品9区 | 国产伦精品一区二区三区无广告 | 欧美天天综合网 | 午夜视频久久久 | 91免费在线视频 | 久草在线中文视频 | 国产视频一区精品 | 国产精品video爽爽爽爽 | 一区二区三区四区五区在线 | 伊人伊成久久人综合网站 | 色噜噜狠狠狠狠色综合 | 欧美日韩99 | 天天摸天天干天天操天天射 | 丁香六月av | 精品亚洲免a | 一区二区三区免费在线观看 | 激情久久久久久久久久久久久久久久 | 97精产国品一二三产区在线 | 99精品一区二区三区 | 日日插日日干 | 中文字幕成人在线 | 久久人人97超碰com | 夜夜躁日日躁狠狠久久88av | 久久人人爽人人片av | 成人av一二三区 | 国产午夜三级一区二区三桃花影视 | 久久精品国产亚洲精品 | 亚洲精品一区二区精华 | 99热9| 在线视频手机国产 | 亚洲午夜av电影 | 精品视频在线观看 | 久久99精品国产麻豆婷婷 | 日本黄色大片免费 | 亚洲三级性片 | 国产精品乱码久久 | 免费在线国产精品 | 激情欧美丁香 | 久久99久久99精品 | 久久综合中文色婷婷 | 中文字幕一区在线 | 99 精品 在线 | 色在线免费观看 | 久久久久久久久久久久久久电影 | 免费观看9x视频网站在线观看 | 人人狠狠综合久久亚洲 | 久草国产在线 | 国产免费不卡av | 亚洲精品大全 | 97成人在线免费视频 | 96av在线| 国产成a人亚洲精v品在线观看 | 色婷婷免费视频 | 日韩中文字幕视频在线观看 | 亚洲一级免费电影 | 欧美精品在线视频 | 激情网色 | 中文av不卡| 成年人在线看视频 | 天天插日日插 | 欧美精品一二 | 精品国产亚洲一区二区麻豆 | 亚洲欧洲日韩在线观看 | 激情影院在线 | 免费在线一区二区 | 日韩视频一区二区三区 | 色a综合 | 天天色天天综合 | 视频在线观看99 | 国产福利一区二区三区在线观看 | 久久久国产精品免费 | 2019中文在线观看 | 在线视频 91 | 国产精品99久久久久久小说 | 成人久久视频 | 日韩一区二区三区高清在线观看 | 免费日韩电影 | 精品日韩av| 99爱在线| 亚洲狠狠 | 日韩午夜电影院 | www.色综合.com | 99免费在线观看视频 | 91国内产香蕉 | 丁香久久五月 | 伊人婷婷| 中文字幕永久免费 | 日韩欧美视频一区 | 在线亚洲精品 | 婷婷在线免费观看 | 精品国产电影 | 天天色婷婷 | 国产精品18久久久久久久久久久久 | a午夜在线 | 视频一区二区三区视频 | 国产一区自拍视频 | 999久久a精品合区久久久 | 在线观看国产www | 国产高清视频免费最新在线 | 国产一区在线免费 | 精品国产一区二区三区久久 | 91亚洲精品久久久中文字幕 | 中文字幕色在线 | 69av免费视频 | 国产成本人视频在线观看 | 日躁夜躁狠狠躁2001 | 欧美一区二区视频97 | av免费电影网站 | 久久久99精品免费观看乱色 | 香蕉视频在线观看免费 | 欧美极品在线播放 | 91精品久久久久久久91蜜桃 | 黄网站色视频 | 精品国产亚洲日本 | 欧美一二区在线 | 97色国产 | 在线观看av不卡 | 国产欧美精品xxxx另类 | 中文在线字幕免费观看 | 一区二区丝袜 | 天天玩夜夜操 | 91人人澡人人爽人人精品 | 久久综合狠狠综合久久综合88 | 天天插天天狠天天透 | 国产一二三精品 | 日韩网站免费观看 | 久久精品久久久久 | 久久亚洲影院 | 成人91在线 | 婷婷色中文字幕 | 五月天伊人 | 夜色在线资源 | 久久国产精品系列 | 99精品国产兔费观看久久99 | 黄色大片视频网站 | 最新中文字幕在线观看视频 | 亚洲专区欧美专区 | 国产黄a三级三级 | 在线91精品| 日韩在线中文字幕视频 | 婷婷在线资源 | 日韩在线短视频 | 91尤物国产尤物福利在线播放 | 91九色视频导航 | 久久成人高清视频 | 欧美日韩午夜爽爽 | 成片免费| 特黄特色特刺激视频免费播放 | 国产精品久久久久三级 | 亚洲午夜精品久久久久久久久 | 久久久久久久久久久久国产精品 | 91日韩在线专区 | 三级视频日韩 | 色综合久久久久综合 | 久久激情日本aⅴ | 中文字幕一区在线 | 91精选在线 | 久久视频在线视频 | 综合久久久久久久 | 国产精品福利无圣光在线一区 | 国产成人一级电影 | 色资源在线| 久久人人爽人人爽人人片av免费 | 中日韩三级视频 | 久久伊人五月天 | 中文字幕有码在线观看 | 美女在线观看网站 | www.久久久com | av线上看 | 国产在线国偷精品产拍 | 婷婷六月综合网 | 免费日韩三级 | 日本最大色倩网站www | 欧美aaa视频 | 天天综合网天天综合色 | 在线观看国产v片 | 亚洲精品在线观看不卡 | 久草在线欧美 | 人人爽人人爽人人片av免 | 91在线麻豆 | 最近日本韩国中文字幕 | 国产视频91在线 | 国产伦理久久 | 国产亚洲在线 | 欧美性猛片,| 天天婷婷 | 日韩一区二区三区高清免费看看 | 在线观看日本高清mv视频 | 日韩三级视频 | 黄色av一级 | 成人免费共享视频 | 欧美在线视频第一页 | 国产99久久久国产精品免费看 | 涩涩网站在线 | 国产污视频在线观看 | 欧美日韩亚洲国产一区 | 久久中文字幕视频 | 综合网婷婷 | 97人人模人人爽人人少妇 | av黄色一级片 | 精品国产欧美一区二区 | 国产精品一区二区三区在线播放 | 午夜精品久久久久久久99热影院 | 免费毛片aaaaaa | 在线观看福利网站 | 蜜臀久久99静品久久久久久 | 欧美一区二区伦理片 | 久久久久高清毛片一级 | 亚洲va在线va天堂va偷拍 | 91av成人 | 欧美精品在线观看免费 | 日本免费久久高清视频 | 99久久er热在这里只有精品15 | 欧美一区二区视频97 | 超碰在线cao | 国产黄网在线 | 18久久久 | 成人av一区二区兰花在线播放 | 国产伦精品一区二区三区四区视频 | 97av在线视频| 久久香蕉一区 | 婷婷福利影院 | 亚洲精品在线观看免费 | 一级片观看| 国产在线p| 欧美成人基地 | 国产蜜臀av | 一级片观看 | 亚洲精品综合一区二区 | 国产精品久久久久9999 | 五月天激情视频 | 欧美在线视频a | www看片网站| 2020天天干夜夜爽 | 99久久国产免费,99久久国产免费大片 | 91久久国产露脸精品国产闺蜜 | 欧美 另类 交| www.99av | 91粉色视频 | 91香蕉视频污在线 | 成人免费在线观看av | 五月婷婷,六月丁香 | 美女精品在线观看 | 在线免费观看不卡av | www.亚洲黄| 久久综合九色99 | 久久免费99精品久久久久久 | 久久精品视频免费观看 | 麻豆国产在线播放 | 六月婷色 | 国产亚洲精品成人av久久ww | 国产精品va在线观看入 | 欧美国产高清 | 在线免费国产视频 | 亚洲精品成人免费 | 久久手机免费观看 | 亚洲欧美视频在线播放 | 天天躁天天躁天天躁婷 | 精品视频在线播放 | 99久久婷婷国产精品综合 | 97热在线观看 | 中文在线字幕免费观看 | 天天做天天爱天天爽综合网 | 亚洲精品视频在线免费播放 | 激情综合色综合久久综合 | 激情综合五月天 | 国产欧美精品xxxx另类 | 国内精品在线观看视频 | 国产精品电影一区二区 | 亚洲一级黄色av | 天天操天天干天天操天天干 | 国产91成人在在线播放 | 久久av中文字幕片 | 中文字幕欧美日韩va免费视频 | 国产伦精品一区二区三区无广告 | 免费观看一级 | a级国产乱理伦片在线播放 久久久久国产精品一区 | 国产美女视频网站 | 日韩网站在线免费观看 | 久久精品美女 | 五月综合激情网 | а天堂中文最新一区二区三区 | 在线看国产视频 | 中文字幕一区二区三 | 香蕉免费 | 欧美性极品xxxx娇小 | 日本一区二区高清不卡 | 在线激情小视频 | 天天色天天上天天操 | 精品久久久久久久久久久久 | 在线观看日本高清mv视频 | 亚洲九九九在线观看 | 日本中文字幕免费观看 | 中文字幕一区二区三区乱码不卡 | 欧美精品资源 | 丰满少妇一级片 | 在线观看中文字幕一区二区 | 久久综合狠狠狠色97 | 国产做爰视频 | 免费成人在线电影 | 日韩高清在线不卡 | 中文字幕一区二区三区四区视频 | 国内精品亚洲 | 少妇bbr搡bbb搡bbb | 99热这里只有精品在线观看 | 亚洲视频 视频在线 | 国产亚洲aⅴaaaaaa毛片 | 欧美激情精品久久久久久免费印度 | 美女免费视频观看网站 | 免费看的黄色录像 | 一区二区三区日韩在线观看 | 亚洲女裸体 | 在线观看视频97 | 国产精品video爽爽爽爽 | 亚洲资源| 欧美视频国产视频 | 亚洲精品乱码久久久久久蜜桃91 | 91手机视频在线 | 国产精品网址在线观看 | 亚在线播放中文视频 | 国产精品com | 99久久精品免费看国产一区二区三区 | 久久66热这里只有精品 | 麻豆91在线播放 | 丁香综合网 | 激情网站网址 | 日本精品视频在线播放 | 激情五月婷婷网 | 精品国模一区二区三区 | 精品欧美小视频在线观看 | 黄网站免费大全入口 | 中文字幕永久免费 | 日p视频在线观看 | www.久久久.com| 日韩精品一区二区在线观看视频 | 亚洲欧美成人网 | 99理论片| 日韩一区二区三区在线看 | 国产伦精品一区二区三区高清 | 伊人视频 | 91九色国产 | 69视频在线| 日韩性片 | 激情偷乱人伦小说视频在线观看 | 97国产精品久久 | 视频一区在线免费观看 | 日韩在线观看三区 | av大全在线| 日本婷婷色 | 欧美成人91 | 久久人人爽人人爽人人片av软件 | 国产精品久免费的黄网站 | 911国产精品| 国产极品尤物在线 | 91av网站在线观看 | 久久不见久久见免费影院 | 久久人人精| 久草在线资源观看 | 国产伦理久久精品久久久久_ | 在线观看视频黄 | 日韩精品一区在线观看 | av解说在线观看 | 一 级 黄 色 片免费看的 | 九色91在线视频 | 91字幕| 亚洲经典中文字幕 | 中文字幕一区二区三区四区 | 精品福利在线视频 | 精品九九九 | 国产在线不卡 | 国产精品69av| 激情网色 | 欧美午夜精品久久久久久浪潮 | 欧美日韩啪啪 | 久久国产经典视频 | av中文字幕第一页 | 久久综合给合久久狠狠色 | 新版资源中文在线观看 | 射九九| 久久久久久黄色 | 精品久久1| 99精品视频在线播放免费 | 丁香五婷| 国产一区二区在线免费播放 | 高潮久久久久久久久 | 久久久久久久久久久电影 | 美女视频黄免费网站 | 精品国产一区二区三区久久久 | 99在线视频免费观看 | 91在线产啪| 狠狠干中文字幕 | 欧美亚洲另类在线视频 | 国内精品亚洲 | 九九热精品国产 | 最新av在线免费观看 | 在线久久 | 亚洲美女视频网 | 97精品国产97久久久久久 | 亚洲精品久久久久中文字幕m男 | 久草视频在线新免费 | 麻豆mv在线观看 | 日韩丝袜 | 日韩1页| 色婷婷99| 狠狠狠狠狠狠狠 | 婷婷激情av| 免费高清男女打扑克视频 | 国产一区自拍视频 | 国产涩涩在线观看 | 亚洲美女精品视频 | 国产69精品久久久久99尤 | 婷婷亚洲最大 | 国产高清在线看 | 综合伊人久久 | 国产亚洲免费的视频看 | 国内精品久久久精品电影院 | 国产第一页福利影院 | 视频成人永久免费视频 | 在线亚洲观看 | 蜜臀av性久久久久蜜臀aⅴ流畅 | 亚洲综合一区二区精品导航 | 久久综合色影院 | 97超视频免费观看 | av成人动漫 | 人人超碰人人 | 欧美精品999 | 玖玖视频网 | 色婷婷精品大在线视频 | 色综合五月天 | 久热av在线 | 欧美激情精品久久久 | 久久99在线视频 | 国产亚洲精品久久久久久大师 | 91探花在线视频 | av亚洲产国偷v产偷v自拍小说 | 天天添夜夜操 | 黄av在线 | 国产精品国产毛片 | 久久99最新地址 | 深夜免费小视频 | 麻豆传媒视频在线免费观看 | 国产精品视频永久免费播放 | www国产一区 | 999视频精品 | 成人免费视频播放 | 亚洲国产日本 | 午夜精品久久久久久 | 日韩三级不卡 | 免费三级影片 | 激情欧美日韩一区二区 | 高清av免费观看 | 亚洲黄色成人 | 精品国产乱码久久久久久三级人 | 免费在线激情视频 | 玖玖爱免费视频 | 婷婷久月 | 天天色天 | 日韩精品中文字幕有码 | 视频福利在线观看 | 深爱激情久久 | 成人黄色电影在线观看 | 久久精品免视看 | 青春草视频 | 精品欧美日韩 | 国产在线黄 | 亚洲www天堂com | 视频91在线| 天天射天天干天天操 | 99久久精品免费看国产免费软件 | 成人一级片在线观看 | 丁香六月综合网 | 在线观看视频三级 | 五月婷婷丁香激情 | 91资源在线视频 | 人人添人人澡 | 人人搞人人干 | 国产精品女 | 国产精品免费大片视频 | 超碰个人在线 | 一区二区电影在线观看 | 九九欧美视频 | 午夜精品电影 | 国产手机在线播放 | 久久99精品久久久久久久久久久久 | 九九精品视频在线看 | 天天操天天拍 | 国产女人40精品一区毛片视频 | 国产一区在线看 | 日韩在线视频一区 | 少妇性xxx | 最新av在线网址 | 人人爽人人片 | 又污又黄的网站 | 日本不卡一区二区三区在线观看 | 久草国产视频 | 国产精品久久久久久久久久久免费 | 色网站在线观看 | 亚洲做受高潮欧美裸体 | 日韩精品在线看 | 2019中文字幕网站 | 中文字幕丝袜 | 亚洲一区日韩精品 | 黄色一级免费电影 | 国产手机视频在线播放 | 波多野结衣一区 | 国产99久久九九精品 | 国产亚洲欧美在线视频 | 视频国产在线观看18 | 99一级片 | 韩国在线视频一区 | 亚洲婷婷在线视频 | 探花视频免费观看 | 欧美另类xxx | 波多野结衣视频一区二区三区 | 国产精品mm | 在线小视频 | 又黄又爽又色无遮挡免费 | 亚洲国产免费 | 在线电影日韩 | 狠狠操综合网 | 国产精品正在播放 | 在线视频 影院 | 玖玖视频网 | 国产精品久久久毛片 | av爱干| 激情五月婷婷综合网 | 亚洲欧美日本国产 | 在线直播av | 夜色资源站国产www在线视频 | 久久久精品国产一区二区 | 国产精品成人久久久久久久 | av黄色在线播放 | 欧美日韩中字 | 黄色av电影一级片 | 夜夜躁狠狠躁日日躁视频黑人 | 美女视频又黄又免费 | 六月色丁 | 99视频精品 | 免费在线观看一区 | 久久不色 | 在线成人中文字幕 | 国产精品成人av在线 | 黄p在线播放| 国产精品欧美久久久久三级 | 久草香蕉在线视频 | 91麻豆.com | 国产在线观看国语版免费 | 少妇bbb搡bbbb搡bbbb′ | 久久国产色 | 一级a性色生活片久久毛片波多野 | 91精品天码美女少妇 | 久久视频在线看 | 免费看的av片 | 国产真实精品久久二三区 | 亚洲精品五月 | 久久9视频 | 久久精品一区二区三区四区 | 青青草国产精品视频 | 91精品一区二区三区久久久久久 | 东方av在线免费观看 | 伊人婷婷| 国产分类视频 | 9999精品视频 | av不卡在线看 | 久久国产影院 | 国产精品视频一二三 | 九九精品视频在线观看 | 亚洲九九九在线观看 | 国产精品久久久久久一区二区 | 久草在线免费电影 | 一区二区三区国 | 在线观看日本高清mv视频 | 欧美高清视频不卡网 | 国产1级毛片 | 在线午夜av| 亚洲成av片人久久久 | 69国产盗摄一区二区三区五区 | 色综合网在线 | 国产精品久久久区三区天天噜 | 青青草国产精品 | 久久再线视频 | 国内精品久久久久久久久久久久 | 久久久精品国产一区二区电影四季 | 免费97视频 | 中文字幕高清av | 久久草网站 | 狠狠干 狠狠操 | 国产精品不卡在线播放 | 久久精品之 | 中文在线www | 欧美一二三区在线播放 | 五月天.com | 成人九九视频 | 久草在线综合 | 国产黄色精品在线观看 | 欧美性成人 | 国产精品美女www爽爽爽视频 | 日韩av手机在线观看 | 伊人天天狠天天添日日拍 | 色片网站在线观看 | 91在线看 | 最近中文国产在线视频 | 日日夜夜综合网 | 欧美精品国产综合久久 | 亚洲精品视频在线看 | 超碰97公开| 久久躁日日躁aaaaxxxx | 91精品久久久久久综合五月天 | 亚洲黄污| 九色琪琪久久综合网天天 | 亚洲精品短视频 | 国产成人久久精品亚洲 | 2020天天干天天操 | 国产免费又粗又猛又爽 | 日韩理论片在线 | 国产日韩在线观看一区 | 69av免费视频| 久久综合色天天久久综合图片 | 麻豆免费视频网站 | 又色又爽又黄高潮的免费视频 | 91精品国产91久久久久久三级 | 91精品秘密在线观看 | 欧美精品一区二区在线观看 | 日韩精品一区二区在线 | 日本在线视频网址 | 一 级 黄 色 片免费看的 | 亚洲综合欧美激情 | 草在线 | 极品久久久 | 色黄www小说 | 日韩理论在线播放 | 久久亚洲国产精品 | 精品国产诱惑 | 日本中出在线观看 | 亚洲精品久久久久久中文传媒 | 日韩videos高潮hd| 蜜桃av观看 | 最近中文字幕高清字幕在线视频 | 日韩av片在线 | 97av影院| 久久久精品 一区二区三区 国产99视频在线观看 | 日韩xxxx视频| 日韩经典一区二区三区 | 国产精品国产三级国产不产一地 | 欧美日韩国产一区二区三区 | 日韩区欠美精品av视频 | 91丨九色丨丝袜 | 91av手机在线 | 婷婷在线网站 | 最新av在线免费观看 | 狠狠色噜噜狠狠狠合久 | 欧洲一区二区三区精品 | 日韩欧美一区二区三区免费观看 | 国产情侣一区 | 日韩理论电影在线观看 | 久草在线电影网 | 精品色综合 | 一区二区三区视频 | 久久在线观看视频 | 国内成人精品视频 | 激情电影在线观看 | 99久久婷婷国产综合精品 | 五月婷婷综合色拍 | 视频在线观看一区 | 制服丝袜一区二区 | 四虎成人av | 成年一级片 | 成人中文字幕av | 国产精品久久久久婷婷二区次 | 在线观看免费国产小视频 | 一区二区不卡高清 | 国产精品一区二区久久久 | 亚洲综合色视频 | 高潮毛片无遮挡高清免费 | 色欲综合视频天天天 | 少妇高潮冒白浆 | 国产精品久久一区二区无卡 | 91精品专区 | 99精品欧美一区二区三区黑人哦 | 99精品视频播放 | 中文久久精品 | 欧美精品v国产精品 | 97看片网| 日本久久视频 | 五月开心色 | 久久久久久久福利 | www.五月婷婷.com | 日本中文字幕在线免费观看 | 欧美性生活久久 | 五月婷av| 免费看片网址 | 天天色天天色 | 美女视频黄是免费的 | 国产日韩在线观看一区 | 欧美在线一二 | 亚洲精品在 | 国产成人一区二区三区影院在线 | 欧美一二三区在线观看 | 中文字幕日本在线 | 久久久www免费电影网 | 麻豆免费在线播放 | 特级毛片在线免费观看 |