Logstash and Laravel (Part 1)

Laravel က log ကို logstash ကို ပို့ဖို့ စမ်းနေတာ ကြာပြီ။ သေချာအချိန်ပေးပြီး မစမ်း ဖြစ်ဘူး။ ကျွန်တော် ဖန်တီးချင်သည့် infra က အောက်ကလို ပုံပါ။


Laravel နဲ့ Apache က log တွေ အကုန် logstash ကို ပို့။ logstash ကနေ elastic search ကို ပို့။ ပြီးရင် kibana နဲ့ filter လုပ်ကြည့်ဖို့အတွက်ပါ။

အခုတော့ ရသွားပါပြီ။ အဓိက logstash မှာ plugin တွေ သွင်းရတာ ကို မသိခဲ့တာပါ။

Logstash အတွက် config ကို အောက်ကလို ရေးပါတယ်။

input {
    tcp {
        port => 9425
    }
}

filter {
    json {
        source => "message"
        add_tag => ["tag"]
    }
}
output {
    elasticsearch {
        "hosts" => "http://127.0.0.1:9200"
        "index" => "laravel-%{+YYYY.MM.dd}"
    }
    stdout{}
}

သုံးထားသည့် plugin တွေက input မှာ tcp , filter မှာ json, output မှာ elasticsearch နဲ့ stdout သုံးထားပါတယ်။ stdout ကတော့ ပြန်စစ်ဖို့ အတွက်ပါ။

cd /usr/share/logstash/bin
./logstash-plugin install logstash-input-tcp
./logstash-plugin install logstash-filter-json
./logstash-plugin install logstash-output-stdout
./logstash-plugin install logstash-output-elasticsearch

ပြီးရင် ဖန်တီးထားသည့် config file နဲ့ အခု လို run ကြည့်ပါမယ်။

cd /usr/share/logstash/bin
./logstash -f ~/udp.conf

udp.conf က ကျွန်တော် ဖန်တီးထားသည့် config file ပါ။

ပြီးရင် message.json မှာ အောက်ကလို ရေးထားပါ။

{"message" : "testing","tag" : "just"}

စမ်းပြီး ပို့ကြည့်ပါမယ်။

nc 127.0.0.1 9425 < message.json

error မတက်ပဲ stdout မှာ ပြပြီ ဆိုရင်တော့ အလုပ်လုပ်ပါပြီ။

ဒါဆိုရင် control + c (win,linux) , command + c (mac) နှိပ်ပြီးတော့ run ထားသည့် logstash ကို ပိတ်ပါ။

mv udp.conf /etc/logstash/conf.d/
service logstash restart

အခုဆိုရင် logstash က ready ဖြစ်ပါပြီ။ Kibana နဲ့ Laravel ကို တော့ မနက်ဖြန်မှ ဆက်ရေးပါတော့မယ်။

1 Comment

Comments are closed.