Logstash - Panduan Cepat

Logstash adalah alat yang didasarkan pada pola filter / pipa untuk mengumpulkan, memproses, dan menghasilkan log atau peristiwa. Ini membantu dalam memusatkan dan membuat analisis waktu nyata dari log dan peristiwa dari berbagai sumber.

Logstash ditulis pada bahasa pemrograman JRuby yang berjalan di JVM, oleh karena itu Anda dapat menjalankan Logstash di berbagai platform. Ini mengumpulkan berbagai jenis data seperti Log, Paket, Peristiwa, Transaksi, Data Stempel Waktu, dll., Dari hampir setiap jenis sumber. Sumber data dapat berupa data Sosial, E-commerce, Artikel berita, CRM, Data game, Tren web, Data keuangan, Internet of Things, Perangkat seluler, dll.

Fitur Umum Logstash

Fitur umum Logstash adalah sebagai berikut -

  • Logstash dapat mengumpulkan data dari berbagai sumber dan mengirim ke banyak tujuan.

  • Logstash dapat menangani semua jenis data logging seperti Apache Logs, Windows Event Logs, Data over Network Protocols, Data dari Standard Input dan banyak lagi.

  • Logstash juga dapat menangani permintaan http dan data respons.

  • Logstash menyediakan berbagai filter, yang membantu pengguna menemukan lebih banyak makna dalam data dengan mengurai dan mengubahnya.

  • Logstash juga dapat digunakan untuk menangani data sensor di internet of things.

  • Logstash adalah open source dan tersedia di bawah lisensi Apache versi 2.0.

Konsep Kunci Logstash

Konsep utama Logstash adalah sebagai berikut -

Objek Acara

Ini adalah objek utama di Logstash, yang merangkum aliran data di pipeline Logstash. Logstash menggunakan objek ini untuk menyimpan data masukan dan menambahkan bidang ekstra yang dibuat selama tahap filter.

Logstash menawarkan API Peristiwa kepada pengembang untuk memanipulasi peristiwa. Dalam tutorial ini, event ini disebut dengan berbagai nama seperti Logging Data Event, Log Event, Log Data, Input Log Data, Output Log Data, dll.

Pipa

Ini terdiri dari tahapan aliran data di Logstash dari input ke output. Data input dimasukkan ke dalam pipeline dan diproses dalam bentuk event. Kemudian mengirimkan ke tujuan keluaran dalam format yang diinginkan pengguna atau sistem akhir.

Memasukkan

Ini adalah tahap pertama dalam pipeline Logstash, yang digunakan untuk mendapatkan data di Logstash untuk diproses lebih lanjut. Logstash menawarkan berbagai plugin untuk mendapatkan data dari berbagai platform. Beberapa plugin yang paling umum digunakan adalah - File, Syslog, Redis dan Beats.

Saring

Ini adalah tahap tengah dari Logstash, tempat pemrosesan peristiwa yang sebenarnya terjadi. Pengembang dapat menggunakan Pola Regex yang telah ditentukan sebelumnya oleh Logstash untuk membuat urutan untuk membedakan antara bidang dalam acara dan kriteria untuk kejadian masukan yang diterima.

Logstash menawarkan berbagai plugin untuk membantu pengembang mengurai dan mengubah acara menjadi struktur yang diinginkan. Beberapa plugin filter yang paling umum digunakan adalah - Grok, Mutate, Drop, Clone, dan Geoip.

Keluaran

Ini adalah tahap terakhir dalam pipeline Logstash, di mana peristiwa keluaran dapat diformat ke dalam struktur yang dibutuhkan oleh sistem tujuan. Terakhir, ia mengirimkan acara keluaran setelah pemrosesan selesai ke tujuan dengan menggunakan plugin. Beberapa plugin yang paling umum digunakan adalah - Elasticsearch, File, Graphite, Statsd, dll.

Keuntungan Logstash

Poin-poin berikut menjelaskan berbagai keunggulan Logstash.

  • Logstash menawarkan urutan pola regex untuk mengidentifikasi dan mengurai berbagai bidang dalam peristiwa masukan apa pun.

  • Logstash mendukung berbagai server web dan sumber data untuk mengekstrak data logging.

  • Logstash menyediakan banyak plugin untuk mengurai dan mengubah data logging menjadi format yang diinginkan pengguna.

  • Logstash terpusat, yang membuatnya mudah untuk memproses dan mengumpulkan data dari server yang berbeda.

  • Logstash mendukung banyak database, protokol jaringan, dan layanan lain sebagai sumber tujuan untuk peristiwa logging.

  • Logstash menggunakan protokol HTTP, yang memungkinkan pengguna memutakhirkan versi Elasticsearch tanpa harus memutakhirkan Logstash dalam langkah kunci.

Kekurangan Logstash

Poin-poin berikut menjelaskan berbagai kelemahan Logstash.

  • Logstash menggunakan http, yang berdampak negatif pada pemrosesan data logging.

  • Bekerja dengan Logstash terkadang bisa sedikit rumit, karena membutuhkan pemahaman dan analisis yang baik dari data pencatatan input.

  • Plugin filter tidak umum, jadi, pengguna mungkin perlu menemukan urutan pola yang benar untuk menghindari kesalahan dalam penguraian.

Di bab selanjutnya, kita akan memahami apa itu ELK Stack dan bagaimana itu membantu Logstash.

ELK adalah singkatan dari Elasticsearch, Logstash, dan Kibana. Di tumpukan ELK, Logstash mengekstrak data logging atau peristiwa lain dari sumber input yang berbeda. Ini memproses acara dan kemudian menyimpannya di Elasticsearch. Kibana adalah antarmuka web, yang mengakses data logging dari Elasticsearch dan memvisualisasikannya.

Logstash dan Elasticsearch

Logstash menyediakan input dan output plugin Elasticsearch untuk membaca dan menulis peristiwa log ke Elasticsearch. Elasticsearch sebagai tujuan keluaran juga direkomendasikan oleh Elasticsearch Company karena kompatibilitasnya dengan Kibana. Logstash mengirimkan data ke Elasticsearch melalui protokol http.

Elasticsearch menyediakan fasilitas unggahan massal, yang membantu mengunggah data dari berbagai sumber atau instans Logstash ke mesin Elasticsearch terpusat. ELK memiliki keunggulan berikut dibandingkan Solusi DevOps lainnya -

  • Tumpukan ELK lebih mudah dikelola dan dapat diskalakan untuk menangani peristiwa berukuran petabyte.

  • Arsitektur tumpukan ELK sangat fleksibel dan menyediakan integrasi dengan Hadoop. Hadoop terutama digunakan untuk keperluan arsip. Logstash dapat langsung dihubungkan ke Hadoop dengan menggunakan flume dan Elasticsearch menyediakan konektor bernamaes-hadoop untuk terhubung dengan Hadoop.

  • Total biaya kepemilikan ELK jauh lebih rendah daripada alternatifnya.

Logstash dan Kibana

Kibana tidak berinteraksi dengan Logstash secara langsung tetapi melalui sumber data, yaitu Elasticsearch di tumpukan ELK. Logstash mengumpulkan data dari setiap sumber dan Elasticsearch menganalisisnya dengan kecepatan sangat cepat, lalu Kibana memberikan wawasan yang dapat ditindaklanjuti pada data tersebut.

Kibana adalah alat visualisasi berbasis web, yang membantu pengembang dan lainnya untuk menganalisis variasi dalam jumlah besar peristiwa yang dikumpulkan oleh Logstash di mesin Elasticsearch. Visualisasi ini memudahkan untuk memprediksi atau melihat perubahan tren kesalahan atau peristiwa penting lainnya dari sumber masukan.

Untuk menginstal Logstash pada sistem, kita harus mengikuti langkah-langkah yang diberikan di bawah ini -

Step 1- Periksa versi Java yang terpasang di komputer Anda; seharusnya Java 8 karena tidak kompatibel dengan Java 9. Anda dapat memeriksanya dengan -

Di Sistem Operasi (OS) Windows (menggunakan prompt perintah) -

> java -version

Di UNIX OS (Menggunakan Terminal) -

$ echo $JAVA_HOME

Step 2 - Unduh Logstash dari -

https://www.elastic.co/downloads/logstash.

  • Untuk OS Windows, unduh file ZIP.

  • Untuk UNIX OS, unduh file TAR.

  • Untuk Debian OS, unduh file DEB.

  • Untuk Red Hat dan distribusi Linux lainnya, unduh file RPN.

  • Utilitas APT dan Yum juga dapat digunakan untuk menginstal Logstash di banyak distribusi Linux.

Step 3- Proses instalasi Logstash sangat mudah. Mari kita lihat bagaimana Anda dapat menginstal Logstash di berbagai platform.

Note - Jangan letakkan spasi atau titik dua di folder instalasi.

  • Windows OS - Buka zip paket zip dan Logstash diinstal.

  • UNIX OS - Ekstrak file tar di lokasi mana pun dan Logstash diinstal.

$tar –xvf logstash-5.0.2.tar.gz

Using APT utility for Linux OS −

  • Unduh dan pasang Kunci Penandatanganan Publik -
$ wget -qO - https://artifacts.elastic.co/GPG-KEY-elasticsearch | sudo apt-key add -
  • Simpan definisi repositori -
$ echo "deb https://artifacts.elastic.co/packages/5.x/apt stable main" | sudo
   tee -a /etc/apt/sources.list.d/elastic-5.x.list
  • Jalankan pembaruan -
$ sudo apt-get update
  • Sekarang Anda dapat menginstal dengan menggunakan perintah berikut -
$ sudo apt-get install logstash

Using YUM utility for Debian Linux OS -

  • Unduh dan pasang Kunci Penandatanganan Publik -
$ rpm --import https://artifacts.elastic.co/GPG-KEY-elasticsearch
  • Tambahkan teks berikut dalam file dengan akhiran .repo di direktori o “/etc/yum.repos.d/” Anda. Sebagai contoh,logstash.repo

[logstash-5.x]
name = Elastic repository for 5.x packages
baseurl = https://artifacts.elastic.co/packages/5.x/yum
gpgcheck = 1
gpgkey = https://artifacts.elastic.co/GPG-KEY-elasticsearch
enabled = 1
autorefresh = 1
type = rpm-md
  • Anda sekarang dapat menginstal Logstash dengan menggunakan perintah berikut -
$ sudo yum install logstash

Step 4- Buka direktori beranda Logstash. Di dalam folder bin, jalankanelasticsearch.batfile dalam kasus windows atau Anda dapat melakukan hal yang sama menggunakan command prompt dan melalui terminal. Di UNIX, jalankan file Logstash.

Kita perlu menentukan sumber masukan, sumber keluaran, dan filter opsional. Untuk memverifikasi instalasi, Anda dapat menjalankannya dengan konfigurasi dasar dengan menggunakan aliran input standar (stdin) sebagai sumber input dan aliran output standar (stdout) sebagai sumber output. Anda juga dapat menentukan konfigurasi di baris perintah dengan menggunakan–e pilihan.

In Windows −

