如果细心的读者阅读过我之前的文章 “Elasticsearch:aggregation 介绍”,就会发现在我之前的例子中,我有用到 Script 来生成一个 field,并对这个 field 进行聚合统计。当时是这样做的:

GET sports/_search
{"size": 0,"aggs": {"age_range": {"range": {"script": {"source": """def dob = doc['birthdate'].value;return params.now - dob.getYear()""","params": {"now": 2019}},"ranges": [{"from": 30,"to": 31}]}}}
}

那么我们可以在 Kibana 中做同样的事吗?

答案是肯定的。在今天的文章中,我将来介绍如何在 Kibana 中使用 Script 来生产一个 field,并对这个 field 进行统计。

什么是 Scripted Field?

Scripted Field 用中文讲就是脚本字段。它是基于脚本即时计算值

  • 在查询时计算的值,但未编制索引
  • 可能会占用大量资源,并且会影响 Kibana 的效果
  • 没有验证
  • Buggy 脚本将生成异常
  • 可以使用 “Painless” 或者 “Luncene 表达式” 来写脚本

我们可以参考如下的链接:

  1. https://www.elastic.co/guide/en/elasticsearch/reference/current/ modules-scripting-painless.html

  2. https://www.elastic.co/guide/en/elasticsearch/reference/current/ modules-scripting-expression.html

下面我们还是使用一个具体的例子来讲述 Scripted Fields。

准备数据

为了能够展现如何生产 Scripted Filed,我们先使用如下的一个基本的数据。在 Kibana 中输入如下的数据:

POST _bulk
{ "index" : { "_index" : "twitter", "_id": 1} }
{"user":"张三","message":"今儿天气不错啊,出去转转去","uid":2,"city":"北京","province":"北京","country":"中国","address":"中国北京市海淀区","location":{"lat":"39.970718","lon":"116.325747"}, "DOB":"1980-12-01"}
{ "index" : { "_index" : "twitter", "_id": 2 }}
{"user":"老刘","message":"出发,下一站云南!","uid":3,"city":"北京","province":"北京","country":"中国","address":"中国北京市东城区台基厂三条3号","location":{"lat":"39.904313","lon":"116.412754"}, "DOB":"1981-12-01"}
{ "index" : { "_index" : "twitter", "_id": 3} }
{"user":"李四","message":"happy birthday!","uid":4,"city":"北京","province":"北京","country":"中国","address":"中国北京市东城区","location":{"lat":"39.893801","lon":"116.408986"}, "DOB":"1982-12-01"}
{ "index" : { "_index" : "twitter", "_id": 4} }
{"user":"老贾","message":"123,gogogo","uid":5,"city":"北京","province":"北京","country":"中国","address":"中国北京市朝阳区建国门","location":{"lat":"39.718256","lon":"116.367910"}, "DOB":"1983-12-01"}
{ "index" : { "_index" : "twitter", "_id": 5} }
{"user":"老王","message":"Happy BirthDay My Friend!","uid":6,"city":"北京","province":"北京","country":"中国","address":"中国北京市朝阳区国贸","location":{"lat":"39.918256","lon":"116.467910"}, "DOB":"1984-12-01"}
{ "index" : { "_index" : "twitter", "_id": 6} }
{"user":"老吴","message":"好友来了都今天我生日,好友来了,什么 birthday happy 就成!","uid":7,"city":"上海","province":"上海","country":"中国","address":"中国上海市闵行区","location":{"lat":"31.175927","lon":"121.383328"}, "DOB":"1985-12-01"}

这个 twitter 的 schema 是这样的:

{"twitter" : {"mappings" : {"properties" : {"DOB" : {"type" : "date"},"address" : {"type" : "text","fields" : {"keyword" : {"type" : "keyword","ignore_above" : 256}}},"city" : {"type" : "text","fields" : {"keyword" : {"type" : "keyword","ignore_above" : 256}}},"country" : {"type" : "text","fields" : {"keyword" : {"type" : "keyword","ignore_above" : 256}}},"location" : {"properties" : {"lat" : {"type" : "text","fields" : {"keyword" : {"type" : "keyword","ignore_above" : 256}}},"lon" : {"type" : "text","fields" : {"keyword" : {"type" : "keyword","ignore_above" : 256}}}}},"message" : {"type" : "text","fields" : {"keyword" : {"type" : "keyword","ignore_above" : 256}}},"province" : {"type" : "text","fields" : {"keyword" : {"type" : "keyword","ignore_above" : 256}}},"uid" : {"type" : "long"},"user" : {"type" : "text","fields" : {"keyword" : {"type" : "keyword","ignore_above" : 256}}}}}}
}

我们发现这个 Schema 里含有一个叫做 DOB (date of birth)的字段,但是它没有一个叫做 age 的字段,也就是年龄。我们知道这个年龄字段其实是根据每次查询的时间,会有不同。比如今年查询和明年查询,显然显示的年龄应该会有不同。我们的目标是每次搜索时会自动生产相应的 age。

我们先打开 Kibana,然后点击Management

我们选中 Twitter index pattern。如果大家不知到什么是 Inxdex pattern和如何生产 Index Pattern,请参阅我之前的文章“Kibana: 如何使用 Search Bar”。我们点击 Scripted Field:

然后点击 Add scripted field:

如上所示,我们想创建一个叫做 age 的 scripted field。它的值是 2019-doc['DOB'].value.getYear(),也就是用我们当前的年份减去生日的年份。由于这个脚本没有验证,有可能出现错误,那么我们如何测试它呢?

