• Elasticsearch——Rest API中的常用用法


    本篇翻译的是Elasticsearch官方文档中的一些技巧,是使用Elasticsearch必不可少的必备知识,并且适用于所有的Rest Api。

    返回数据格式化

    当在Rest请求后面添加?pretty时,结果会以Json格式化的方式显示。另外,如果添加?format=yaml结果会以树的形式显示,默认都是Flase.

    返回数据的易读性

    结尾添加?human=true,返回的数据会有很好的可读性,比如:

    • time:3600 会显示为 time:1h
    • size:1024 会显示为 1kb

    常用的Date Math

    在Elasticsearch中日期数学表达式是很常用的,在查询中经常会通过它来作为检索条件,比如range或者daterange。表达式通常会有下面几种操作:

    • +1h ,表示加上一个一个小时
    • -1d,表示减去一天
    • /d,表示向一天取整

    支持的单位也很多,比如

    • y,代表一年
    • M,代表一个月
    • w,代表一周
    • d,代表一天
    • h,代表一个小时
    • m,代表一分钟
    • s,代表一秒钟
    • ms,代表毫秒

    举个例子:

    • now+1h,表示当前时间加上一个小时,即一个小时后
    • now+1h+1m,表示当前时间加上一个小时零一分钟,即一个小时一分钟后
    • now+1h/d,表示当前时间加上一个小时,并向一天取整。
    • 2015-01-01||+1M/d,2015-01-01加上一个月,并向一天取整

    返回的内容过滤

    有时候我们可能并不想返回所有的数据,因为这样会浪费一定的空间和时间,因此需要对查询返回的结果进行过滤。所有的API都接受一个参数——filter_path,这个参数支持逗号分隔,可以同时填写多个值。

    例如,如果只想要返回查询的时间、事件的id和分值,可以像下面这样:

    curl -XGET 'localhost:9200/_search?pretty&filter_path=took,hits.hits._id,hits.hits._score'
    {
      "took" : 3,
      "hits" : {
        "hits" : [
          {
            "_id" : "3640",
            "_score" : 1.0
          },
          {
            "_id" : "3642",
            "_score" : 1.0
          }
        ]
      }
    }

    也支持*来忽略对某个字段的过滤:

    curl -XGET 'localhost:9200/_nodes/stats?filter_path=nodes.*.ho*'
    {
      "nodes" : {
        "lvJHed8uQQu4brS-SXKsNA" : {
          "host" : "portable"
        }
      }
    }

    使用**则会忽略最大长度的路径,与Spring MVC的Url匹配差不多。

    curl 'localhost:9200/_segments?pretty&filter_path=indices.**.version'
    {
      "indices" : {
        "movies" : {
          "shards" : {
            "0" : [ {
              "segments" : {
                "_0" : {
                  "version" : "5.2.0"
                }
              }
            } ],
            "2" : [ {
              "segments" : {
                "_0" : {
                  "version" : "5.2.0"
                }
              }
            } ]
          }
        },
        "books" : {
          "shards" : {
            "0" : [ {
              "segments" : {
                "_0" : {
                  "version" : "5.2.0"
                }
              }
            } ]
          }
        }
      }
    }

    注意,elasticsearch一般会直接返回一条数据的原始信息,即_source字段。如果要对_source进行过滤,可以参考下面的用法:

    curl -XGET 'localhost:9200/_search?pretty&filter_path=hits.hits._source&_source=title'
    {
      "hits" : {
        "hits" : [ {
          "_source":{"title":"Book #2"}
        }, {
          "_source":{"title":"Book #1"}
        }, {
          "_source":{"title":"Book #3"}
        } ]
      }
    }

    扁平化

    设置flat_settings 为true,会以扁平化的方式返回数据:

    {
      "persistent" : { },
      "transient" : {
        "discovery.zen.minimum_master_nodes" : "1"
      }
    }

    关于参数

    在Elastcisearch的使用中,往往要接触到各种数据类型。如果某个字段设置了固定的类型,那么当执行查询或者索引时,一些数据会发生自动的类型转换。

    Boolean

    在Es中,false、no、0、off这些值都代表false,其他的值都是true.

    Number

    所有的API都支持以字符串的方式代表JSON中的数字类型。

    Date

    支持的类型上面都说过了...

    Geo

    Geo类型主要用于地图一类的数据,这里就先不介绍了。使用方法可以参考

    模糊查询

    有的时候一些需要允许一定的模糊度,比如检索hallo可以查询到hello,这就要支持模糊查询。模糊查询可以使用fuzziness参数,它有点像range:

    -fuzziness <= fieldValue <= +fuzziness

    并且可以设置一定的模糊度,比如:

    比如,长度为:

    • 0..2,必须完全匹配
    • 3..5,可以有一个编辑距离的模糊度
    • >5,可以有两个编辑距离的模糊度

    返回结果——驼峰式

    所有的API都接受一个case参数,如果设置为camelCase,那么所有的名称都会以驼峰式的形式返回。

    查询的请求体

    除了POST请求外,其他的请求时没有请求体的。这个时候如果要执行查询,可以把参数放在Url后面。

    参考

    官方文档
    编辑距离,wiki百科

  • 相关阅读:
    spring mvc随便接收list<objeect>参数
    python django model类型摘要
    【Unity3D自我记录】解决NGUI通过问题触发事件点
    sqlcipher移植
    外键约束列并没有导致大量建筑指数library cache pin/library cache lock
    34一个美丽的生活窍门
    html表格合并(行,一排)
    01标题背包水章 HDU2955——Robberies
    苹果Swift编程语言新手教程【中国版】
    神经网络和BP算法推导
  • 原文地址:https://www.cnblogs.com/a-du/p/7456898.html
Copyright © 2020-2023  润新知