Elasticsearch官档翻译——4.3 通用选项

通用选项

以下选项可以用于全部的REST API。

格式化的结果

当任意请求加入参数?pretty=true参数,返回的JSON将会被格式化(推荐只在debug的时候使用!)。另一个选项设置参数为?format=yaml,可以设置返回结果是可读的YAML格式。

人可读的输出

统计数据可以返回合适的人可读的格式(例如"exists_time": "1h""size": "1kb")和计算机的格式(例如"exists_time_in_millis": 3600000"size_in_bytes": 1024)。人可读的值可以通过在querystring后面添加?human=false来关闭。这个功能在stats结果提供给监控工具而不是给人直接看的时候比较有意义。human的默认值是false。

日期数学表达式

绝大多数接受格式化的日期值的查询,例如 range查询中的 gtlt,或者 daterange 集合中的fromto,都能够识别日期数学。
表达式以固定的日期开始,可以是now或者日期字符串,然后以||结尾。这个固定的日期后面可以选择加上一个或多个数学表达式。

  • +1h - 加一小时
  • -1d - 减一天
  • /d - 四舍五入到最近的一天

支持的时间单位有y (year), M (month), w (week), d (day), h (hour), m (minute), 和 s (second).

展示几个示例:

  • now+1h - 当前时间加一小时,毫秒处理
  • now+1h+1m - 当前时间加一小时和一分钟,毫秒处理
  • now+1h/d - 当前时间加一小时,并四舍五入到最近的一天
  • 2015-01-01||+1M/d - 2015-01-01加一个月,并四舍五入到最近的一天

响应过滤器

所有的响应都接收一个filter_path参数,可以减少elasticsearch的返回结果。这个参数后面跟一组表达式使用逗号进行分割。

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"
}
}
}

**通配符可用于匹配字段中不确定确切路径的字段。例如,返回Lucene每个分片的版本:

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字段,你要把filter_path参数和_source参数一起用(详见 Get API)。如下:

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参数可以影响settings的渲染效果,当设置flat_settings为true,settings将会平铺渲染展示:

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

当他设置为fasle的时候,将会返回更人性化的结构:

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

默认flat_settings是false。

参数

其余参数(当使用HTTP,HTTP映射到URL的字符串)遵循下划线约定。

布尔值

所有的REST API(请求体和响应JSON)都支持布尔值 false有以下几种表示方式:false0nooff。剩下其他值都是true,注意这个和入索引的文档中的字段无关。

数值

所有REST API除了原生的JSON数字类型还支持数字格式的字符串。

时间单位

无论什么时候要指定时间,例如timeout参数,时间必须指定单位,比如2d表示两天,支持的单位如下:

  • y - Year (年)
  • M - Month(月)
  • w - Week(周)
  • d - Day(日)
  • h - Hour(小时)
  • m - Minute(分钟)
  • s - Second(秒)
  • ms - Milli-second(毫秒)

数据大小单位

无论什么时候需要指定数据大小,例如设置缓冲区大小,单位必须要指定,例如10kb 就是1000字节。支持的单位如下:

  • b - Byte
  • kb - 千字节
  • mb - 兆字节
  • gb - GB
  • tb - TB
  • pb - PB

距离单位

无论什么时候需要指定距离,例如在Geo Distance Query查询中使用distance字段,没指定的情况下默认是米,也可以指定其他单位,例如1km2mi
单位列表如下:

  • Mile - mi or miles
  • Yard - yd or yards
  • Feet - ft or feet
  • Inch - in or inch
  • Kilometer - km or kilometers
  • Meter - m or meters
  • Centimeter - cm or centimeters
  • Millimeter - mm or millimeters
  • Nautical mile - NM, nmi or nauticalmiles

Geohash Cell Query中的precision(精度)字段可以接受上述距离单位,如果没有指定,使用geohash的长度。

模糊行

有些查询或API支持不精确的模糊匹配,使用fuzziness参数。fuzziness是上下文敏感的,也就是说这取决于被查询字段的类型。

数字,日期和IPV4字段

当查询数字,日期和IPV4字段时,fuzziness被解析为+/-,表现和Range Query类似:

-fuzziness <= field value <= +fuzziness

fuzziness字段应该使用数字值,例如2或2.0。date类型应该被解析为long值,当然也可以用包含时间的字符串—— “1h” —— 使用时间单位edit解析。IPV4字段可以接受long值或者另一个IPV4值(也被解析成long值得IPV4)

String字段

当查询string类型字段,fuzziness使用编辑距离算法解析,一个字符串的改变可以使一个字符串等价于另一个字符串。
fuzziness参数可以指定如下值:

  • 0, 1, 2 - 最大的编辑距离。
  • AUTO 基于term的长度生成编辑距离,例如长度在0-2的必须要完全匹配,3-5的可以有一个字符不同,大于5的可以有两个。

通常来说AUTO是fuzziness参数的首选。

返回结果风格

所有API都接受case参数。当设置了camelCase,所有的参数都会使用驼峰命名,否则是下划线命名。注意这个在文档的source字段中不起作用。

译者批注:大概是因为source是使用者自定义的,而API里面的名字是ES可控的

query string中的请求体

对于不接受非POST请求的请求体的库,可以将请求体放在query string的source参数中传递。


基于URL的访问控制

很多用户使用代理访和基于URL的访问控制来确保elasticsearch的索引安全,对于multi_searchmulti_get以及bulk请求,用户可以在URL中指定索引名,并且还可以在请求体中指定索引名。这样就基于URL的访问控制就比较有挑战了。

为了防止用户请求体中的索引名覆盖了URL中的索引名,可以在配置文件中加入如下配置:

rest.action.multi.allow_explicit_index: false

默认值是true。但如果配置为false,Elasticsearch就会拒绝请求体重指明索引名的请求。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,922评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,591评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,546评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,467评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,553评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,580评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,588评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,334评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,780评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,092评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,270评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,925评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,573评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,194评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,437评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,154评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,127评论 2 352

推荐阅读更多精彩内容

  • 博客原文一博客原文二 翻译作品,水平有限,如有错误,烦请留言指正。原文请见 官网英文文档 起步 Elasticse...
    rabbitGYK阅读 3,236评论 0 68
  • 文章名称:Elasticsearch Reference[2.2]原文地址:https://www.elastic...
    code4j阅读 458评论 0 1
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,647评论 18 139
  • 收听曾国藩的日记,看到近代第一完人,如何对自己精雕细琢,从一个资质平庸的普通人成长为一代圣人。一件事情总...
    牧_童阅读 218评论 1 2
  • 1996年 我是一片云 在暖洋洋的空中 懒懒的飘来荡去 栀子花开的那抹纯白 是我单纯的眼眸 笑靥如春 唤醒了公主 ...
    漫真阅读 287评论 4 6