当前位置:首页 > 火币公告 > 正文内容

grok(groom)

xytest2023-03-26

grok(groom) 火币公告

最近有一位之前找过币圈网的用户问了我们小编的一个问题,我相信这也是很多币圈朋友经常会疑惑的问题:grok相关问题,groom相关问题,带着这一个问题,让专业的小编告诉您原因。

本文目录:

  • 1、
  • 2、
  • 3、

grok 是什么语法

grok 英[grɒk] 美[grɑ:k]

v. 通过感觉意会;

[例句]Eventually, the player uses an existing skill to grok another skill.

最终,玩家用已有的技能去获得新技能。

你真的了解Grok吗

在日志处理的过程中,有一项非常常见的任务就是把原始的单行日志转换成结构化的日志。如果你使用了ELK,那么你可以利用ES对数据进行聚合,使用Kibana来进行数据可视化从日志中来发现一些有价值的信息。

在LogStash中,这项工作是由logstash-filter-grok来完成的,它有超过200个可用的,大家都认为是比较有用的Grok模式,例如IPv6地址、UNIX路径等等。

下面是一个示例日志

使用Grok库,我们可以很容易的就完成日志格式化提取的任务

提取后的数据格式如下

看起来这是一件非常简单的事情,好吧。。那这篇文章就这样写完了么,当然不是。。

这是一个非常常见的问题。性能这个问题通常都是要被拿出来讨论的,用户通常会发现使用了Grok表达式之后,LogStash处理日志的速度变得很慢。就像前面所说的一样,Grok模式是基于正则表达式的,所以这个插件在性能上已经对正则做了非常多的性能优化的了。接下来的章节,我们会讨论在使用Grok模式中需要注意的点

在设计Grok表达式的时候,我们需要一些方法来测试究竟哪种写法性能表现更好。出于这个原因,我些了个很小的jruby脚步用于测试Grok插件处理我所写的Grok模式的性能,你可以在这里获取到这个 脚本

尽管Grok匹配的性能是非常重要的,但是匹配失败的时候对性能的影响也是我们需要留意的。当grok匹配失败的时候,插件会为这个事件打个tag,默认是_grokparsefailure。LogStash允许你把这些处理失败的事件路由到其他地方做后续的处理,例如

这样的话我们就可以对这些处理失败的事件做性能基准测试了。

现在,我们要开始对Apache的日志进行格式化处理了

然后我们使用下面的Grok模式去进行格式化提取

然后我们使用三种示例日志去测试这个Grok的性能,和Grok不匹配的日志分别出现在开始,中间和结束的位置

下面是性能测试的结果

基于上面这个测试结果,我们可以发现,Grok的性能和不匹配的日志所出现的位置有关,最快与最慢的性能差了差不多6倍。这就能解释为什么有用户提出当Grok匹配日志失败的时候CPU会被吃满的原因了,例如这个issues

.

我们能做些什么呢

我们已经知道了处理失败对grok的性能影响是非常大的,所以我们需要解决这个问题。对于正则引擎来说,你需要做的最合适的事情就是减少正则表达式所需要的猜测。这就是为什么贪婪匹配最好少用的原因,那回到这个问题,有没一种更好的方法来调整这个Grok模式呢,让我们重新来看看这行Apache的日志

刚才我们使用的Grok模式是这样的

由于用户以为Grok表达式只会从开头匹配到结束,所以导致了在一些普通的场景下也会出现性能问题。但是实际上,Grok只是被告知“在这段文本中寻找匹配的内容”,这就意味着下面这种示例也会被Grok所匹配。。。

呃。。这都行,不过解决这个问题还是很简单的,我们加一些锚点就搞定了。锚点可以让你再一个指定的位置处理字符串。加入了开始和结束的锚点之后(^和$),Grok就会从开头处理日志到结束了。这对处理那些不能匹配的日志有非常重要的作用。假如我们没有假如锚点,当正则无法匹配这行日志的时候,它就会开始从子字符串中进行匹配,然后性能就会下降,接下来我们把锚点加上,然后再做一次测试

可以看到性能有了很大的提升,在一开始就匹配失败的场景中,性能提升了将近10倍

你可能会说,“好吧,我的日志都是能匹配通过的,没有上面的问题”,但是事情可能并不是这样的

