लॉगस्टैश - लॉग्स को पार्स करना
लॉगस्टैश इनपुट प्लगइन्स का उपयोग करके लॉग प्राप्त करता है और फिर डेटा को पार्स और बदलने के लिए फ़िल्टर प्लगइन्स का उपयोग करता है। आउटपुट के गंतव्य में मौजूद सिस्टम के अनुसार लॉग का पार्सिंग और परिवर्तन किया जाता है। लॉगस्टैश लॉगिंग डेटा को पार्स करता है और केवल आवश्यक फ़ील्ड को आगे बढ़ाता है। बाद में, इन क्षेत्रों को गंतव्य प्रणाली के संगत और समझने योग्य रूप में बदल दिया जाता है।
कैसे लॉग पार्स करने के लिए?
लॉग का पार्सिंग मेरे प्रयोग से किया जाता है GROK (ज्ञान का चित्रमय प्रतिनिधित्व) पैटर्न और आप उन्हें गितुब में पा सकते हैं -
https://github.com/elastic/logstash/tree/v1.4.2/patterns।
लॉगस्टैश लॉग्स के डेटा को "% {COMBINEDAPACHELOG} जैसे लॉग को पार्स करने के लिए एक निर्दिष्ट अनुक्रम पैटर्न या एक पैटर्न अनुक्रम के साथ मेल खाता है, जो आमतौर पर एपाचे लॉग के लिए उपयोग किया जाता है।
पार्स किया गया डेटा अधिक संरचित है और खोज करने और प्रश्नों को करने के लिए आसान है। लॉगस्टैश इनपुट लॉग में निर्दिष्ट सकल पैटर्न की खोज करता है और लॉग से मिलान लाइनों को निकालता है। आप अपने सकल पैटर्न का परीक्षण करने के लिए सकल डिबगर का उपयोग कर सकते हैं।
एक सकल पैटर्न के लिए वाक्यविन्यास% {SYNTAX: SEMANTIC} है। Logstash GROK फ़िल्टर निम्नलिखित रूप में लिखा गया है -
%{PATTERN:FieldName}
यहाँ, PATTERN GROK पैटर्न का प्रतिनिधित्व करता है और फ़ील्डनाम फ़ील्ड का नाम है, जो आउटपुट में पार्स किए गए डेटा का प्रतिनिधित्व करता है।
उदाहरण के लिए, ऑनलाइन सकल डिबगर का उपयोग करना https://grokdebug.herokuapp.com/
इनपुट
एक लॉग में एक नमूना त्रुटि लाइन -
[Wed Dec 07 21:54:54.048805 2016] [:error] [pid 1234:tid 3456829102]
[client 192.168.1.1:25007] JSP Notice: Undefined index: abc in
/home/manu/tpworks/tutorialspoint.com/index.jsp on line 11
सकल पैटर्न अनुक्रम
यह सकल पैटर्न अनुक्रम लॉग इवेंट से मेल खाता है, जिसमें एक टाइमस्टैम्प शामिल है, जिसके बाद लॉग स्तर, प्रक्रिया आईडी, लेनदेन आईडी और एक त्रुटि संदेश है।
\[(%{DAY:day} %{MONTH:month} %{MONTHDAY} %{TIME} %{YEAR})\] \[.*:%{LOGLEVEL:loglevel}\]
\[pid %{NUMBER:pid}:tid %{NUMBER:tid}\] \[client %{IP:clientip}:.*\]
%{GREEDYDATA:errormsg}
उत्पादन
आउटपुट JSON फॉर्मेट में है।
{
"day": [
"Wed"
],
"month": [
"Dec"
],
"loglevel": [
"error"
],
"pid": [
"1234"
],
"tid": [
"3456829102"
],
"clientip": [
"192.168.1.1"
],
"errormsg": [
"JSP Notice: Undefined index: abc in
/home/manu/tpworks/tutorialspoint.com/index.jsp on line 11"
]
}