> cd logstash-5.0.1/bin
> Logstash -e 'input { stdin { } } output { stdout {} }'

In Linux −

$ cd logstash-5.0.1/bin
$ ./logstash -e 'input { stdin { } } output { stdout {} }'

Note- dalam kasus windows, Anda mungkin mendapatkan kesalahan yang menyatakan JAVA_HOME tidak disetel. Untuk ini, harap setel di variabel lingkungan ke "C: \ Program Files \ Java \ jre1.8.0_111" atau lokasi tempat Anda menginstal java.

Step 5 - Port default untuk antarmuka web Logstash adalah 9600 hingga 9700 ditentukan di logstash-5.0.1\config\logstash.yml sebagai http.port dan itu akan mengambil port pertama yang tersedia dalam kisaran yang diberikan.

Kami dapat memeriksa apakah server Logstash aktif dan berjalan dengan menjelajah http://localhost:9600atau jika porta berbeda, lalu periksa prompt perintah atau terminal. Kita dapat melihat port yang ditetapkan sebagai "Berhasil memulai titik akhir API Logstash {: port ⇒ 9600}. Ini akan mengembalikan objek JSON, yang berisi informasi tentang Logstash yang diinstal dengan cara berikut -

{
   "host":"manu-PC", 
   "version":"5.0.1",
   "http_address":"127.0.0.1:9600",
   "build_date":"2016-11-11T22:28:04+00:00",
   "build_sha":"2d8d6263dd09417793f2a0c6d5ee702063b5fada",
   "build_snapshot":false
}

Pada bab ini, kita akan membahas tentang arsitektur internal dan berbagai komponen Logstash.

Arsitektur Layanan Logstash

Logstash memproses log dari berbagai server dan sumber data dan berfungsi sebagai pengirim. Pengirim digunakan untuk mengumpulkan log dan ini dipasang di setiap sumber input. Broker sukaRedis, Kafka atau RabbitMQ adalah buffer untuk menyimpan data bagi pengindeks, mungkin ada lebih dari satu broker karena gagal dalam beberapa kasus.

Pengindeks suka Lucenedigunakan untuk mengindeks log untuk kinerja pencarian yang lebih baik dan kemudian hasilnya disimpan di Elasticsearch atau tujuan keluaran lainnya. Data dalam penyimpanan keluaran tersedia untuk Kibana dan perangkat lunak visualisasi lainnya.

Arsitektur Internal Logstash

Pipeline Logstash terdiri dari tiga komponen Input, Filters dan Output. Bagian input bertanggung jawab untuk menentukan dan mengakses sumber data input seperti folder logApache Tomcat Server.

Contoh untuk Menjelaskan Logstash Pipeline

File konfigurasi Logstash berisi detail tentang tiga komponen Logstash. Dalam hal ini, kami membuat nama file bernamaLogstash.conf.

Konfigurasi berikut menangkap data dari log masukan "inlog.log" dan menulisnya ke log keluaran "outlog.log" tanpa filter apa pun.

Logstash.conf

File konfigurasi Logstash hanya menyalin data dari inlog.log file menggunakan plugin input dan menghapus data log ke outlog.log file menggunakan plugin keluaran.

input {
   file {
      path => "C:/tpwork/logstash/bin/log/inlog.log"
   }
}
output {
   file {
      path => "C:/tpwork/logstash/bin/log/outlog.log"
   }
}

Jalankan Logstash

Penggunaan Logstash –f opsi untuk menentukan file konfigurasi.

C:\logstash\bin> logstash –f logstash.conf

inlog.log

Blok kode berikut menunjukkan data log masukan.

Hello tutorialspoint.com

outlog.log

Output Logstash berisi data input di bidang pesan. Logstash juga menambahkan bidang lain ke keluaran seperti Stempel Waktu, Jalur Sumber Input, Versi, Host, dan Tag.

{
   "path":"C:/tpwork/logstash/bin/log/inlog1.log",
   "@timestamp":"2016-12-13T02:28:38.763Z",
   "@version":"1", "host":"Dell-PC",
   "message":" Hello tutorialspoint.com", "tags":[]
}

Seperti yang Anda bisa, output Logstash berisi lebih dari data yang disediakan melalui input log. Keluarannya berisi Jalur Sumber, Stempel Waktu, Versi, Nama Inang, dan Tag, yang digunakan untuk mewakili pesan tambahan seperti kesalahan.

Kita dapat menggunakan filter untuk memproses data dan membuatnya berguna untuk kebutuhan kita. Pada contoh berikutnya, kami menggunakan filter untuk mendapatkan data, yang membatasi output hanya untuk data dengan kata kerja seperti GET atau POST diikuti denganUnique Resource Identifier.

Logstash.conf

Dalam konfigurasi Logstash ini, kami menambahkan filter bernama grokuntuk menyaring data masukan. Peristiwa log masukan, yang cocok dengan log masukan urutan pola, hanya sampai ke tujuan keluaran dengan kesalahan. Logstash menambahkan tag bernama "_grokparsefailure" di acara keluaran, yang tidak cocok dengan urutan pola filter grok.

Logstash menawarkan banyak pola regex bawaan untuk mengurai log server populer seperti Apache. Pola yang digunakan di sini mengharapkan kata kerja seperti get, post, dll., Diikuti oleh pengenal sumber daya yang seragam.

input {
   file {
      path => "C:/tpwork/logstash/bin/log/inlog2.log"
   }
}
filter {
   grok {
      match => {"message" => "%{WORD:verb} %{URIPATHPARAM:uri}"}
   }
}
output {
   file {
      path => "C:/tpwork/logstash/bin/log/outlog2.log"
   }
}

Jalankan Logstash

Kita dapat menjalankan Logstash dengan menggunakan perintah berikut.

C:\logstash\bin> logstash –f  Logstash.conf

inlog2.log

File masukan kita berisi dua kejadian yang dipisahkan oleh pembatas default, yaitu pembatas baris baru. Peristiwa pertama cocok dengan pola yang ditentukan dalam GROk dan peristiwa kedua tidak.

GET /tutorialspoint/Logstash
Input 1234

outlog2.log

Kita dapat melihat bahwa acara keluaran kedua berisi tag "_grokparsefailure", karena tidak cocok dengan pola filter grok. Pengguna juga dapat menghapus kejadian yang tidak cocok ini dalam keluaran dengan menggunakan‘if’ kondisi di plugin keluaran.

{
   "path":"C:/tpwork/logstash/bin/log/inlog2.log",
   "@timestamp":"2016-12-13T02:47:10.352Z","@version":"1","host":"Dell-PC","verb":"GET",
   "message":"GET /tutorialspoint/logstash", "uri":"/tutorialspoint/logstash", "tags":[]
}
{
   "path":"C:/tpwork/logstash/bin/log/inlog2.log",
   "@timestamp":"2016-12-13T02:48:12.418Z", "@version":"1", "host":"Dell-PC",
   "message":"t 1234\r", "tags":["_grokparsefailure"]
}

Log dari server atau sumber data yang berbeda dikumpulkan menggunakan pengirim. Pengirim adalah instance Logstash yang dipasang di server, yang mengakses log server dan mengirim ke lokasi keluaran tertentu.

Ini terutama mengirimkan output ke Elasticsearch untuk disimpan. Logstash mengambil masukan dari sumber berikut -

  • STDIN
  • Syslog
  • Files
  • TCP/UDP
  • Microsoft Windows Eventlogs
  • Websocket
  • Zeromq
  • Ekstensi yang disesuaikan

Mengumpulkan Log Menggunakan Server Apache Tomcat 7

Dalam contoh ini, kami mengumpulkan log dari Apache Tomcat 7 Server yang diinstal di windows menggunakan plugin input file dan mengirimkannya ke log lain.

logstash.conf

Di sini, Logstash dikonfigurasi untuk mengakses log akses Apache Tomcat 7 yang diinstal secara lokal. Pola regex digunakan dalam pengaturan jalur plugin file untuk mendapatkan data dari file log. Ini berisi "akses" dalam namanya dan menambahkan jenis apache, yang membantu dalam membedakan peristiwa apache dari yang lain di sumber tujuan terpusat. Akhirnya, acara keluaran akan ditampilkan di output.log.

input {
   file {
      path => "C:/Program Files/Apache Software Foundation/Tomcat 7.0/logs/*access*"
      type => "apache"
   }
} 
output {
   file {
      path => "C:/tpwork/logstash/bin/log/output.log"
   }
}

Jalankan Logstash

Kita dapat menjalankan Logstash dengan menggunakan perintah berikut.

C:\logstash\bin> logstash –f  Logstash.conf

Log Apache Tomcat

