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,验证一下解析出的数据是否正确。


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

查看所有标签

猜你喜欢:

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

Objective-C编程

Objective-C编程

[美] Aaron Hillegass / 夏伟频、李骏 / 华中科技大学出版社 / 2012-9-25 / 58.00元

《Objective-C编程》讲述Objective-C编程语言和基本的iOS/Mac开发知识。作者首先从基本的编程概念讲起(变量、条件语句、循环结构等),接着用浅显易懂的语言讲解Objective-C和Foundation的知识,包括Objective-C的基本语法、 Foundation常用类 、内存管理、常用设计模式等,最后手把手教读者编写完整的、基于事件驱动的iOS/Mac应用。作者还穿插......一起来看看 《Objective-C编程》 这本书的介绍吧!

RGB转16进制工具
RGB转16进制工具

RGB HEX 互转工具

在线进制转换器
在线进制转换器

各进制数互转换器

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

正则表达式在线测试