Kibana可视化Dashboard如何基于字段是否包含某关键词进行过滤

kinana是一个功能强大、可对Elasticsearch数据进行可视化的开源工具。

我们在dashboard创建可视化时,有时需要将某个index里数据的某个字段根据是否包含某些特定关键词进行过滤,这个时候就可以用到lens里的filter功能很方便地进行操作。

如上图所示,一个名为 formatted-logs的index数据用于检索,我选择了三个字段构成图中的表格,分别是 hostname, abstract 和 log.keyword。

需求一:

将 log.keyword 字段中包含 "No. of IPv6 Unicast prefixes received from" 字符串的行数筛选出来。

操作:

点击 "添加筛选",选择 log.keyword 字段,在运算符处选择 "是",然后在"值"一栏填入"No. of IPv6 Unicast prefixes received from *",因为我们是要匹配包含某字符串的字段内容而不是精确查找,填写完成后点击"保存",然后会发现一个问题,就是找不到结果。

这个时候再点击刚刚创建的filter标签,点击"编辑筛选"。

点击"编辑为查询DSL",DSL是ES提供的一种灵活的、基于 JSON 的查询语言。

这个时候可以看到实际用来查询的DSL,可以发现用到的检索是精确匹配,用的是"match_phrase", 我们希望能够用*进行模糊匹配,所以要把检索方式换成"wildcard"

将精确匹配的"match_phrase"换成支持模糊匹配的"wildcard",然后再点击"保存"

保存之后,就可以看到所有选择的时间范围内包含 "No. of IPv6 Unicast prefixes received from *" 字符串的日志数据了。

需求二:

将 log.keyword 字段中包含 "No. of IPv6 Unicast prefixes received from" 字符串的日志数据过滤掉。

操作:

将包含某指定字符串的数据行过滤掉不显示在表格内容中,其实就是在实现需求一所用到的ES查询DSL中进行反向操作。

这个时候可以使用 bool 查询中的 must_not 子句。must_not 子句用于排除与特定条件匹配的字段所在行数据(谢谢ChatGPT的倾情解答)。

那么将DSL调整为如下即可:

这个时候再更新检索结果,就可以看到log.keyword 字段中不包含 "No. of IPv6 Unicast prefixes received from" 字符串的日志数据。

最后的温馨tips: DSL 可以使用AI工具帮忙生成!!再次感谢ChatGPT。

相关推荐
云和数据.ChenGuang1 分钟前
自动化运维工程师之ansible启动rpcbind和nfs服务
运维·服务器·运维技术·数据库运维工程师·运维教程
yimengsama2 分钟前
VMWare虚拟机如何连接U盘
linux·运维·服务器·网络·windows·经验分享·远程工作
松涛和鸣6 分钟前
32、Linux线程编程
linux·运维·服务器·c语言·开发语言·windows
云和数据.ChenGuang8 分钟前
AB压力测试运维工程师技术教程
运维·压力测试·运维工程师
少年白char21 分钟前
【AI漫剧】开源自动化AI漫剧生成工具 - 从文字到影像:AI故事视频创作的全新可能
运维·人工智能·自动化
容智信息23 分钟前
容智Report Agent智能体驱动财务自动化,从核算迈向价值创造
大数据·运维·人工智能·自然语言处理·自动化·政务
眠りたいです1 小时前
Docker:容器虚拟化技术基础-namespace,cgroups,资源管理与LXC
运维·docker·中间件·容器
小周学学学1 小时前
vSphere DRS与vSphere HA
运维·服务器·vmware·虚拟化
小周学学学2 小时前
vcenter的SMB备份
运维·服务器·vmware·虚拟化
BullSmall2 小时前
Apache Doris 精细化调优配置指南
linux·运维·服务器·database