Akses Server Apache Tomcat dan aplikasi webnya (http://localhost:8080) untuk menghasilkan log. Data yang diperbarui di log dibaca oleh Logstash secara real time dan disimpan di output.log seperti yang ditentukan dalam file konfigurasi.

Apache Tomcat membuat file log akses baru sesuai dengan tanggal dan mencatat peristiwa akses di sana. Dalam kasus kami, itu localhost_access_log.2016-12-24.txt dilogs direktori Apache Tomcat.

0:0:0:0:0:0:0:1 - - [
   25/Dec/2016:18:37:00 +0800] "GET / HTTP/1.1" 200 11418
0:0:0:0:0:0:0:1 - munish [
   25/Dec/2016:18:37:02 +0800] "GET /manager/html HTTP/1.1" 200 17472
0:0:0:0:0:0:0:1 - - [
   25/Dec/2016:18:37:08 +0800] "GET /docs/ HTTP/1.1" 200 19373
0:0:0:0:0:0:0:1 - - [
   25/Dec/2016:18:37:10 +0800] "GET /docs/introduction.html HTTP/1.1" 200 15399

output.log

Anda dapat melihat di acara keluaran, bidang tipe ditambahkan dan acara hadir di bidang pesan.

{
   "path":"C:/Program Files/Apache Software Foundation/Tomcat 7.0/logs/
   localhost_access_log.2016-12-25.txt",
   "@timestamp":"2016-12-25T10:37:00.363Z","@version":"1","host":"Dell-PC",
   "message":"0:0:0:0:0:0:0:1 - - [25/Dec/2016:18:37:00 +0800] \"GET /
   HTTP/1.1\" 200 11418\r","type":"apache","tags":[]
}
{
   "path":"C:/Program Files/Apache Software Foundation/Tomcat 7.0/logs/
   localhost_access_log.2016-12-25.txt","@timestamp":"2016-12-25T10:37:10.407Z",
   "@version":"1","host":"Dell-PC",
   "message":"0:0:0:0:0:0:0:1 - munish [25/Dec/2016:18:37:02 +0800] \"GET /
   manager/html HTTP/1.1\" 200 17472\r","type":"apache","tags":[]
}
{
   "path":"C:/Program Files/Apache Software Foundation/Tomcat 7.0/logs/
   localhost_access_log.2016-12-25.txt","@timestamp":"2016-12-25T10:37:10.407Z",
   "@version":"1","host":"Dell-PC",
   "message":"0:0:0:0:0:0:0:1 - - [25/Dec/2016:18:37:08 +0800] \"GET /docs/
   HTTP/1.1\" 200 19373\r","type":"apache","tags":[]
}
{
   "path":"C:/Program Files/Apache Software Foundation/Tomcat 7.0/logs/
   localhost_access_log.2016-12-25.txt","@timestamp":"2016-12-25T10:37:20.436Z",
   "@version":"1","host":"Dell-PC",
   "message":"0:0:0:0:0:0:0:1 - - [25/Dec/2016:18:37:10 +0800] \"GET /docs/
   introduction.html HTTP/1.1\" 200 15399\r","type":"apache","tags":[]
}

Mengumpulkan Log Menggunakan Plugin STDIN

Pada bagian ini, kita akan membahas contoh lain mengumpulkan log menggunakan STDIN Plugin.

logstash.conf

Ini adalah contoh yang sangat sederhana, di mana Logstash membaca peristiwa yang dimasukkan oleh pengguna dalam input standar. Dalam kasus kami, ini adalah command prompt, yang menyimpan kejadian di file output.log.

input {
   stdin{}
}
output {
   file {
      path => "C:/tpwork/logstash/bin/log/output.log"
   }
}

Jalankan Logstash

Kita dapat menjalankan Logstash dengan menggunakan perintah berikut.

C:\logstash\bin> logstash –f  Logstash.conf

Tulis teks berikut di command prompt -

Pengguna memasuki dua baris berikut. Logstash memisahkan acara dengan pengaturan pembatas dan nilainya secara default adalah '\ n'. Pengguna dapat mengubah dengan mengubah nilai pembatas di file plugin.

Tutorialspoint.com welcomes you
Simply easy learning

output.log

Blok kode berikut menunjukkan data log keluaran.

{
   "@timestamp":"2016-12-25T11:41:16.518Z","@version":"1","host":"Dell-PC",
   "message":"tutrialspoint.com welcomes you\r","tags":[]
}
{
   "@timestamp":"2016-12-25T11:41:53.396Z","@version":"1","host":"Dell-PC",
   "message":"simply easy learning\r","tags":[]
}

Logstash mendukung sejumlah besar log dari berbagai sumber. Ini bekerja dengan sumber terkenal seperti yang dijelaskan di bawah ini.

Kumpulkan Log dari Metrik

Peristiwa sistem dan aktivitas waktu lainnya dicatat dalam metrik. Logstash dapat mengakses log dari metrik sistem dan memprosesnya menggunakan filter. Ini membantu untuk menunjukkan kepada pengguna umpan langsung dari acara dengan cara yang disesuaikan. Metrik dikosongkan sesuai denganflush_interval settingfilter metrik dan secara default; ini disetel ke 5 detik.

Kami melacak metrik pengujian yang dihasilkan oleh Logstash, dengan mengumpulkan dan menganalisis acara yang berjalan melalui Logstash dan menampilkan umpan langsung pada prompt perintah.

logstash.conf

Konfigurasi ini berisi plugin generator, yang ditawarkan oleh Logstash untuk metrik pengujian dan menyetel setelan jenis ke "dihasilkan" untuk penguraian. Pada fase pemfilteran, kami hanya memproses baris dengan tipe yang dihasilkan dengan menggunakan pernyataan 'jika'. Kemudian, plugin metrik menghitung bidang yang ditentukan dalam pengaturan meteran. Plugin metrik menghapus hitungan setelah setiap 5 detik yang ditentukan diflush_interval.

Terakhir, keluarkan peristiwa filter ke keluaran standar seperti prompt perintah menggunakan codec pluginuntuk pemformatan. Plugin Codec menggunakan nilai [ events ] [ rate_1m ] untuk mengeluarkan kejadian per detik dalam jendela geser 1 menit.

input {
   generator {
     	type => "generated"
   }
}
filter {
   if [type] == "generated" {
      metrics {
         meter => "events"
         add_tag => "metric"
      }
   }
}
output {
   # only emit events with the 'metric' tag
   if "metric" in [tags] {
      stdout {
         codec => line { format => "rate: %{[events][rate_1m]}"
      }
   }
}

Jalankan Logstash

Kita dapat menjalankan Logstash dengan menggunakan perintah berikut.

>logsaths –f logstash.conf

stdout (prompt perintah)

rate: 1308.4
rate: 1308.4
rate: 1368.654529135342
rate: 1416.4796003951449
rate: 1464.974293984808
rate: 1523.3119444107458
rate: 1564.1602979542715
rate: 1610.6496496890895
rate: 1645.2184750334154
rate: 1688.7768007612485
rate: 1714.652283095914
rate: 1752.5150680019278
rate: 1785.9432934744932
rate: 1806.912181962126
rate: 1836.0070454626025
rate: 1849.5669494173826
rate: 1871.3814756851832
rate: 1883.3443123790712
rate: 1906.4879113216743
rate: 1925.9420717997118
rate: 1934.166137658981
rate: 1954.3176526556897
rate: 1957.0107444542625

Kumpulkan Log dari Server Web

Server web menghasilkan log dalam jumlah besar terkait akses pengguna dan kesalahan. Logstash membantu mengekstrak log dari server yang berbeda menggunakan plugin input dan menyimpannya di lokasi terpusat.

Kami mengekstrak data dari stderr logs dari Server Apache Tomcat lokal dan menyimpannya di output.log.

logstash.conf

File konfigurasi Logstash ini mengarahkan Logstash untuk membaca log error apache dan menambahkan tag bernama "apache-error". Kita cukup mengirimkannya ke output.log menggunakan plugin file output.

input {
   file {
      path => "C:/Program Files/Apache Software Foundation/Tomcat 7.0 /logs/*stderr*"
      type => "apache-error"  
   }
} 
output {
   file {
      path => "C:/tpwork/logstash/bin/log/output.log"
   }
}

Jalankan Logstash

Kita dapat menjalankan Logstash dengan menggunakan perintah berikut.

>Logstash –f Logstash.conf

Contoh dari Input log

Ini sampelnya stderr log, yang dihasilkan saat peristiwa server terjadi di Apache Tomcat.

C: \ Program Files \ Apache Software Foundation \ Tomcat 7.0 \ logs \ tomcat7-stderr.2016-12-25.log

Dec 25, 2016 7:05:14 PM org.apache.coyote.AbstractProtocol start
INFO: Starting ProtocolHandler ["http-bio-9999"]
Dec 25, 2016 7:05:14 PM org.apache.coyote.AbstractProtocol start
INFO: Starting ProtocolHandler ["ajp-bio-8009"]
Dec 25, 2016 7:05:14 PM org.apache.catalina.startup.Catalina start
INFO: Server startup in 823 ms

output.log

{
   "path":"C:/Program Files/Apache Software Foundation/Tomcat 7.0/logs/
   tomcat7-stderr.2016-12-25.log","@timestamp":"2016-12-25T11:05:27.045Z",
   "@version":"1","host":"Dell-PC",
   "message":"Dec 25, 2016 7:05:14 PM org.apache.coyote.AbstractProtocol start\r",
   "type":"apache-error","tags":[]
}
{
   "path":"C:/Program Files/Apache Software Foundation/Tomcat 7.0/logs/
   tomcat7-stderr.2016-12-25.log","@timestamp":"2016-12-25T11:05:27.045Z",
   "@version":"1","host":"Dell-PC",
   "message":"INFO: Starting ProtocolHandler [
      \"ajp-bio-8009\"]\r","type":"apache-error","tags":[]
}
{
   "path":"C:/Program Files/Apache Software Foundation/Tomcat 7.0/logs/
   tomcat7-stderr.2016-12-25.log","@timestamp":"2016-12-25T11:05:27.045Z",
   "@version":"1","host":"Dell-PC",
   "message":"Dec 25, 2016 7:05:14 PM org.apache.catalina.startup.Catalina start\r",
   "type":"apache-error","tags":[]
}
{
   "path":"C:/Program Files/Apache Software Foundation/Tomcat 7.0/logs/
   tomcat7-stderr.2016-12-25.log","@timestamp":"2016-12-25T11:05:27.045Z",
   "@version":"1","host":"Dell-PC",
   "message":"INFO: Server startup in 823 ms\r","type":"apache-error","tags":[]
}

Kumpulkan Log dari sumber Data

Untuk memulainya, mari kita pahami cara Mengkonfigurasi MySQL untuk logging. Tambahkan baris berikutmy.ini file dari server database MySQL di bawah [mysqld].

Di windows, itu ada di dalam direktori instalasi MySQL, yang ada di -

C:\wamp\bin\mysql\mysql5.7.11

Di UNIX, Anda dapat menemukannya di - /etc/mysql/my.cnf

general_log_file   = "C:/wamp/logs/queries.log"
general_log = 1

logstash.conf

Dalam file konfigurasi ini, file plugin digunakan untuk membaca log MySQL dan menuliskannya ke ouput.log.

input {
   file {
      path => "C:/wamp/logs/queries.log"
   }
}
output {
   file {
      path => "C:/tpwork/logstash/bin/log/output.log"
   }
}

queries.log

Ini adalah log yang dihasilkan oleh kueri yang dijalankan di database MySQL.

2016-12-25T13:05:36.854619Z   2 Query		select * from test1_users
2016-12-25T13:05:51.822475Z    2 Query	select count(*) from users
2016-12-25T13:05:59.998942Z    2 Query         select count(*) from test1_users

output.log

{
   "path":"C:/wamp/logs/queries.log","@timestamp":"2016-12-25T13:05:37.905Z",
   "@version":"1","host":"Dell-PC",
   "message":"2016-12-25T13:05:36.854619Z    2 Query\tselect * from test1_users",
   "tags":[]
}
{
   "path":"C:/wamp/logs/queries.log","@timestamp":"2016-12-25T13:05:51.938Z",
   "@version":"1","host":"Dell-PC",
   "message":"2016-12-25T13:05:51.822475Z    2 Query\tselect count(*) from users",
   "tags":[]
}
{
   "path":"C:/wamp/logs/queries.log","@timestamp":"2016-12-25T13:06:00.950Z",
   "@version":"1","host":"Dell-PC",
   "message":"2016-12-25T13:05:59.998942Z    2 Query\tselect count(*) from test1_users",
   "tags":[]
}

Logstash menerima log menggunakan plugin input dan kemudian menggunakan plugin filter untuk mengurai dan mengubah data. Penguraian dan transformasi log dilakukan sesuai dengan sistem yang ada di tujuan keluaran. Logstash mem-parsing data logging dan hanya meneruskan bidang yang diperlukan. Kemudian, bidang ini diubah menjadi bentuk yang kompatibel dan dapat dipahami sistem tujuan.

Bagaimana cara mengurai Log?

Parsing log dilakukan saya menggunakan GROK Pola (Representasi Grafis Pengetahuan) dan Anda dapat menemukannya di Github -

https://github.com/elastic/logstash/tree/v1.4.2/patterns.

Logstash mencocokkan data log dengan Pola GROK tertentu atau urutan pola untuk menguraikan log seperti "% {COMBINEDAPACHELOG}", yang biasanya digunakan untuk log apache.

Data yang diurai lebih terstruktur dan mudah ditelusuri serta untuk menjalankan kueri. Logstash mencari pola GROK yang ditentukan di log masukan dan mengekstrak garis yang cocok dari log. Anda dapat menggunakan debugger GROK untuk menguji pola GROK Anda.

Sintaks untuk pola GROK adalah% {SYNTAX: SEMANTIC}. Filter Logstash GROK ditulis dalam bentuk berikut -

%{PATTERN:FieldName}

Di sini, PATTERN mewakili pola GROK dan nama bidang adalah nama bidang, yang mewakili data yang diurai dalam keluaran.

Misalnya, menggunakan debugger GROK online https://grokdebug.herokuapp.com/

Memasukkan

Contoh baris kesalahan dalam log -

[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

Urutan Pola GROK

Urutan pola GROK ini cocok dengan peristiwa log, yang terdiri dari stempel waktu yang diikuti oleh Tingkat Log, Id Proses, Id Transaksi, dan Pesan Kesalahan.

\[(%{DAY:day} %{MONTH:month} %{MONTHDAY} %{TIME} %{YEAR})\] \[.*:%{LOGLEVEL:loglevel}\]
   \[pid %{NUMBER:pid}:tid %{NUMBER:tid}\] \[client %{IP:clientip}:.*\]
   %{GREEDYDATA:errormsg}

keluaran

Outputnya dalam format 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"
   ]
}

Logstash menggunakan filter di tengah jalur antara input dan output. Filter tindakan Logstash memanipulasi dan membuat acara sepertiApache-Access. Banyak plugin filter yang digunakan untuk mengelola acara di Logstash. Di sini, dalam contoh fileLogstash Aggregate Filter, kami memfilter durasi setiap transaksi SQL dalam database dan menghitung total waktu.

Memasang Plugin Filter Agregat

Menginstal Plugin Filter Agregat menggunakan utilitas Logstash-plugin. Plugin Logstash adalah file batch untuk windowsbin folder di Logstash.

>logstash-plugin install logstash-filter-aggregate

logstash.conf

Dalam konfigurasi ini, Anda dapat melihat tiga pernyataan 'jika' untuk Initializing, Incrementing, dan generating total durasi transaksi, yaitu sql_duration. Plugin agregat digunakan untuk menambahkan sql_duration, yang ada di setiap acara log input.

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
      }
   }
}
output {
   file {
      path => "C:/tpwork/logstash/bin/log/output.log"    
   }
}

