Graylog解析Syslog中的Json数据

栏目: 后端 · 前端 · 发布时间: 7年前

内容简介:按照Syslog规范中所定义的message格式,例如下面的消息:对于用户来说,真正关心的是:

按照Syslog规范中所定义的message格式,

<PRI>Timestamp Hostname Tag: Content

例如下面的消息:

<28>2018-10-08T16:03:00+08:00 zhangtaodeMacBook-Pro.local demotag[15182]:  
{
"name":"devex",
"status":1
}

对于用户来说,真正关心的是:

{
"name":"devex",
"status":1
}

因此如果使用Graylog来接受Syslog消息时,需要剥离Content之前的数据。

配置Regex Extractors

首先使用正则表达式,从message中提取content。 因为最关心的数据再最后面,同时demotag是程序中固定输出的tag,因此可以按照下面的正则规则来设定:

^.*demotag\[.+\]:(.*)$

我们只保留 : 之后的字符串。 这样就将

{
"name":"devex",
"status":1
}

剥离了出来。 然后下一步就是解析这段字符串。

配置Json Extractors

在Json Extractors中,需要设定对哪个字段进行json解析。 所以需要对上面通过正则解析出来的数据给个字段名,这里命名为raw message。 然后对raw message进行json解析。解析出来的字段保留原始名称。

因为是对raw_message整个字段进行json解析,因此只要这个字段保存的是合法json字符串,那么就可以动态解析其包含的字段。

最后,通过syslog客户端发送数据到graylog,验证一下解析出的数据是否正确。


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

编码

编码

[美] Charles Petzold / 左飞、薛佟佟 / 电子工业出版社 / 2010 / 55.00元

本书讲述的是计算机工作原理。作者用丰富的想象和清晰的笔墨将看似繁杂的理论阐述得通俗易懂,你丝毫不会感到枯燥和生硬。更重要的是,你会因此而获得对计算机工作原理较深刻的理解。这种理解不是抽象层面上的,而是具有一定深度的。一起来看看 《编码》 这本书的介绍吧!

MD5 加密
MD5 加密

MD5 加密工具

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具