我们可以选择 Preview Results 来进行查看我们的结果。如果没有错误,那么我们可以看到输出的值。加入我们把脚本改为 2019-doc['DOB].value.getYear() 的话,显然这个是一个错误的脚本,在 DOB 那里少了一个引号。我们重复刚才的动作,那么:

这次显然是有错误的信息出现。我们可以通过这样的方法来排查我们的错误。最后,我们选择 Create field 按钮:

这样就看到了一个生成的叫做 age 的 Scripted field。那么我们该如何使用这个字段呢?我们点击 Discover,并搜索我们想要的年龄:

显然,这个时候,我们可以通过 age 来搜索我们的 index。但是必须记住的,这个新生成的字段只限于 Kibana 使用,并不会写回 twitter 索引,并生产相应的 token。

依赖于刚生成的 age,我们甚至可以做出相应的可视化图:

Kibana: 如何在 Kibana 中生成 Scripted fields相关推荐

  1. 浅析如何在Nancy中生成API文档

    前言 前后端分离,或许是现如今最为流行开发方式,包括UWP.Android和IOS这样的手机客户端都是需要调用后台的API来进行数据的交互. 但是这样对前端开发和APP开发就会面临这样一个问题:如何知 ...

  2. 中boxplot函数的参数设置_如何在Python中生成图形和图表

    在本章中,我们将学习如何在Python中生成图形和图表,同时将使用函数和面向对象的方法来可视化数据. Python中常用的一些可视化数据包括以下几种. Matplotlib. Seaborn. ggp ...

  3. 如何在Java中生成比特币钱包地址

    让我们通过学习比特币(Bitcoin)如何实施该技术的各个方面来工作,好吗?该技术包括以下几个方面: 比特币地址bitcoin address是用来发送和接收比特币的. 交易transaction是比 ...

  4. 大数据分析如何在Python中生成FiveThirtyEight图

    大数据分析如何在Python中生成FiveThirtyEight图?如果你阅读大数据分析文章,则可能已经迷失了FiveThirtyEight的内容.自然,他们的出色可视化使你印象深刻.你想制作自己的出 ...

  5. 如何在javascript中生成1到10之间的随机数

    在这篇文章中,我们将看到如何在 javascript 中生成 1 到 10 之间的随机数. 如何在javascript中生成1到10之间的随机数 我们可以简单地使用 Math.random() 方法在 ...

  6. JavaScript 随机数 – 如何在 JS 中生成随机数

    在使用 JavaScript 程序时,有时您可能需要生成一个随机数. 例如,您可能希望在开发 JavaScript 游戏(例如猜数字游戏)时生成一个随机数. JavaScript 有许多用于处理数字和 ...

  7. linux 随机密码更改,如何在Linux中生成EncryptDecrypt随机密码

    安全是网络世界中的主要问题之一.网络安全,也称为信息技术安全,重点在于保护计算机,网络,程序和数据免遭意外或未经授权的访问,更改或破坏.我们将密码用于计算机,电子邮件,云,电话,文档等.我们都知道选择 ...

  8. python制作词云时出现figure1 figure2_「中文版」如何在Python中生成任何形状的词云...

    有机会介绍一些有趣的项目,向更多人甚至是非技术人员推广Python和人工智能的东西还是蛮有意义的.话不多说,本文将介绍如何将你喜欢的文章或者歌词做一个炫丽的词云图片. 什么是词云呢?简单来说就是,将提 ...

  9. 如何在C中生成随机int?

    是否有在C中生成随机int数的函数? 或者我必须使用第三方库吗? #1楼 让我们来看看. 首先,我们使用srand()函数为随机化器播种. 基本上,计算机可以根据提供给srand()的数字生成随机数. ...

最新文章

  1. 地铁线路辅助绘图设计---不做简单的画图师
  2. Eclipse中web项目的默认发布路径改为外部Tomcat中webapp路径
  3. AAA Password Expiry in Cisco IOS Easy***
  4. 字符设备驱动程序之poll机制(韦大仙)
  5. Android--获取App应用程序的大小
  6. 剑指Offer(java版):字符串的排列
  7. 2017百度之星资格赛:1001. 度度熊保护村庄(floyd最小环)
  8. 准备开始考试系统分析员
  9. 五个最佳RSS新闻阅读器
  10. 常用代码大全(新手入门必备)
  11. java学习心得---循环结构
  12. 法兰克焊接机器人编程入门_Fanuc ARC MATE 焊接机器人操作编程.pdf
  13. P3C-PMD自定义规则实战
  14. 在Linux上安装centos 7镜像详细步骤
  15. webservice 缺少根元素_草莓种植,钙、硼元素十分重要,直接关系到草莓的产量和品质!...
  16. android+实现微信对话框样式,实现微信对话框的图片样式以及图片边框
  17. linux 安装memcache 到简单使用
  18. 常见报错信息及解决方法
  19. 【Latex】Texstudio英文拼写错误检查功能出问题的解决方法
  20. windlx 双精度一维向量相乘 代码

热门文章

  1. 基于计算的蛋白质复合物预测方法综述
  2. LeetCode 13 罗马数字转整数[找规律 多条件判断] HERODING的LeetCode之路
  3. android snackbar源码,Android中Snackbar的使用方法及小技巧
  4. 网络再现新的虐猫图片!!
  5. show函数的作用是什么python_python 学习之Python函数
  6. SQL语句建表基础教程
  7. CS versus EE
  8. 【MySQL】MySQL NDB Cluster安装
  9. 树莓派python编程入门先学什么_树莓派Python编程入门与实战
  10. qt画笔效果笔锋:铅笔、画笔、钢笔、毛笔、蜡笔