लॉगस्टैश - आउटपुट स्टेज
आउटपुट लॉगस्टैश पाइपलाइन में अंतिम चरण है, जो इनपुट डेटा से निर्दिष्ट गंतव्य तक फ़िल्टर डेटा भेजता है। लॉगस्टैश फ़िल्टर किए गए लॉग ईवेंट को विभिन्न अलग-अलग स्टोरेज और सर्च इंजनों पर स्टैश करने के लिए कई आउटपुट प्लगइन्स प्रदान करता है।
भंडारण लॉग
लॉगस्टैश फ़िल्टर किए गए लॉग को एक में स्टोर कर सकता है File, Elasticsearch Engine, stdout, AWS CloudWatch, आदि जैसे नेटवर्क प्रोटोकॉल TCP, UDP, Websocket लॉग इवेंट में दूरस्थ स्टोरेज सिस्टम में लॉग इवेंट को स्थानांतरित करने के लिए भी उपयोग किया जा सकता है।
ELK स्टैक में, उपयोगकर्ता लॉग इवेंट्स को संग्रहीत करने के लिए Elasticsearch इंजन का उपयोग करते हैं। यहां, निम्नलिखित उदाहरण में, हम एक स्थानीय इलास्टिक्स खोज इंजन के लिए लॉग ईवेंट उत्पन्न करेंगे।
एलिस्टिक्स खोज आउटपुट प्लगइन को स्थापित करना
हम निम्न कमांड के साथ एलीस्टेकर्च आउटपुट प्लगइन स्थापित कर सकते हैं।
>logstash-plugin install Logstash-output-elasticsearch
logstash.conf
इस कॉन्फिग फाइल में एलियस्टैकेसर्च प्लगइन होता है, जो स्थानीय रूप से स्थापित एलिस्टिक्स सर्च में आउटपुट इवेंट को स्टोर करता है।
input {
file {
path => "C:/tpwork/logstash/bin/log/input.log"
}
}
filter {
grok {
match => [ "message", "%{LOGLEVEL:loglevel} -
%{NOTSPACE:taskid} - %{NOTSPACE:logger} -
%{WORD:label}( - %{INT:duration:int})?" ]
}
if [logger] == "TRANSACTION_START" {
aggregate {
task_id => "%{taskid}"
code => "map['sql_duration'] = 0"
map_action => "create"
}
}
if [logger] == "SQL" {
aggregate {
task_id => "%{taskid}"
code => "map['sql_duration'] ||= 0 ;
map['sql_duration'] += event.get('duration')"
}
}
if [logger] == "TRANSACTION_END" {
aggregate {
task_id => "%{taskid}"
code => "event.set('sql_duration', map['sql_duration'])"
end_of_task => true
timeout => 120
}
}
mutate {
add_field => {"user" => "tutorialspoint.com"}
}
}
output {
elasticsearch {
hosts => ["127.0.0.1:9200"]
}
}
Input.log
निम्न कोड ब्लॉक इनपुट लॉग डेटा दिखाता है।
INFO - 48566 - TRANSACTION_START - start
INFO - 48566 - SQL - transaction1 - 320
INFO - 48566 - SQL - transaction1 - 200
INFO - 48566 - TRANSACTION_END - end
एलिजाबेथ में इलास्टिक्स की शुरुआत करें
एलिजाबेथ को लोकलहोस्ट पर शुरू करने के लिए, आपको निम्नलिखित कमांड का उपयोग करना चाहिए।
C:\elasticsearch\bin> elasticsearch
एक बार एलिस्टिक्स खोज तैयार हो जाने के बाद, आप इसे अपने ब्राउज़र में निम्न URL लिखकर जाँच सकते हैं।
http://localhost:9200/
प्रतिक्रिया
निम्नलिखित कोड ब्लॉक में एलिजाबेथ की प्रतिक्रिया को स्थानीयहोस्ट में दिखाया गया है।
{
"name" : "Doctor Dorcas",
"cluster_name" : "elasticsearch",
"version" : {
"number" : "2.1.1",
"build_hash" : "40e2c53a6b6c2972b3d13846e450e66f4375bd71",
"build_timestamp" : "2015-12-15T13:05:55Z",
"build_snapshot" : false,
"lucene_version" : "5.3.1"
},
"tagline" : "You Know, for Search"
}
Note - इलास्टिक्स खोज के बारे में अधिक जानकारी के लिए, आप निम्न लिंक पर क्लिक कर सकते हैं।
https://www.tutorialspoint.com/elasticsearch/index.html
अब, उपर्युक्त Logstash.conf के साथ लॉगस्टैश चलाएं
>Logstash –f Logstash.conf
आउटपुट लॉग में उपर्युक्त पाठ को चिपकाने के बाद, उस पाठ को लॉस्टश द्वारा एलिटिक्स खोज में संग्रहीत किया जाएगा। आप ब्राउज़र में निम्न URL टाइप करके संग्रहीत डेटा की जांच कर सकते हैं।
http://localhost:9200/logstash-2017.01.01/_search?pretty
प्रतिक्रिया
यह JSON प्रारूप में डेटा है जो कि Logstash-2017.01.01 सूचकांक में संग्रहीत है।
{
"took" : 20,
"timed_out" : false,
"_shards" : {
"total" : 5,
"successful" : 5,
"failed" : 0
},
"hits" : {
"total" : 10,
"max_score" : 1.0,
"hits" : [ {
"_index" : "logstash-2017.01.01",
"_type" : "logs",
"_id" : "AVlZ9vF8hshdrGm02KOs",
"_score" : 1.0,
"_source":{
"duration":200,"path":"C:/tpwork/logstash/bin/log/input.log",
"@timestamp":"2017-01-01T12:17:49.140Z","loglevel":"INFO",
"logger":"SQL","@version":"1","host":"wcnlab-PC",
"label":"transaction1",
"message":" INFO - 48566 - SQL - transaction1 - 200\r",
"user":"tutorialspoint.com","taskid":"48566","tags":[]
}
},
{
"_index" : "logstash-2017.01.01",
"_type" : "logs",
"_id" : "AVlZ9vF8hshdrGm02KOt",
"_score" : 1.0,
"_source":{
"sql_duration":520,"path":"C:/tpwork/logstash/bin/log/input.log",
"@timestamp":"2017-01-01T12:17:49.145Z","loglevel":"INFO",
"logger":"TRANSACTION_END","@version":"1","host":"wcnlab-PC",
"label":"end",
"message":" INFO - 48566 - TRANSACTION_END - end\r",
"user":"tutorialspoint.com","taskid":"48566","tags":[]
}
}
}
}