新聞中心
1、第一種,直接在配置文件中自定義時(shí)間格式
創(chuàng)新互聯(lián)專注于灞橋企業(yè)網(wǎng)站建設(shè),自適應(yīng)網(wǎng)站建設(shè),電子商務(wù)商城網(wǎng)站建設(shè)。灞橋網(wǎng)站建設(shè)公司,為灞橋等地區(qū)提供建站服務(wù)。全流程按需網(wǎng)站建設(shè),專業(yè)設(shè)計(jì),全程項(xiàng)目跟蹤,創(chuàng)新互聯(lián)專業(yè)和態(tài)度為您提供的服務(wù)這是tomcat配置文件中的一段日志時(shí)間配置,按照這樣的配置,那么輸出的日志是這樣子的:
然后你繼續(xù)在logstash中這樣子配置
此時(shí)logstash就不會(huì)報(bào)"_dateparsefailed"錯(cuò)誤了。
這種形式在nginx、apache等web服務(wù)器中配置是最好的,也比較方便分析。
2、第二種,帶有中括號(hào)的(其實(shí)跟上面是一回事)
日志本身輸出是這樣子的
[07/Feb/2018:16:24:19?+0800]
帶有一對(duì)中括號(hào)
那么在grok插件中這樣子定義就行:
\[%{HTTPDATE:timestamp}\]
date插件可以直接轉(zhuǎn)換,如下:
最后的效果是這樣子的
這樣子也不會(huì)報(bào)錯(cuò)
3、ISO8601形式
在日志文件中原生日志是這樣子的:
2019-03-19?13:08:07.782
重點(diǎn)是后面的”.782“,后面附加以毫秒為單位的。
?那么grok插件中可以這樣子定義匹配的規(guī)則:
此時(shí)date插件可以這樣子定義:
?date?{ ????????????????match?=>?[?"access_time","MMM??d?HH:mm:ss",?"MMM?dd?HH:mm:ss",?"ISO8601"] ????????}
上面的形式?jīng)]有寫錯(cuò),直接復(fù)制粘貼到配置文件即可
最后匹配如下:
這樣子也不會(huì)報(bào)”_dateparsefailed“錯(cuò)誤。
最后附加一張時(shí)間匹配規(guī)則表,平時(shí)可做參考
4、根據(jù)時(shí)間戳來轉(zhuǎn)換數(shù)據(jù)。
在mysql的慢查詢?nèi)罩局惺占瘯r(shí),由于某些情況下只能根據(jù)時(shí)間戳來確定時(shí)間,那么我們就必須使用轉(zhuǎn)換的方案了。主要是將時(shí)間戳轉(zhuǎn)換成UNIX風(fēng)格的時(shí)間,比如:
mysql慢查詢?nèi)罩镜臅r(shí)間是這樣子的:
那么我們?cè)趌ogstash的配置文件中使用的date插件這樣子來寫:
這樣子就可以匹配成功了。
上面的“timestamp_mysql”是我在grok插件中的匹配后的時(shí)間賦值,比如:
%{NUMBER:timestamp_mysql};
4、ISO8601形式
時(shí)間日志:
2018-02-09T10:57:42+08:00
此時(shí)在grok中可以這么寫:
grok?{ ????????match?=>?{?"message"?;?"{TIMESTAMP_ISO8601:localtime} }
而在時(shí)間轉(zhuǎn)存到@timestamp有兩種寫法可以供使用
date?{ ????????match?=>?["localtime",?"yyyy-MM-dd'T'HH:mm:ssZZ"] ????????target?=>?"@timestamp" }
或者是
date?{ ????????match?=>?["localtime",?"ISO8601"] ????}
都可以實(shí)現(xiàn)ISO8601時(shí)間的匹配格式
?
新聞名稱:logstash關(guān)于date時(shí)間處理的幾種方式總結(jié)-創(chuàng)新互聯(lián)
文章URL:http://fisionsoft.com.cn/article/dhschj.html