我们看到过非常多的grok模式在处理同一个网关发出的多种应用日志时候所出现的问题,例如syslog。想象一下这样一个场景,我们使用了“common_header: payload“这种日志格式来记录了三种应用日志

通常我们会在一个Grok里面就把三种日志都处理掉

值得留意的是即使你的日志是能正常匹配的,Grok还是会按照顺序许匹配送进来的日志,当碰到第一个匹配成功的日志就break掉这个循环。这就要我们自己去判断一下,怎么放是最合适的了,不然的话会一个一个往下进行尝试,毕竟是多种不同的格式。

一种常用的优化方案是使用分层匹配来对这个Grok进行优化

这是两种匹配方案的性能测试结果

看起来真有意思。。使用锚点的话,无论哪种方案性能都是一样的。不用锚点的情况下分层Grok的方案比不分层的又快很多

我们已经得出了对_grokparsefaiure进行处理的必要性了,那么我们还能做什么呢?

从3.2.0这个Grok插件开始,它有一些参数可以帮助你了解为什么一个事件会被处理那么久了。使用 timeout_millis 和 tag_on_timeout 可以设置Grok匹配的最大处理时长。如果超时了,这个事件会被打上 _groktimeout 的tag,然后我们就可以把他们送到一个Grok处理失败的ES索引里面去做后续的分析了

另外一个很棒的方法是LogStash5.0带了插件性能统计的功能,我们可以通过API来查看插件处理日志的性能了

然后我们就可以通过 duration_in_millis 来判断一个插件的性能了

希望这篇文章能帮你了解为什么Grok的性能会变得慢和如何去提升他的性能。下面是对这篇文字的总结:

原文:

logstash神器之grok

Grok 是 Logstash 最重要的插件。你可以在 grok 里直接使用或应用预定义的表达式名称,grok 支持把预定义的 grok 表达式 写入到文件中,官方提供的预定义 grok 表达式见: 。

最直观的grok语法使用参见: ELK应用之Logstash ;

,这里不做赘述。

下面是从官方文件中摘抄的最简单但是足够说明用法的示例:

第一列是正则grok表达式的名称,可直接使用;第二列是普通的正则表达式 ;

第一行,用普通的正则表达式来定义一个 grok 表达式;第二行,通过打印赋值格式,用前面定义好的 grok 表达式来定义另一个 grok 表达式。 (简单的说就是,名字和表达式,而且可嵌套使用)

grok 表达式使用的基本语法是下面这样的:

小贴士:SYNTAX是指预定义好的表达式的名字,SEMANTIC是指匹配之后要放的字段名字(自定义或随心所欲,只要自己能认识区分的)。

附录:

关于grok和groom的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。

分享给朋友:

相关文章

飞机软件聊天下载免费_飞机聊天软件官方下载

飞机软件聊天下载免费_飞机聊天软件官方下载

今天给各位分享飞机软件聊天下载免费的知识,其中也会对飞机聊天软件官方下载进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,如果有不同的见解与看法,请积极在评论区留言,现在开始进入正题! 下...

USDT苹果手机版下载安装_USDT苹果版正式版下载

USDT苹果手机版下载安装_USDT苹果版正式版下载

USDT苹果版下载到本地,软件不仅可以购买USDT和比特币ETC以太币ETH等,而且还可以进行币种的交易,支持多种交易类型,不同交易类型手续费也不同,法币交易的手续费为0。总之整体的手续费在其他交易所...

CZ:Bitcoin并没有死,我们还在这里

CZ:Bitcoin并没有死,我们还在这里

CZ发推特表示,Bitcoin并没有死,我们还在这里。...

ABYSS币总量多少?ABYSS币初始发行价格是多少?

ABYSS币总量多少?ABYSS币初始发行价格是多少?

这个是新开发出来的,从出来到现在,一直向持续规0的方向发展。目前每天的交易量也就是。0.5个比特币。可以说现在已经死了。他模仿了bm的steem。又引入了游戏积分的概念,但是遇到了熊市,项目方,估计选...

公链和私链的区别是什么?

公链和私链的区别是什么?

公有链上的各个节点可以自由加入和退出网络,并参加链上数据的读写,读写时以扁平的拓扑结构互联互通,网络中不存在任何中心化的服务端节点。 像到底所熟悉的比特币和以太坊,都是一种公有链。公有链的好处是没有...