Jalankan Logstash

Kita dapat menjalankan Logstash dengan menggunakan perintah berikut.

>logstash –f logstash.conf

input.log

Blok kode berikut menunjukkan data log masukan.

INFO - 48566 - TRANSACTION_START - start
INFO - 48566 - SQL - transaction1 - 320
INFO - 48566 - SQL - transaction1 - 200
INFO - 48566 - TRANSACTION_END - end

output.log

Seperti yang ditentukan dalam file konfigurasi, pernyataan 'jika' terakhir di mana logger berada - TRANSACTION_END, yang mencetak total waktu transaksi atau sql_duration. Ini telah disorot dengan warna kuning di output.log.

{
   "path":"C:/tpwork/logstash/bin/log/input.log","@timestamp": "2016-12-22T19:04:37.214Z",
   "loglevel":"INFO","logger":"TRANSACTION_START","@version": "1","host":"wcnlab-PC",
   "message":"8566 - TRANSACTION_START - start\r","tags":[]
}
{
   "duration":320,"path":"C:/tpwork/logstash/bin/log/input.log",
   "@timestamp":"2016-12-22T19:04:38.366Z","loglevel":"INFO","logger":"SQL",
   "@version":"1","host":"wcnlab-PC","label":"transaction1",
   "message":" INFO - 48566 - SQL - transaction1 - 320\r","taskid":"48566","tags":[]
}
{
   "duration":200,"path":"C:/tpwork/logstash/bin/log/input.log",
   "@timestamp":"2016-12-22T19:04:38.373Z","loglevel":"INFO","logger":"SQL",
   "@version":"1","host":"wcnlab-PC","label":"transaction1",
   "message":" INFO - 48566 - SQL - transaction1 - 200\r","taskid":"48566","tags":[]
}
{
   "sql_duration":520,"path":"C:/tpwork/logstash/bin/log/input.log",
   "@timestamp":"2016-12-22T19:04:38.380Z","loglevel":"INFO","logger":"TRANSACTION_END",
   "@version":"1","host":"wcnlab-PC","label":"end",
   "message":" INFO - 48566 - TRANSACTION_END - end\r","taskid":"48566","tags":[]
}

Logstash menawarkan berbagai plugin untuk mengubah log yang diurai. Plugin ini bisaAdd, Delete, dan Update bidang di log untuk pemahaman dan kueri yang lebih baik dalam sistem keluaran.

Kami menggunakan Mutate Plugin untuk menambahkan pengguna nama bidang di setiap baris log masukan.

Instal Plugin Filter Mutate

Untuk menginstal plugin filter mutasi; kita bisa menggunakan perintah berikut.

>Logstash-plugin install Logstash-filter-mutate

logstash.conf

Dalam file konfigurasi ini, Plugin Mutate ditambahkan setelah Plugin Agregat untuk menambahkan bidang baru.

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 {
   file {
      path => "C:/tpwork/logstash/bin/log/output.log"
   }
}

Jalankan Logstash

Kita dapat menjalankan Logstash dengan menggunakan perintah berikut.

>logstash –f logstash.conf

input.log

Blok kode berikut menunjukkan data log masukan.

INFO - 48566 - TRANSACTION_START - start
INFO - 48566 - SQL - transaction1 - 320
INFO - 48566 - SQL - transaction1 - 200
INFO - 48566 - TRANSACTION_END - end

output.log

Anda dapat melihat bahwa ada bidang baru bernama "pengguna" di acara keluaran.

{
   "path":"C:/tpwork/logstash/bin/log/input.log",
   "@timestamp":"2016-12-25T19:55:37.383Z",
   "@version":"1",
   "host":"wcnlab-PC",
   "message":"NFO - 48566 - TRANSACTION_START - start\r",
   "user":"tutorialspoint.com","tags":["_grokparsefailure"]
}
{
   "duration":320,"path":"C:/tpwork/logstash/bin/log/input.log",
   "@timestamp":"2016-12-25T19:55:37.383Z","loglevel":"INFO","logger":"SQL",
   "@version":"1","host":"wcnlab-PC","label":"transaction1",
   "message":" INFO - 48566 - SQL - transaction1 - 320\r",
   "user":"tutorialspoint.com","taskid":"48566","tags":[]
}
{
   "duration":200,"path":"C:/tpwork/logstash/bin/log/input.log",
   "@timestamp":"2016-12-25T19:55:37.399Z","loglevel":"INFO",
   "logger":"SQL","@version":"1","host":"wcnlab-PC","label":"transaction1",
   "message":" INFO - 48566 - SQL - transaction1 - 200\r",
   "user":"tutorialspoint.com","taskid":"48566","tags":[]
}
{
   "sql_duration":520,"path":"C:/tpwork/logstash/bin/log/input.log",
   "@timestamp":"2016-12-25T19:55:37.399Z","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":[]
}

Output adalah tahap terakhir dalam pipeline Logstash, yang mengirim data filter dari log input ke tujuan yang ditentukan. Logstash menawarkan beberapa plugin keluaran untuk menyimpan peristiwa log yang difilter ke berbagai penyimpanan dan mesin pencari yang berbeda.

Menyimpan Log

Logstash dapat menyimpan log yang difilter di file File, Elasticsearch Engine, stdout, AWS CloudWatch, dll. Protokol jaringan seperti TCP, UDP, Websocket juga dapat digunakan di Logstash untuk mentransfer peristiwa log ke sistem penyimpanan jarak jauh.

Dalam tumpukan ELK, pengguna menggunakan mesin Elasticsearch untuk menyimpan peristiwa log. Di sini, pada contoh berikut, kami akan membuat peristiwa log untuk mesin Elasticsearch lokal.

Menginstal Plugin Output Elasticsearch

Kita dapat menginstal plugin keluaran Elasticsearch dengan perintah berikut.

>logstash-plugin install Logstash-output-elasticsearch

logstash.conf

File konfigurasi ini berisi plugin Elasticsearch, yang menyimpan acara keluaran di Elasticsearch yang diinstal secara lokal.

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

Blok kode berikut menunjukkan data log masukan.

INFO - 48566 - TRANSACTION_START - start
INFO - 48566 - SQL - transaction1 - 320
INFO - 48566 - SQL - transaction1 - 200
INFO - 48566 - TRANSACTION_END - end

Mulai Elasticsearch di Localhost

Untuk memulai Elasticsearch di localhost, Anda harus menggunakan perintah berikut.

C:\elasticsearch\bin> elasticsearch

Setelah Elasticsearch siap, Anda dapat memeriksanya dengan mengetik URL berikut di browser Anda.

http://localhost:9200/

Tanggapan

Blok kode berikut menunjukkan respons Elasticsearch di localhost.

{
   "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 - Untuk informasi lebih lanjut tentang Elasticsearch, Anda dapat mengklik tautan berikut.

https://www.tutorialspoint.com/elasticsearch/index.html

Sekarang, jalankan Logstash dengan Logstash.conf yang disebutkan di atas

>Logstash –f Logstash.conf

Setelah menempelkan teks yang disebutkan di atas di log keluaran, teks itu akan disimpan di Elasticsearch oleh Logstash. Anda dapat memeriksa data yang disimpan dengan mengetikkan URL berikut di browser.

http://localhost:9200/logstash-2017.01.01/_search?pretty

Tanggapan

Ini adalah data dalam format JSON yang disimpan dalam indeks 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":[]
         }
      }
   }
}

Logstash menyediakan banyak Plugin untuk mendukung berbagai penyimpanan data atau mesin pencari. Peristiwa keluaran log dapat dikirim ke file keluaran, keluaran standar atau mesin pencari seperti Elasticsearch. Ada tiga jenis keluaran yang didukung di Logstash, yaitu -

  • Output Standar
  • Keluaran File
  • Output Nihil

Sekarang mari kita bahas masing-masing secara mendetail.

Output Standar (stdout)

Ini digunakan untuk menghasilkan peristiwa log yang difilter sebagai aliran data ke antarmuka baris perintah. Berikut adalah contoh menghasilkan total durasi transaksi database ke stdout.

logstash.conf

File konfigurasi ini berisi plugin output stdout untuk menulis total sql_duration ke output standar.

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
      }
   }
}
output {
   if [logger] == "TRANSACTION_END" {
      stdout {
         codec => line{format => "%{sql_duration}"}
      }
   }
}

Note - Harap instal filter agregat, jika belum diinstal.

>logstash-plugin install Logstash-filter-aggregate

Jalankan Logstash

Kita dapat menjalankan Logstash dengan menggunakan perintah berikut.

>logstash –f logsatsh.conf

Input.log

Blok kode berikut menunjukkan data log masukan.

