我试图使用Logstash模式解析SSSD恶魔日志,以获得更好的可见性。
日志样本
(Mon Nov 9 12:08:56 2020) [sssd[nss]] [client_recv] (0x0200): Client disconnected!
(Mon Nov 9 12:08:56 2020) [sssd[nss]] [client_close_fn] (0x2000): Terminated client [0x55ffd29d93c0][22]我已经创建了自定义Grok模式,如下所示:
SSSD_TIME [ \(%{DAY} %{MONTH} %{MONTHDAY} %{TIME} %{YEAR}\)]+
SSSD_DEMON \[[a-z]*\[[a-z]*\]\]+
SSSD_FUNCTION \[[a-z,_]*\]+
SSD_LOG_LEVEL (\(\dx\d*\))+我使用上述自定义grok模式获取以下输出,用于下面的查询
%{SSSD_TIME:time} %{SSSD_DEMON:demon} %{SSSD_FUNCTION:function} %{SSD_LOG_LEVEL:loglevel}[:]\s+%{GREEDYDATA:message}输出:
{
"function": "[client_recv]",
"loglevel": "(0x0200)",
"time": "(Mon Nov 9 12:08:56 2020)",
"demon": "[sssd[nss]]",
"message": "Client disconnected!"
}我只需要提取括号中的值,而不是整个内容。
我试着跳过括号,但它只适用于第一个值。
下面查询跳过第一个括号
\(%{SSSD_TIME:time}\) %{SSSD_DEMON:demon} %{SSSD_FUNCTION:function} %{SSD_LOG_LEVEL:loglevel}[:]\s+%{GREEDYDATA:message}我需要得到下面的输出
{
"function": "client_recv",
"loglevel": "0x0200",
"time": "Mon Nov 9 12:08:56 2020",
"demon": "sssd[nss]",
"message": "Client disconnected!"
}如果有人能帮我,那就太好了
谢谢
发布于 2020-11-19 18:05:53
下面是您想要的输出的grok模式:
\((?<timestamp>%{DAY} %{MONTH} %{MONTHNUM} %{TIME} %{YEAR})\) \[(?<daemon>(.*))\] \[%{DATA:function}\] \(%{DATA:log_level}\): %{GREEDYDATA:message}
我使用格罗克调试器创建了from模式。
以下是输出的屏幕截图:


如果需要,可以使用logstash的DAY过滤器删除不必要的标记,如MONTH等。
https://stackoverflow.com/questions/64912407
复制相似问题