drupal and logstash centralised logging
play

Drupal and Logstash: centralised logging Marji Cermak Marji Cermak - PowerPoint PPT Presentation

Drupal and Logstash: centralised logging Marji Cermak Marji Cermak Systems Engineer at Morpht @cermakm The BELK stack Marji Cermak @cermakm To get you an idea Customer says they get randomly redirected while browsing their website


  1. Drupal and Logstash: centralised logging Marji Cermak

  2. Marji Cermak Systems Engineer at Morpht @cermakm The BELK stack Marji Cermak @cermakm

  3. To get you an idea Customer says they get randomly redirected while browsing their website… The BELK stack The BELK stack Marji Cermak @cermakm Marji Cermak @cermakm

  4. The old school $ grep ' 30[1234] ' /var/logs/apache2/access.log | grep -v baidu | grep -v Googlebot 173.230.156.8 - - [04/Sep/2015:06:10:10 +0000] "GET /morpht HTTP/1.0" 301 26 "-" "Mozilla/5.0 (pc-x86_64-linux-gnu)" 192.3.83.5 - - [04/Sep/2015:06:10:22 +0000] "GET /?q=node/add HTTP/1.0" 301 26 "http://morpht.com/" "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_10_1) AppleWebKit/600.2.5 (KHTML, like Gecko) Version/8.0.2 Safari/600.2.5" 192.3.83.5 - - [04/Sep/2015:06:10:23 +0000] "GET /?q=user/register HTTP/1.0" 301 26 "http://morpht.com/node/add" "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_10_1) AppleWebKit/600.2.5 (KHTML, like Gecko) Version/8.0.2 Safari/600. 2.5" The BELK stack Marji Cermak @cermakm

  5. The new school logtype: "apache" AND website: "mysite" AND server_response: [301 TO 304] The BELK stack Marji Cermak @cermakm

  6. The BELK stack Marji Cermak @cermakm

  7. The BELK stack Marji Cermak @cermakm

  8. The BELK stack Marji Cermak @cermakm

  9. What have we just seen? ✤ These were interactions with Kibana. ✤ We executed a query, created several visualisations. ✤ But what else is under the hood? ✤ And where is logstash? The BELK stack Marji Cermak @cermakm

  10. The BELK stack Marji Cermak @cermakm Source: "Family of Elk on Grassland" (CC BY-NC-ND 2.0) by Princess-Lodges

  11. The ELK stack E lasticsearch L ogstash K ibana The BELK stack Marji Cermak @cermakm

  12. Source: https://www.elastic.co/blog/heya-elastic-stack-and-x-pack The BELK stack Marji Cermak @cermakm

  13. The BELK stack B eats E lasticsearch L ogstash K ibana The BELK stack Marji Cermak @cermakm

  14. The elastic stack The BELK stack Marji Cermak @cermakm

  15. The elastic stack The BELK stack Marji Cermak @cermakm

  16. The stack’s goal ✤ Take data from any source, any format, The BELK stack Marji Cermak @cermakm

  17. The stack’s goal ✤ Take data from any source, any format, ✤ process, transform and enrich it, The BELK stack Marji Cermak @cermakm

  18. The stack’s goal ✤ Take data from any source, any format, ✤ process, transform and enrich it, ✤ store it, The BELK stack Marji Cermak @cermakm

  19. The stack’s goal ✤ Take data from any source, any format, ✤ process, transform and enrich it, ✤ store it, ✤ so you can search, analyse and visualise it in real time. The BELK stack Marji Cermak @cermakm

  20. The four components The BELK stack Marji Cermak @cermakm

  21. E lasticsearch ✤ open source, full-text search analytic engine ✤ distributed, High Availability ✤ designed for horizontal scalability and reliability ✤ based on Apache Lucene (like Apache solr) ✤ written in Java The BELK stack Marji Cermak @cermakm

  22. L ogstash ✤ tool to collect, process, and forward events and log messages ✤ data collection, enrichment and transformation pipeline ✤ configurable input and output plugins ✤ e.g. logfile, MS windows eventlog, socket, Syslog, redis, salesforce, Drupal DBLog The BELK stack Marji Cermak @cermakm

  23. Source: https://www.elastic.co/guide/en/logstash/current/introduction.html The BELK stack Marji Cermak @cermakm

  24. L ogstash dozens of input plugins Beats ✤ file ✤ TCP, UDP, websocket ✤ syslog ✤ redis ✤ MS windows eventlog ✤ drupal_dblog ✤ The BELK stack Marji Cermak @cermakm

  25. L ogstash dozens of input plugins file ✤ TCP, UDP, websocket ✤ dozens of output plugins syslog ✤ redis, SQS ✤ graphite, influxdb ✤ nagios, zabbix ✤ jira, redmine ✤ s3 ✤ elasticsearch ✤ The BELK stack Marji Cermak @cermakm

  26. L ogstash dozens of input plugins grok ✤ mutate ✤ dozens of output plugins drop ✤ date ✤ dozens of filter plugins geoip ✤ The BELK stack Marji Cermak @cermakm

  27. K ibana ✤ open source data visualisation platform ✤ allows to interact with data through powerful graphics ✤ brings data to life with visuals The BELK stack Marji Cermak @cermakm

  28. B eats ✤ Open source data shippers ✤ Lightweight ✤ e.g. network packets, log files The BELK stack Marji Cermak @cermakm

  29. The BELK flow Elasticsearch Kibana The BELK stack Marji Cermak @cermakm

  30. The BELK flow Data Source Elasticsearch Data Source Kibana Data Source The BELK stack Marji Cermak @cermakm

  31. The BELK flow Data Source Elasticsearch Logstash Data B Source Kibana Data Source The BELK stack Marji Cermak @cermakm

  32. The BELK flow Data B Source Elasticsearch Logstash Data B Source Kibana Data Source The BELK stack Marji Cermak @cermakm

  33. The BELK flow Data B Logstash Source Elasticsearch Input Filter Output plugin plugin plugin Data B Source Kibana Data Source The BELK stack Marji Cermak @cermakm

  34. The BELK stack Marji Cermak @cermakm

  35. Docker Docker is an open platform for developers and sysadmins to build, ship, and run distributed applications. The BELK stack Marji Cermak @cermakm

  36. Docker Docker is a tool that can package an application and its dependencies in a virtual container that can run on any Linux server. The BELK stack Marji Cermak @cermakm

  37. Docker Logstash Hello World! docker run -it --rm logstash:2.3 logstash -e ' input { stdin { } } output { stdout { codec => rubydebug} }' 107.187.90.29 - - [05/Sep/2015:01:14:02 +0000] "GET / HTTP/1.1" 200 453 "-" "curl/7.21.0" The BELK stack Marji Cermak @cermakm

  38. Docker Logstash Hello World, apache! docker run -it --rm logstash:2.3 logstash -e ' input { stdin { } } filter { grok { match => [ "message", "%{COMBINEDAPACHELOG}"]}} output { stdout { codec => rubydebug } }' 107.187.90.29 - - [05/Sep/2015:01:14:02 +0000] "GET / HTTP/1.1" 200 453 "-" "curl/7.21.0" The BELK stack Marji Cermak @cermakm

  39. Now let’s try this Data B Logstash Source Elasticsearch Input Filter Output plugin plugin plugin Data B Source Kibana Data Source The BELK stack Marji Cermak @cermakm

  40. Docker ELK Let’s run 3 docker images: $ docker run --name myes -d elasticsearch:2.3 $ docker run --name mykibana --link myes:elasticsearch -p 5601:5601 -d kibana:4.5 $ docker run --rm --link myes:elasticsearch -v ${PWD}/config-dir:/config-dir -v ${PWD}/source:/source logstash:2.3 logstash -f /config-dir The BELK stack Marji Cermak @cermakm

  41. Is it going to work this time? :) Local demo The BELK stack Marji Cermak @cermakm

  42. What we have just seen (In case it worked :) ✤ Logstash input reading lines from apache logfile The BELK stack Marji Cermak @cermakm

  43. What we have just seen (In case it worked :) ✤ Logstash input reading lines from apache logfile ✤ Logstash filter matching them with COMBINEDAPACHELOG pattern The BELK stack Marji Cermak @cermakm

  44. What we have just seen (In case it worked :) ✤ Logstash input reading lines from apache logfile ✤ Logstash filter matching them with COMBINEDAPACHELOG pattern ✤ Logstash output storing parsed lines to Elasticsearch The BELK stack Marji Cermak @cermakm

  45. What we have just seen (In case it worked :) ✤ Logstash input reading lines from apache logfile ✤ Logstash filter matching them with COMBINEDAPACHELOG pattern ✤ Logstash output storing parsed lines to Elasticsearch ✤ Kibana querying the data from Elasticsearch , visualising them The BELK stack Marji Cermak @cermakm

  46. L ogstash input { dozens of input plugins file { path => "/source/access.log" type => "apache" dozens of output plugins start_position => "beginning" } } output { elasticsearch { hosts => ["myes"] } stdout { codec => rubydebug } } The BELK stack Marji Cermak @cermakm

  47. L ogstash filter { dozens of input plugins if [type] == "apache" { grok { match => [ dozens of output plugins "message", "%{COMBINEDAPACHELOG}" ] } dozens of filter plugins } } The BELK stack Marji Cermak @cermakm

  48. L ogstash filter { dozens of input plugins if [type] == "apache" { grok { match => [ dozens of output plugins "message", "%{COMBINEDAPACHELOG}" ] } dozens of filter plugins geoip { source => "clientip" } } } The BELK stack Marji Cermak @cermakm

  49. L ogstash filter { dozens of input plugins if [type] == "apache" { grok { match => [ dozens of output plugins "message", "%{COMBINEDAPACHELOG}" ] } dozens of filter plugins geoip { source => "clientip" } date { locale => "en" match => [ "timestamp", "dd/MMM/yyyy:HH:mm:ss Z" ] } } } The BELK stack Marji Cermak @cermakm

Download Presentation
Download Policy: The content available on the website is offered to you 'AS IS' for your personal information and use only. It cannot be commercialized, licensed, or distributed on other websites without prior consent from the author. To download a presentation, simply click this link. If you encounter any difficulties during the download process, it's possible that the publisher has removed the file from their server.

Recommend


More recommend