INFO - 48566 - TRANSACTION_START - start
INFO - 48566 - SQL - transaction1 - 320
INFO - 48566 - SQL - transaction1 - 200
INFO - 48566 - TRANSACTION_END – end

stdout (ini akan menjadi command prompt di windows atau terminal di UNIX)

Ini adalah total sql_duration 320 + 200 = 520.

520

Keluaran File

Logstash juga dapat menyimpan peristiwa log filter ke file keluaran. Kami akan menggunakan contoh yang disebutkan di atas dan menyimpan hasilnya dalam file, bukan STDOUT.

logstash.conf

File konfigurasi Logstash ini mengarahkan Logstash untuk menyimpan total sql_duration ke file log keluaran.

input {
   file {
      path => "C:/tpwork/logstash/bin/log/input1.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
      }
   }
}
output {
   if [logger] == "TRANSACTION_END" {
      file {
         path => "C:/tpwork/logstash/bin/log/output.log"
         codec => line{format => "%{sql_duration}"}
      }
   }
}

Jalankan logstash

Kita dapat menjalankan Logstash dengan menggunakan perintah berikut.

>logstash –f logsatsh.conf

input.log

Blok kode berikut menunjukkan data log masukan.

INFO - 48566 - TRANSACTION_START - start
INFO - 48566 - SQL - transaction1 - 320
INFO - 48566 - SQL - transaction1 - 200
INFO - 48566 - TRANSACTION_END – end

output.log

Blok kode berikut menunjukkan data log keluaran.

520

Output Nihil

Ini adalah plugin keluaran khusus, yang digunakan untuk menganalisis kinerja plugin masukan dan filter.

Logstash menawarkan berbagai plugin untuk ketiga tahap pipeline-nya (Input, Filter, dan Output). Plugin ini membantu pengguna untuk menangkap log dari berbagai sumber seperti Server Web, Database, Over Network Protocols, dll.

Setelah menangkap, Logstash dapat mengurai dan mengubah data menjadi informasi yang bermakna seperti yang diperlukan oleh pengguna. Terakhir, Logstash dapat mengirim atau menyimpan informasi yang berarti tersebut ke berbagai sumber tujuan seperti Elasticsearch, AWS Cloudwatch, dll.

Plugin Input

Plugin input di Logstash membantu pengguna mengekstrak dan menerima log dari berbagai sumber. Sintaks untuk menggunakan plugin input adalah sebagai berikut -

Input {
   Plugin name {
      Setting 1……
      Setting 2……..
   }
}

Anda dapat mengunduh plugin input dengan menggunakan perintah berikut -

>Logstash-plugin install Logstash-input-<plugin name>

Utilitas Logstash-plugin ada di bin folderdari direktori instalasi Logstash. Tabel berikut memiliki daftar plugin input yang ditawarkan oleh Logstash.

Sr.No. Nama & Deskripsi plugin
1

beats

Untuk mendapatkan data atau peristiwa logging dari kerangka elastic beats.

2

cloudwatch

Untuk mengekstrak kejadian dari CloudWatch, tawaran API oleh Amazon Web Services.

3

couchdb_changes

Acara dari _chages URI couchdb dikirim menggunakan plugin ini.

4

drupal_dblog

Untuk mengekstrak data logging pengawas drupal dengan mengaktifkan DBLog.

5

Elasticsearch

Untuk mengambil hasil query yang dilakukan di cluster Elasticsearch.

6

eventlog

Untuk mendapatkan acara dari windows event log.

7

exec

Untuk mendapatkan keluaran perintah shell sebagai masukan di Logstash.

8

file

Untuk mendapatkan acara dari file input. Ini berguna, ketika Logstash diinstal secara lokal dengan sumber masukan dan memiliki akses ke log sumber masukan.

9

generator

Ini digunakan untuk tujuan pengujian, yang membuat peristiwa acak.

10

github

Merekam peristiwa dari webhook GitHub.

11

graphite

Untuk mendapatkan data metrik dari alat pemantauan grafit.

12

heartbeat

Ini juga digunakan untuk pengujian dan menghasilkan peristiwa seperti detak jantung

13

http

Untuk mengumpulkan peristiwa log melalui dua protokol jaringan dan itu adalah http dan https.

14

http_poller

Ini digunakan untuk mendekode keluaran API HTTP ke sebuah acara.

15

jdbc

Ini mengubah transaksi JDBC menjadi acara di Logstash.

16

jmx

Untuk mengekstrak metrik dari aplikasi java jarak jauh menggunakan JMX.

17

log4j

Menangkap peristiwa dari objek socketAppender dari Log4j melalui soket TCP.

18

rss

Untuk keluaran alat baris perintah sebagai peristiwa masukan di Logstash.

19

tcp

Menangkap peristiwa melalui soket TCP.

20

twitter

Kumpulkan acara dari Twitter streaming API.

21

unix

Kumpulkan acara melalui soket UNIX.

22

websocket

Rekam peristiwa melalui protokol websocket.

23

xmpp

Membaca peristiwa melalui protokol Jabber / xmpp.

Pengaturan Plugin

Semua plugin memiliki pengaturan khusus, yang membantu menentukan bidang penting seperti Port, Path, dll., Di dalam plugin. Kami akan membahas pengaturan dari beberapa plugin input.

Mengajukan

Plugin input ini digunakan untuk mengekstrak kejadian secara langsung dari log atau file teks yang ada di sumber input. Ia bekerja mirip dengan perintah tail di UNIX dan menyimpan kursor baca terakhir dan hanya membaca data baru yang ditambahkan dari file input, tetapi dapat diubah dengan menggunakan pengaturan star_position. Berikut adalah pengaturan plugin input ini.

Nama Pengaturan Nilai Default Deskripsi
add_field {} Tambahkan bidang baru ke acara masukan.
close_older 3600 File yang memiliki waktu baca terakhir (dalam detik) lebih dari yang ditentukan dalam plugin ini ditutup.
codec "polos" Ini digunakan untuk memecahkan kode data sebelum masuk ke pipa Logstash.
pembatas “\ N” Ini digunakan untuk menentukan pembatas baris baru.
Discover_interval 15 Ini adalah interval waktu (dalam detik) antara menemukan file baru di jalur yang ditentukan.
enable_metric benar Ini digunakan untuk mengaktifkan atau menonaktifkan pelaporan dan pengumpulan metrik untuk plugin yang ditentukan.
mengecualikan Ini digunakan untuk menentukan nama file atau pola, yang harus dikecualikan dari plugin input.
Indo Untuk menentukan identitas unik untuk instance plugin itu.
max_open_files Ini menentukan jumlah maksimum file input oleh Logstash kapan saja.
jalan Tentukan jalur file dan itu dapat berisi pola untuk nama file.
posisi awal "akhir" Anda dapat mengubah ke "awal", jika Anda menginginkannya; awalnya Logstash harus mulai membaca file dari awal dan tidak hanya peristiwa log baru.
start_interval 1 Ini menentukan interval waktu dalam hitungan detik, setelah itu Logstash memeriksa file yang dimodifikasi.
tag Untuk menambahkan informasi tambahan apa pun, seperti Logstash, ia menambahkan "_grokparsefailure" di tag, saat peristiwa log apa pun gagal mematuhi filter grok yang ditentukan.
Tipe Ini adalah bidang khusus, yang dapat Anda tambahkan ke acara masukan dan berguna dalam filter dan kibana.

Elasticsearch

Plugin khusus ini digunakan untuk membaca hasil kueri penelusuran di cluster Elasticsearch. Berikut ini adalah pengaturan yang digunakan dalam plugin ini -

Nama Pengaturan Nilai Default Deskripsi
add_field {} Sama seperti di file plugin, ini digunakan untuk menambahkan bidang di acara masukan.
ca_file Ini digunakan untuk menentukan jalur file Otoritas sertifikat SSL.
codec "polos" Ini digunakan untuk mendekode peristiwa input dari Elasticsearch sebelum masuk ke pipeline Logstash.
docinfo "Salah" Anda dapat mengubahnya menjadi true, jika Anda ingin mengekstrak informasi tambahan seperti indeks, jenis dan id dari mesin Elasticsearch.
docinfo_fields ["_index", "_type", "_id"] Anda dapat menghilangkan bidang apa pun, yang tidak Anda inginkan di masukan Logstash Anda.
enable_metric benar Ini digunakan untuk mengaktifkan atau menonaktifkan pelaporan dan pengumpulan metrik untuk instance plugin itu.
tuan rumah Ini digunakan untuk menentukan alamat semua mesin elasticsearch, yang akan menjadi sumber input dari instance Logstash itu. Sintaksnya adalah host: port atau IP: port.
Indo Ini digunakan untuk memberikan nomor identitas unik ke instance plugin input tertentu.
indeks "logstash- *" Ini digunakan untuk menentukan nama indeks atau pola, yang akan dipantau oleh Logstash oleh Logstash untuk input.
kata sandi Untuk tujuan otentikasi.
pertanyaan "{\" urutkan \ ": [\" _ doc \ "]}" Permintaan untuk eksekusi.
ssl Salah Mengaktifkan atau menonaktifkan lapisan soket aman.
tag Untuk menambahkan informasi tambahan dalam acara masukan.
Tipe Ini digunakan untuk mengklasifikasikan formulir masukan sehingga mudah untuk mencari semua peristiwa masukan di tahap selanjutnya.
pengguna Untuk tujuan otentik.

eventlog

Plugin input ini membaca data dari win32 API server windows. Berikut ini adalah pengaturan plugin ini -

Nama Pengaturan Nilai Default Deskripsi
add_field {} Sama seperti di file plugin, ini digunakan untuk menambahkan bidang di acara masukan
codec "polos" Ini digunakan untuk memecahkan kode peristiwa input dari windows; sebelum masuk ke pipeline Logstash
logfile ["Aplikasi", "Keamanan", "Sistem"] Acara yang diperlukan dalam file log masukan
selang 1000 Ini dalam milidetik dan menentukan interval antara dua pemeriksaan berturut-turut dari log peristiwa baru
tag Untuk menambahkan informasi tambahan dalam acara masukan
Tipe Ini digunakan untuk mengklasifikasikan formulir masukan plugin tertentu untuk jenis yang diberikan, sehingga akan mudah untuk mencari semua peristiwa masukan di tahap selanjutnya

Indonesia

Plugin input ini digunakan untuk mengumpulkan feed twitter dari Streaming API-nya. Tabel berikut menjelaskan pengaturan plugin ini.

Nama Pengaturan Nilai Default Deskripsi
add_field {} Sama seperti di file plugin, ini digunakan untuk menambahkan bidang di acara masukan
codec "polos" Ini digunakan untuk memecahkan kode peristiwa input dari windows; sebelum masuk ke pipeline Logstash
kunci_konsumen Ini berisi kunci konsumen aplikasi twitter. Untuk info lebih lanjut, kunjungihttps://dev.twitter.com/apps/new
rahasia_konsumen Berisi kunci rahasia konsumen aplikasi twitter. Untuk info lebih lanjut, kunjungihttps://dev.twitter.com/apps/new
enable_metric benar Ini digunakan untuk mengaktifkan atau menonaktifkan pelaporan dan pengumpulan metrik untuk instance plugin itu
mengikuti

