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

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的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。

分享给朋友:

相关文章

什么是 TON 币?TON币全方位介绍

什么是 TON 币?TON币全方位介绍

如果你有在使用Telegram,肯定看过它的广告,本篇文章要来介绍的是Toncoin(Ton)币,究竟Toncoin是什么?有什么价值?哪里买?Toncoin生态系钱包Toncoin 钱包Ton...

什么是EKT币?有哪些技术亮点?

什么是EKT币?有哪些技术亮点?

EKT是一个模块化的区块链底层框架,将构建一个基于多链架构的公有链生态系统,致力于成为支持大量应用落地的商用公链。能够为企业提供易用、灵活且高效的通用型基础技术,共同推动区块链应用场景落地。 项目的...

莱特币价格今日行情(莱特币行情走势)

莱特币价格今日行情(莱特币行情走势)

莱特币价格今日行情很多人都很关心的(莱特币价格今日行情)别着急今天就为大家详细讲解下: 1.莱特币速度更快,15分钟就可以完成6次确认,另外莱特币的数量也是比特币的四倍,总数达到8400万枚。 2...

火必Huobi官方回应裁员:网传裁员计划不实,尊重员工合法诉求

火必Huobi官方回应裁员:网传裁员计划不实,尊重员工合法诉求

孙宇晨:火必没有遇到财务问题,裁员是基于运营目标的调整 ---- 火必huobi 火必集团旗下服务于全球专业交易用户的创新数字资产国际站。...