InfluxDB & Kapacitor & Chronograf Kullanarak DeadMan Bildirimleri Oluşturmak

Arkadaşlar merhaba ,

InfluxDB kullanmaktan çok zevk aldığım timeseries veritabanlarından birisi.

 

Özellikle sistem izleme metric oluşturma gibi konularda oldukça güçlü ve hızlı bir çözüm.

Şu linkten influxDB ve ElasticSearch arasındaki benchmarklara göz atabilirsiniz.

Benchmark sonuçları aşağıda görebileceğiniz şekilde influxDB’nin ezici üstünlüğünü gözler önüne seriyor.

Bu yazımızda işleyeceğimiz konu DeadMan bildirimleri. Deadman bildirimi x kaynağından y süresince veri gelmemiş ise burada bir sorun vardır logic’i üzerine kurulu bildirimlerdir.  Bu bildirimler bize bir cluster’ı yönetme konusunda ya da IoT dünyasında donanımlarımızın durumlarını kontrol etme konusunda yardımcı olabilir.

 

Kapacitor nedir ? 

Kapacitor influxDB ekosisteminde yer alan bir time-series data analizörüdür. Akan data üzerinde analizler yapmamıza yardımcı oluyor kısacası.

Chronograf nedir ?

Chronograf influxDB ve kapacitor tarafından oluşturulan çıktıları takip ve konfigüre edebileceğimiz bir yönetim arayüzüdür.

 

Şu linkten kapacitor , influxdb ve chronograf’ı indirelim ve arşivlerden çıkaralım.

Klasör yapımız aşağıdaki gibi olacaktır. (Komutları verirken bu klasör yapısı ile veriyor olacağım.)

 

Şimdi ihtiyac duyduğumuz servisleri çalıştıralım.

 

 

Kapacitor uygulaması ayağa kalktığı zaman influxDB üzerinde otomatik olarak subscriptionlar oluşturuyor. Ve gelen dataları takip etmeye başlıyor.

 

Favori browserımızı kullanarak localhost:8888 adresine gidiyoruz. Ve Chronograf’ın first run ekranı bizi karşılıyor.

Burada özel bir ayar yapmamız gerekmiyor. Enter Enter Yes Enter , Next Next Okey yöntemi ile chronografın konfigürasyonunu tamamlıyoruz.

Aşağıdaki adımda bazı ön tanımlı dashboardlardan otomatik olarak eklememize yardımcı olacak seçenekler mevcut. Ama şu anki amacımız deadman notificationları olduğu için bu adımda bir seçim yapmadan devam ediyoruz.

 

Şimdi ise Deadman notificationları oluşturmak için influxDB’ye düzenli olarak data gönderen bir uygulamaya ihtiyacımız var. Bunun için bir netcore projesi açıp influxDB’ye write yapan basit bir console uygulaması geliştiriyoruz.

InfluxDB bağlantısı için https://github.com/pootzko/InfluxData.Nett InfluxDB bağlantısı için şu repodaki kütüphaneyi kullanıyorum.

 

Chornograf arayüzünü kullanarak uygulamamız için bir influxDB oluşturuyoruz. Benim veritabanı adım

 

Bu veritabanına veri yazacak kodumuz(dataWriter) aşağıdaki gibidir.

Uygulama içerisinde 20 tane heartbeat verisi atıyoruz. Sonra 1.5 dk boyunca boşta bekliyoruz. Aslında uygulamamızın öldüğü (deadman) olduğu kısım bu 1.5 dakikalık kısımda olacak.

Şimdi ise deadman notificationlarını handle etmek için boş bir WebApi(DeadManNotificationHandler ) projesi açıyoruz. Kapacitor’un alertleri göndermek için slack , telegram , email , post gibi fonksiyonları mevcut. Biz bunların arasından post fonksiyonunu kullanacağız.

Boş API projesinde yer alan ValuesController’ı kullanacağız default olarak.

 

Bu controller’ın kodu aşağıdaki gibidir. MainResultDto nesnesini fiddler kullanarak CSharp objesine dönüştürdüm. MainResultDto.cs

DefaultController.cs

Şimdi Choronograf arayüzünde RuleManagement menüsüne geçelim. Normalde bu arayüz kapacitor’e yeni bir kural eklemek için kullanılıyor. Biz demo uygulama yaptığımız için arayüzü kullanıyoruz. Fakat kapacitor HTTP API üzerinden de bu işlemlerin tamamını desktekliyor. Yani otomatize etmek için ideal.

 

Burada Build Alert Rule butonu ile yeni bir rule yaratalım.

 

Kuralımız ile ilgili bazı ayarlamaları yapıyoruz.

 

Veri yazdığımız veritabanını seçince içinde kullanabileceğimiz fieldler sağ tarafta listeleniyor. Buradan uygulama içinde veri yazdığımız ismi ‘HeartBeatTag’ olan tag’i seçiyoruz.

 

HTPP Post sırasında kullanılacak header değerlerini ekliyoruz.

HTTP endpoint daha önce oluşturduğumuz boş webApi projesinin linki.

Send alert if Data is missing For seçimi ise X dakika veri alınamamışsa durumunu gösteriyor. Influx’a data yazan uygulamamızı 1.5 dakika boyunca boş kalacak şekilde yapılandırdığımız için bu kuralın tetiklenmesini bekliyoruz.

Message alanına Chronograf’ın sağladığı parametreleri kullanarak bir mesaj doldurabiliriz ben statik bir cümle kullanacağım bu alan için. Bu alana yazacağımız mesaj MainResultDto nesnesinin message alanında kullanılabilir oluyor.

 

Ayarlamalarımız tamam ise kuralımızı kayıt ediyoruz. Ve dataWriter ile DeadManNotificationHandler uygulamalarımızı başlatıyoruz.

 

Bu yazımda da dilim döndüğünde InfluxDB & Chronograf & Kapacitor kullanımını ve Complex Event Processor tadında bir implementasyonu sizlerle paylaşmaya çalıştım.

Sürç-ü lisan ettiysem affola.

You may also like...

1 Response

  1. 16 Mayıs 2020

    […] , Kapacitor kullanarak bir değer üzerinden deadman bildirimleri oluşturmuştuk. O yazıma şuradan […]

Bir yanıt yazın

E-posta adresiniz yayınlanmayacak. Gerekli alanlar * ile işaretlenmişlerdir

72 − = sixty six