Ini menentukan id pengguna yang dipisahkan dengan koma dan LogStash memeriksa status pengguna ini di Twitter.

Untuk info lebih lanjut, kunjungi

https://dev.twitter.com

full_tweet Salah Anda dapat mengubahnya menjadi true, jika Anda ingin Logstash membaca objek lengkap yang dikembalikan dari twitter API
Indo Ini digunakan untuk memberikan nomor identitas unik ke instance plugin input tertentu
ignore_retweets Salah Anda dapat mengubah set true untuk mengabaikan retweet di feed twitter masukan
kata kunci Ini adalah susunan kata kunci, yang perlu dilacak di umpan masukan twitters
bahasa Ini mendefinisikan bahasa tweet yang dibutuhkan oleh LogStash dari masukan umpan twitter. Ini adalah larik pengenal, yang mendefinisikan bahasa tertentu di twitter
lokasi Untuk menyaring tweet dari input feed sesuai dengan lokasi yang ditentukan. Ini adalah larik, yang berisi bujur dan lintang lokasi
oauth_token Ini adalah file wajib, yang berisi token oauth pengguna. Untuk informasi lebih lanjut silahkan kunjungi link berikuthttps://dev.twitter.com/apps
oauth_token_secret Ini adalah file wajib, yang berisi token rahasia pengguna. Untuk informasi lebih lanjut silahkan kunjungi link berikuthttps://dev.twitter.com/apps
tag Untuk menambahkan informasi tambahan dalam acara masukan
Tipe Ini digunakan untuk mengklasifikasikan formulir masukan plugin tertentu untuk jenis yang diberikan, sehingga akan mudah untuk mencari semua peristiwa masukan di tahap selanjutnya

TCP

TCP digunakan untuk mendapatkan kejadian melalui soket TCP; itu dapat membaca dari koneksi pengguna atau server, yang ditentukan dalam pengaturan mode. Tabel berikut menjelaskan pengaturan plugin ini -

Nama Pengaturan Nilai Default Deskripsi
add_field {} Sama seperti di file plugin, ini digunakan untuk menambahkan bidang di acara masukan
codec "polos" Ini digunakan untuk memecahkan kode peristiwa input dari windows; sebelum masuk ke pipeline Logstash
enable_metric benar Ini digunakan untuk mengaktifkan atau menonaktifkan pelaporan dan pengumpulan metrik untuk instance plugin itu
tuan rumah "0.0.0.0" Alamat OS server tempat klien bergantung
Indo Ini berisi kunci konsumen aplikasi twitter
mode "Server" Ini digunakan untuk menentukan sumber input adalah server atau klien.
Pelabuhan Ini menentukan nomor port
ssl_cert Ini digunakan untuk menentukan jalur sertifikat SSL
ssl_enable Salah Aktifkan atau nonaktifkan SSL
ssl_key Untuk menentukan jalur file kunci SSL
tag Untuk menambahkan informasi tambahan dalam acara masukan
Tipe Ini digunakan untuk mengklasifikasikan formulir masukan plugin tertentu untuk jenis yang diberikan, sehingga akan mudah untuk mencari semua peristiwa masukan di tahap selanjutnya

Logstash - Plugin Output

Logstash mendukung berbagai sumber keluaran dan dalam berbagai teknologi seperti Basis Data, File, Email, Keluaran Standar, dll.

Sintaks untuk menggunakan plugin keluaran adalah sebagai berikut -

output {
   Plugin name {
      Setting 1……
      Setting 2……..
   }
}

Anda dapat mengunduh plugin keluaran dengan menggunakan perintah berikut -

>logstash-plugin install logstash-output-<plugin name>

Itu Logstash-plugin utilityada di folder bin dari direktori instalasi Logstash. Tabel berikut menjelaskan plugin keluaran yang ditawarkan oleh Logstash.

Sr.No. Nama & Deskripsi Plugin
1

CloudWatch

Plugin ini digunakan untuk mengirim data metrik teragregasi ke CloudWatch dari layanan web amazon.

2

csv

Ini digunakan untuk menulis acara keluaran dengan cara yang dipisahkan koma.

3

Elasticsearch

Ini digunakan untuk menyimpan log keluaran di indeks Elasticsearch.

4

email

Ini digunakan untuk mengirim email notifikasi, ketika output dihasilkan. Pengguna dapat menambahkan informasi tentang keluaran di email.

5

exec

Ini digunakan untuk menjalankan perintah, yang cocok dengan acara keluaran.

6

ganglia

Ini menggeliat metrik untuk gmond Gangila.

7

gelf

Ini digunakan untuk menghasilkan keluaran untuk Graylog2 dalam format GELF.

8

google_bigquery

Ini menghasilkan acara ke Google BigQuery.

9

google_cloud_storage

Ini menyimpan acara keluaran ke Google Cloud Storage.

10

graphite

Ini digunakan untuk menyimpan acara keluaran ke Graphite.

11

graphtastic

Ini digunakan untuk menulis metrik keluaran pada Windows.

12

hipchat

Ini digunakan untuk menyimpan peristiwa log keluaran ke HipChat.

13

http

Ini digunakan untuk mengirim peristiwa log keluaran ke titik akhir http atau https.

14

influxdb

Ini digunakan untuk menyimpan acara keluaran di InfluxDB.

15

irc

Ini digunakan untuk menulis event keluaran ke irc.

16

mongodb

Ini menyimpan data keluaran di MongoDB.

17

nagios

Ini digunakan untuk memberi tahu Nagios dengan hasil pemeriksaan pasif.

18

nagios_nsca

Ini digunakan untuk memberi tahu Nagios dengan hasil pemeriksaan pasif melalui protokol NSCA.

19

opentsdb

Ini menyimpan acara keluaran Logstash ke OpenTSDB.

20

pipe

Ini mengalirkan acara keluaran ke masukan standar dari program lain.

21

rackspace

Ini digunakan untuk mengirim peristiwa log keluaran ke layanan Antrian Rackspace Cloud.

22

redis

Ia menggunakan perintah rpush untuk mengirim data pencatatan keluaran ke antrian Redis.

23

riak

Ini digunakan untuk menyimpan acara keluaran ke pasangan kunci / nilai terdistribusi Riak.

24

s3

Ini menyimpan data pencatatan keluaran ke Amazon Simple Storage Service.

25

sns

Ini digunakan untuk mengirim kejadian keluaran ke Amazon's Simple Notification Service.

26

solr_http

Ini mengindeks dan menyimpan data pencatatan keluaran di Solr.

27

sps

Ini digunakan untuk mengirimkan acara ke Simple Queue Service of AWS.

28

statsd

Ini digunakan untuk mengirimkan data metrik ke daemon jaringan statsd.

29

stdout

Ini digunakan untuk menampilkan event output pada output standar CLI seperti command prompt.

30

syslog

Ini digunakan untuk mengirimkan acara keluaran ke server syslog.

31

tcp

Ini digunakan untuk mengirim acara keluaran ke soket TCP.

32

udp

Ini digunakan untuk mendorong acara keluaran melalui UDP.

33

websocket

Ini digunakan untuk mendorong kejadian keluaran melalui protokol WebSocket.

34

xmpp

Ini digunakan untuk mendorong kejadian keluaran melalui protokol XMPP.

Semua plugin memiliki pengaturan khusus, yang membantu menentukan bidang penting seperti Port, Path, dll., Di dalam plugin. Kami akan membahas pengaturan dari beberapa plugin keluaran.

Elasticsearch

Plugin keluaran Elasticsearch memungkinkan Logstash menyimpan keluaran di kluster tertentu mesin Elasticsearch. Ini adalah salah satu pilihan pengguna yang terkenal karena hadir dalam paket ELK Stack dan oleh karena itu, memberikan solusi ujung ke ujung untuk Devops. Tabel berikut menjelaskan pengaturan plugin keluaran ini.

Nama Pengaturan Nilai Default Deskripsi
tindakan indeks Ini digunakan untuk menentukan tindakan yang dilakukan di mesin Elasticsearch. Nilai lain untuk pengaturan ini adalah delete, create, update, dll.
cacert Ini berisi jalur file dengan .cer atau .pem untuk validasi sertifikat server.
codec "polos" Ini digunakan untuk menyandikan data pencatatan keluaran sebelum mengirimkannya ke sumber tujuan.
doc_as_upset Salah Pengaturan ini digunakan jika ada tindakan pembaruan. Ini membuat dokumen di mesin Elasticsearch, jika id dokumen tidak ditentukan dalam plugin keluaran.
tipe dokumen Ini digunakan untuk menyimpan jenis peristiwa yang sama dalam jenis dokumen yang sama. Jika tidak ditentukan, maka jenis acara digunakan untuk hal yang sama.
flush_size 500 Ini digunakan untuk meningkatkan kinerja unggahan massal di Elasticsearch
tuan rumah ["127.0.0.1"] Ini adalah larik alamat tujuan untuk data pencatatan keluaran
idle_flush_time 1 Ini mendefinisikan batas waktu (detik) antara dua flush, Logstash force flush setelah batas waktu yang ditentukan dalam pengaturan ini
indeks "logstash -% {+ YYYY.MM.dd}" Ini digunakan untuk menentukan indeks mesin Elasticsearch
manage_temlpate benar Ini digunakan untuk menerapkan template default di Elasticsearch
induk nol Ini digunakan untuk menentukan id dokumen induk di Elasticsearch
kata sandi Ini digunakan untuk mengautentikasi permintaan ke cluster aman di Elasticsearch
jalan Ini digunakan untuk menentukan jalur HTTP dari Elasticsearch.
pipa nol Ini digunakan untuk menyetel pipeline serapan, yang ingin dieksekusi oleh pengguna untuk sebuah acara
proxy Ini digunakan untuk menentukan proxy HTTP
retry_initial_interval 2 Ini digunakan untuk menyetel interval waktu awal (detik) antara percobaan ulang massal. Ini menjadi dua kali lipat setelah setiap percobaan ulang hingga mencapai retry_max_interval
retry_max_interval 64 Ini digunakan untuk mengatur interval waktu maksimum untuk retry_initial_interval
retry_on_conflict 1 Ini adalah jumlah percobaan ulang oleh Elasticsearch untuk memperbarui dokumen
ssl Untuk mengaktifkan atau menonaktifkan SSL / TLS diamankan ke Elasticsearch
template Ini berisi jalur template yang disesuaikan di Elasticsearch
template_name "logstash" Ini digunakan untuk memberi nama template di Elasticsearch
waktu habis 60 Ini adalah batas waktu untuk permintaan jaringan ke Elasticsearch
upsert "" Itu memperbarui dokumen atau jika document_id tidak ada, itu membuat dokumen baru di Elasticsearch
pengguna Ini berisi pengguna untuk mengautentikasi permintaan Logstash di cluster Elasticsearch yang aman

Surel

Plugin keluaran email digunakan untuk memberi tahu pengguna, saat Logstash menghasilkan keluaran. Tabel berikut menjelaskan pengaturan untuk plugin ini.

Nama Pengaturan Nilai Default Deskripsi
alamat “Localhost” Ini adalah alamat server email
lampiran [] Ini berisi nama dan lokasi file terlampir
tubuh "" Ini berisi badan email dan harus berupa teks biasa
cc Ini berisi alamat email dengan cara dipisahkan koma untuk cc email
codec "polos" Ini digunakan untuk menyandikan data pencatatan keluaran sebelum mengirimkannya ke sumber tujuan.
Jenis konten "teks / html; charset = UTF-8" Ini digunakan untuk tipe konten email
debug Salah Ini digunakan untuk menjalankan relai email dalam mode debug
domain "localhost" Ini digunakan untuk mengatur domain untuk mengirim pesan email
dari "[email protected]" Ini digunakan untuk menentukan alamat email pengirim
htmlbody "" Ini digunakan untuk menentukan badan email dalam format html
kata sandi Ini digunakan untuk mengautentikasi dengan server email
Pelabuhan 25 Ini digunakan untuk menentukan port untuk berkomunikasi dengan server email
membalas ke Ini digunakan untuk menentukan id email untuk bidang balas ke email
subyek "" Ini berisi baris subjek email
use_tls Salah Mengaktifkan atau menonaktifkan TSL untuk komunikasi dengan server email
nama pengguna Is berisi nama pengguna untuk otentikasi dengan server
melalui “Smtp” Ini mendefinisikan metode pengiriman email dengan Logstash

Http

Pengaturan ini digunakan untuk mengirim acara keluaran melalui http ke tujuan. Plugin ini memiliki pengaturan berikut -

Nama Pengaturan Nilai Default Deskripsi
automatic_retries 1 Ini digunakan untuk menyetel jumlah percobaan ulang permintaan http dengan logstash
cacert Ini berisi jalur file untuk validasi sertifikat server
codec "polos" Ini digunakan untuk menyandikan data pencatatan keluaran sebelum mengirimkannya ke sumber tujuan.
Jenis konten Saya menentukan jenis konten permintaan http ke server tujuan
kue benar Ini digunakan untuk mengaktifkan atau menonaktifkan cookie
format "json" Ini digunakan untuk mengatur format isi permintaan http
header Ini berisi informasi dari http header
http_method "" Ini digunakan untuk menentukan metode http yang digunakan dalam permintaan dengan logstash dan nilainya dapat berupa "put", "post", "patch", "delete", "get", "head"
request_timeout 60 Ini digunakan untuk mengautentikasi dengan server email
url Ini adalah pengaturan yang diperlukan untuk plugin ini untuk menentukan titik akhir http atau https

stdout

Plugin output stdout digunakan untuk menulis event output pada output standar antarmuka baris perintah. Ini adalah command prompt di windows dan terminal di UNIX. Plugin ini memiliki pengaturan berikut -

Nama Pengaturan Nilai Default Deskripsi
codec "polos" Ini digunakan untuk menyandikan data pencatatan keluaran sebelum mengirimkannya ke sumber tujuan.
pekerja 1 Ini digunakan untuk menentukan jumlah pekerja untuk output

statsd

Ini adalah daemon jaringan yang digunakan untuk mengirim data matriks melalui UDP ke layanan backend tujuan. Ini adalah command prompt di windows dan terminal di UNIX. Plugin ini memiliki pengaturan berikut -

Nama Pengaturan Nilai Default Deskripsi
codec "polos" Ini digunakan untuk menyandikan data pencatatan keluaran sebelum mengirimkannya ke sumber tujuan.
menghitung {} Ini digunakan untuk menentukan jumlah yang akan digunakan dalam metrik
pengurangan [] Ini digunakan untuk menentukan nama metrik pengurangan
tuan rumah “Localhost” Ini berisi alamat server statsd
kenaikan [] Ini digunakan untuk menentukan nama metrik kenaikan
Pelabuhan 8125 Ini berisi port server statsd
sample_rate 1 Ini digunakan untuk menentukan tingkat sampel metrik
pengirim "%{tuan rumah}" Ini menentukan nama pengirim
set {} Ini digunakan untuk menentukan metrik yang ditetapkan
waktu {} Ini digunakan untuk menentukan metrik waktu
pekerja 1 Ini digunakan untuk menentukan jumlah pekerja untuk output

Filter Plugin

Logstash mendukung berbagai plugin filter untuk mengurai dan mengubah log masukan menjadi format kueri yang lebih terstruktur dan mudah.

Sintaks untuk menggunakan plugin filter adalah sebagai berikut -

filter {
   Plugin name {
      Setting 1……
      Setting 2……..
   }
}

Anda dapat mengunduh plugin filter dengan menggunakan perintah berikut -

>logstash-plugin install logstash-filter-<plugin name>

Utilitas Logstash-plugin ada di folder bin dari direktori instalasi Logstash. Tabel berikut menjelaskan plugin keluaran yang ditawarkan oleh Logstash.

Sr.No. Nama & Deskripsi Plugin
1

aggregate

Plugin ini mengumpulkan atau menggabungkan data dari berbagai acara dengan jenis yang sama dan memprosesnya di acara terakhir

2

alter

Ini memungkinkan pengguna untuk mengubah bidang peristiwa log, yang tidak ditangani oleh filter mutasi

3

anonymize

Ini digunakan untuk mengganti nilai bidang dengan hash yang konsisten

4

cipher

Ini digunakan untuk mengenkripsi acara keluaran sebelum menyimpannya di sumber tujuan

5

clone

Ini digunakan untuk membuat duplikat dari acara keluaran di Logstash

6

collate

Ini menggabungkan acara dari log yang berbeda dengan waktu atau hitungannya

7

csv

Plugin ini mengurai data dari log input sesuai dengan pemisah

8

date

Ini mengurai tanggal dari bidang dalam acara dan mengaturnya sebagai stempel waktu untuk acara tersebut

9

dissect

Plugin ini membantu pengguna untuk mengekstrak field dari data yang tidak terstruktur dan memudahkan filter grok untuk mengurai dengan benar

10

drop

Ini digunakan untuk menghapus semua kejadian dengan tipe yang sama atau kesamaan lainnya

11

elapsed

Ini digunakan untuk menghitung waktu antara acara awal dan akhir

12

Elasticsearch

Ini digunakan untuk menyalin bidang peristiwa log sebelumnya yang ada di Elasticsearch ke yang saat ini di Logstash

13

extractnumbers

Ini digunakan untuk mengekstrak nomor dari string dalam peristiwa log

14

geoip

Ini menambahkan bidang dalam acara, yang berisi garis lintang dan bujur dari lokasi IP yang ada dalam acara log

15

grok

Ini adalah plugin filter yang umum digunakan untuk mengurai acara untuk mendapatkan bidang

16

i18n

Ini menghapus karakter khusus dari yang diajukan di acara log

17

json

Ini digunakan untuk membuat objek Json terstruktur dalam acara atau di bidang tertentu dari suatu acara

18

kv

Plugin ini berguna dalam memisahkan pasangan nilai kunci dalam data logging

19

metrics

Ini digunakan untuk menggabungkan metrik seperti menghitung durasi waktu di setiap peristiwa

20

multiline

Ini juga merupakan salah satu plugin filter yang umum digunakan, yang membantu pengguna dalam hal mengonversi data pencatatan multiline menjadi satu peristiwa.

21

mutate

Plugin ini digunakan untuk mengganti nama, menghapus, mengganti, dan memodifikasi kolom di acara Anda

22

range

Ini digunakan untuk memeriksa nilai numerik bidang dalam acara terhadap rentang yang diharapkan dan panjang string dalam rentang.

23

ruby

Ini digunakan untuk menjalankan kode Ruby arbitrer

24

sleep

Ini membuat Logstash tertidur selama jangka waktu tertentu

25

split

Ini digunakan untuk membagi bidang acara dan menempatkan semua nilai pemisahan di klon acara itu

26

xml

Ini digunakan untuk membuat acara dengan mengupas data XML yang ada di log

Plugin codec

Plugin Codec dapat menjadi bagian dari plugin input atau output. Plugin ini digunakan untuk mengubah atau memformat presentasi data logging. Logstash menawarkan beberapa Plugin codec dan itu adalah sebagai berikut -

Sr.No. Nama & Deskripsi Plugin
1

avro

Plugin ini menyandikan kejadian Logstash serial ke datum avro atau mendekode catatan avro ke kejadian Logstash

2

cloudfront

Plugin ini membaca data yang dikodekan dari AWS cloudfront

3

cloudtrail

Plugin ini digunakan untuk membaca data dari AWS cloudtrail

4

collectd

Ini membaca data dari protokol biner yang disebut dikumpulkan melalui UDP

5

compress_spooler

Ini digunakan untuk memampatkan peristiwa log di Logstash menjadi kumpulan yang dikumpulkan

6

dots

Ini digunakan pelacakan kinerja dengan menetapkan titik untuk setiap acara ke stdout

7

es_bulk

Ini digunakan untuk mengonversi data massal dari Elasticsearch menjadi peristiwa Logstash termasuk metadata Elasticsearch

8

graphite

Codec ini membaca data dari grafit menjadi peristiwa dan mengubah peristiwa tersebut menjadi catatan berformat grafit

9

gzip_lines

Plugin ini digunakan untuk menangani data yang dikodekan gzip

10

json

Ini digunakan untuk mengonversi satu elemen dalam larik Json menjadi acara Logstash tunggal

11

json_lines

Ini digunakan untuk menangani data Json dengan pembatas baris baru

12

line

Itu plugin akan membaca dan menulis acara dalam satu live, itu berarti setelah pembatas baris baru akan ada acara baru

13

multiline

Ini digunakan untuk mengubah data pencatatan multiline menjadi satu peristiwa

14

netflow

Plugin ini digunakan untuk mengonversi data nertflow v5 / v9 menjadi acara logstash

15

nmap

Ini mem-parsing data hasil nmap ke dalam format XML

16

plain

Ini membaca teks tanpa pembatas

17

rubydebug

Plugin ini akan menulis event Logstash keluaran menggunakan perpustakaan cetak Ruby yang mengagumkan

Bangun Plugin Anda Sendiri

Anda juga dapat membuat Plugin Anda sendiri di Logstash, yang menyesuaikan kebutuhan Anda. Utilitas Logstash-plugin digunakan untuk membuat Plugin kustom. Di sini, kami akan membuat plugin filter, yang akan menambahkan pesan khusus di acara.

Hasilkan Struktur Dasar

Seorang pengguna dapat membuat file yang diperlukan dengan menggunakan opsi generate dari utilitas logstash-plugin atau juga tersedia di GitHub.

>logstash-plugin generate --type filter --name myfilter --path c:/tpwork/logstash/lib

Sini, typePilihan yang digunakan untuk menentukan plugin adalah Input, Output atau Filter. Dalam contoh ini, kami membuat plugin filter bernamamyfilter. Opsi jalur digunakan untuk menentukan jalur, di mana Anda ingin direktori plugin Anda dibuat. Setelah menjalankan perintah yang disebutkan di atas, Anda akan melihat bahwa struktur direktori dibuat.

Kembangkan Plugin

Anda dapat menemukan file kode plugin di \lib\logstash\filtersfolder di direktori plugin. Ekstensi file akan menjadi.rb.

Dalam kasus kami, file kode terletak di dalam jalur berikut -

C:\tpwork\logstash\lib\logstash-filter-myfilter\lib\logstash\filters\myfilter.rb

Kami mengubah pesan menjadi - default ⇒ "Hai, Anda mempelajari ini di tutorialspoint.com" dan simpan file.

Pasang Plugin

Untuk menginstal plugin ini, Gemfile dari Logstash perlu dimodifikasi. Anda dapat menemukan file ini di direktori instalasi Logstash. Dalam kasus kami, itu akan masukC:\tpwork\logstash. Edit file ini menggunakan editor teks apa saja dan tambahkan teks berikut di dalamnya.

gem "logstash-filter-myfilter",:path => "C:/tpwork/logstash/lib/logstash-filter-myfilter"

Pada perintah di atas, kami menentukan nama plugin bersama dengan di mana kami dapat menemukannya untuk instalasi. Kemudian, jalankan utilitas Logstash-plugin untuk menginstal plugin ini.

>logstash-plugin install --no-verify

Menguji

Di sini, kami menambahkan myfilter di salah satu contoh sebelumnya -

logstash.conf

File konfigurasi Logstash ini berisi myfilter di bagian filter setelah plugin filter grok.

input {
   file {
      path => "C:/tpwork/logstash/bin/log/input1.log"
   } 
}
filter {
   grok {
      match => [
         "message", "%{LOGLEVEL:loglevel} - %{NOTSPACE:taskid} -
            %{NOTSPACE:logger} - %{WORD:label}( - %{INT:duration:int})?" ]
   }
   myfilter{}
}
output {
   file {
      path => "C:/tpwork/logstash/bin/log/output1.log"
      codec => rubydebug
   }
}

Run logstash

Kita dapat menjalankan Logstash dengan menggunakan perintah berikut.

>logstash –f logsatsh.conf

input.log

Blok kode berikut menunjukkan data log masukan.

INFO - 48566 - TRANSACTION_START - start

output.log

Blok kode berikut menunjukkan data log keluaran.

{
   "path" => "C:/tpwork/logstash/bin/log/input.log",
   "@timestamp" => 2017-01-07T06:25:25.484Z,
   "loglevel" => "INFO",
   "logger" => "TRANSACTION_END",
   "@version" => "1",
   "host" => "Dell-PC",
   "label" => "end",
   "message" => "Hi, You are learning this on tutorialspoint.com",
   "taskid" => "48566",
   "tags" => []
}

Publikasikan di Logstash

Pengembang juga dapat menerbitkan plugin kustomnya ke Logstash dengan menguploadnya di github dan mengikuti langkah standar yang ditentukan oleh Elasticsearch Company.

Silakan lihat URL berikut untuk informasi lebih lanjut tentang penerbitan -

https://www.elastic.co/guide/en/logstash/current/contributing-to-logstash.html

Logstash menawarkan API untuk memantau kinerjanya. API pemantauan ini mengekstrak metrik waktu proses tentang Logstash.

API Info Node

API ini digunakan untuk mendapatkan informasi tentang node Logstash. Ini mengembalikan informasi OS, pipeline Logstash, dan JVM dalam format JSON.

Anda dapat mengekstrak informasi dengan mengirimkan file get meminta untuk Logstash menggunakan URL berikut -

GET http://localhost:9600/_node?pretty

Tanggapan

Berikut akan menjadi respon dari Node Info API.

{
   "host" : "Dell-PC",
   "version" : "5.0.1",
   "http_address" : "127.0.0.1:9600",
   
   "pipeline" : {
      "workers" : 4,
      "batch_size" : 125,
      "batch_delay" : 5,
      "config_reload_automatic" : false,
      "config_reload_interval" : 3
   },
   "os" : {
      "name" : "Windows 7",
      "arch" : "x86",
      "version" : "6.1",
      "available_processors" : 4
   },
   "jvm" : {
      "pid" : 312,
      "version" : "1.8.0_111",
      "vm_name" : "Java HotSpot(TM) Client VM",
      "vm_version" : "1.8.0_111",
      "vm_vendor" : "Oracle Corporation",
      "start_time_in_millis" : 1483770315412,
      
      "mem" : {
         "heap_init_in_bytes" : 16777216,
         "heap_max_in_bytes" : 1046937600,
         "non_heap_init_in_bytes" : 163840,
         "non_heap_max_in_bytes" : 0
      },
      "gc_collectors" : [ "ParNew", "ConcurrentMarkSweep" ]
   }
}

Anda juga bisa mendapatkan informasi spesifik tentang Pipeline, OS, dan JVM, hanya dengan menambahkan namanya di URL.

GET http://localhost:9600/_node/os?pretty
GET http://localhost:9600/_node/pipeline?pretty
GET http://localhost:9600/_node/jvm?pretty

API Info Plugin

API ini digunakan untuk mendapatkan informasi tentang plugin yang diinstal di Logstash. Anda dapat mengambil informasi ini dengan mengirimkan permintaan get ke URL yang disebutkan di bawah -

GET http://localhost:9600/_node/plugins?pretty

Tanggapan

Berikut ini adalah tanggapan dari API Info Plugin.

{
   "host" : "Dell-PC",
   "version" : "5.0.1",
   "http_address" : "127.0.0.1:9600",
   "total" : 95,
   "plugins" : [ {
      "name" : "logstash-codec-collectd",
      "version" : "3.0.2"
   },
   {
      "name" : "logstash-codec-dots",
      "version" : "3.0.2"
   },
   {
      "name" : "logstash-codec-edn",
      "version" : "3.0.2"
   },
   {
      "name" : "logstash-codec-edn_lines",
      "version" : "3.0.2"
   },
   ............
}

Node Stats API

API ini digunakan untuk mengekstrak statistik Logstash (Memory, Process, JVM, Pipeline) di objek JSON. Anda dapat mengambil informasi ini dengan mengirimkan permintaan get ke URL yang disebutkan di bawah -

GET http://localhost:9600/_node/stats/?pretty
GET http://localhost:9600/_node/stats/process?pretty
GET http://localhost:9600/_node/stats/jvm?pretty
GET http://localhost:9600/_node/stats/pipeline?pretty

Hot Threads API

API ini mengambil informasi tentang hot thread di Logstash. Hot thread adalah java threads, yang memiliki penggunaan CPU tinggi dan berjalan lebih lama dari waktu eksekusi normal. Anda dapat mengambil informasi ini dengan mengirimkan permintaan get ke URL yang disebutkan di bawah -

GET http://localhost:9600/_node/hot_threads?pretty

Seorang pengguna dapat menggunakan URL berikut untuk mendapatkan respon dalam bentuk yang lebih mudah dibaca.

GET http://localhost:9600/_node/hot_threads?human = true

Pada bab ini, kita akan membahas aspek keamanan dan pemantauan Logstash.

Pemantauan

Logstash adalah alat yang sangat bagus untuk memantau server dan layanan di lingkungan produksi. Aplikasi dalam lingkungan produksi menghasilkan berbagai jenis data log seperti Log akses, Log Kesalahan, dll. Logstash dapat menghitung atau menganalisis jumlah kesalahan, akses, atau peristiwa lain menggunakan plugin filter. Analisis dan penghitungan ini dapat digunakan untuk memantau berbagai server dan layanan mereka.

Logstash menawarkan plugin seperti HTTP Polleruntuk memantau pemantauan status situs web. Di sini, kami memantau situs web bernamamysite dihosting di Server Apache Tomcat lokal.

logstash.conf

Dalam file konfigurasi ini, plugin http_poller digunakan untuk mencapai situs yang ditentukan dalam plugin setelah interval waktu yang ditentukan dalam pengaturan interval. Akhirnya, ini menulis status situs ke keluaran standar.

input {
   http_poller {
      urls => {
         site => "http://localhost:8080/mysite"
      }
      request_timeout => 20
      interval => 30
      metadata_target => "http_poller_metadata"
   }
}
output {
   if [http_poller_metadata][code] == 200 {
      stdout {
         codec => line{format => "%{http_poller_metadata[response_message]}"}
      }
   }
   if [http_poller_metadata][code] != 200 {
      stdout {
         codec => line{format => "down"}
      }
   }
}

Jalankan logstash

Kita bisa menjalankan Logstash dengan perintah berikut.

>logstash –f logstash.conf

stdout

Jika situsnya sudah habis, maka hasilnya akan -

Ok

Jika kita menghentikan situs dengan menggunakan Manager App dari Tomcat, output akan berubah menjadi -

down

Keamanan

Logstash menyediakan banyak fitur untuk komunikasi yang aman dengan sistem eksternal dan mendukung mekanisme otentikasi. Semua plugin Logstash mendukung otentikasi dan enkripsi melalui koneksi HTTP.

Keamanan dengan protokol HTTP

Ada pengaturan seperti pengguna dan kata sandi untuk tujuan otentikasi di berbagai plugin yang ditawarkan oleh Logstash seperti di plugin Elasticsearch.

elasticsearch {
   user => <username>
   password => <password>
}

Otentikasi lainnya adalah PKI (public key infrastructure)untuk Elasticsearch. Pengembang perlu menentukan dua pengaturan di plugin keluaran Elasticsearch untuk mengaktifkan otentikasi PKI.

elasticsearch {
   keystore => <string_value>
   keystore_password => <password>
}

Dalam protokol HTTPS, pengembang dapat menggunakan sertifikat otoritas untuk SSL / TLS.

elasticsearch {
   ssl => true
   cacert => <path to .pem file>
}

Keamanan dengan Transport Protocol

To use the transport protocol with Elasticsearch, users need to set protocol setting to transport. This avoids un-marshalling of JSON objects and leads to more efficiency.

The basic authentication is same as performed in http protocol in Elasticsearch output protocol.

elasticsearch {
   protocol => “transport”
   user => <username>
   password => <password>
}

The PKI authentication also needs the SSL sets to be true with other settings in the Elasticsearch output protocol −

elasticsearch {
   protocol => “transport”
   ssl => true
   keystore => <string_value>
   keystore_password => <password>
}

Finally, the SSL security requires a little with more settings than other security methods in communication.

elasticsearch {
   ssl => true
   ssl => true
   keystore => <string_value>
   keystore_password => <password>
   truststore => 
      
        truststore_password => <password> } 
      

Other Security Benefits from Logstash

Logstash can help input system sources to prevent against attacks like denial of service attacks. The monitoring of logs and analyzing the different events in those logs can help system administrators to check the variation in the incoming connections and errors. These analyses can help to see if the attack is happening or going to happen on the servers.

Other products of the Elasticsearch Company such as x-pack and filebeat provides some functionality to communicate securely with Logstash.