什麼是 ELK?

ELK 介紹

ELK 介紹

  • 什麼是 ELK?
  • ELK 用在哪裡 ?
  • Elasticsearch Cluster 介紹
  • Kibana 演示

ELK 安裝與設定

  • 手動安裝
  • logstash 設定 (grok)
  • docker 版安裝與使用方法
  • ES Cluster 安裝

ELK 使用案例

  • 系統效能監控
  • 應用程式除錯監控
  • 網路資安監控
  • 客服也能用

ELK 程式設計

  • Dev Tools
  • curl
  • python
  • Timelion

課程總覽

#DevOps = ~CA(L)MS

C(ulture) - 文化

A(utomation) - 自動化

L(ean) - 敏捷

M(etric) - 監控

S(haring) - 分享 

M(onitoring & Measuring)

- 監控與量測

  • Metric - CPU, Memory, Disk, Networking
  • Logs - Application Logs, System Logs...
  • SNMP - devices, switches...
  • Security - authd.log, auth.log, fail2ban.log
  • IoT - any data format with timestamps

傳統的 monitoring 工具

傳統的 website 架構

傳統的 website 軟體

現在的 website 架構

現在的 website 軟體

未來的 docker 世界

ELK = E(lasticsearch)

+ L(ogstash)

+ K(ibana)    

<- this is an

elk as well    

2012 年開始 Elasticsearch

漸漸被廣泛使用

3 年前開始 Elasticsearch

變成首選

7 年後的今天 Elasticsearch

遙遙領先 

ELK 用在哪裡 ?

初期

  • 開發者除錯
  • 全文檢索
  • 大數據資料收集

現在

  • 資安監控
  • AI 資料來源與分析
  • logs 資料整合
  • IoT 資料視覺化
  • APM 系統效能監測

未來

  • ???
  • 功能太強, 用途太廣, 實在無法預期還能怎麼用

以開發者除錯為例

 開發團隊這樣用 ELK

 docker 版 ELK 這樣用

用 docker

大量部署

ELK 最簡單的安裝架構

... 多台

ELK 最簡單的安裝架構

... 多台

以 IIS Web Server 為例

 

ELK log 的資料流

Redis 當 buffer

logstash

redis

Logstash config

logstash config 檔的位置

/opt/logstash/bin/logstash -f turboteam-iislog-cell.conf
/opt/logstash/bin/logstash -f turboteam-iislog-cell.conf --configtest

Configuration OK

Logstash config 範例

Elasticsearch Cluster 架構

  • indexing

  • 全文檢索

  • 查詢主機

  • 分散式資料庫

  • cluster 架構

  • 自動 shards

  • 自動 replicas

  • REST API

4 nodes 的實體架構

資料複製與 sharding

elasitcsearch 設定檔

修改 /etc/elasticsearch/elasticsearch.yml

 

sudo service elasticsearch restart

Elasticsearch Plugins

- HQ, head, BigDesk, SQL ...

安裝 plugin 指令:

cd /usr/share/elasticsearch

 

sudo bin/plugin install royrusso/elasticsearch-HQ

sudo bin/plugin install mobz/elasticsearch-head

sudo bin/plugin install lukas-vlcek/bigdesk

 

http://10.1.100.121:9200/_plugin/hq

http://10.1.100.121:9200/_plugin/head/

Kibana 做資料視覺化的 GUI

  • Web GUI

  • 資料視覺化

  • auto refresh

  • 容易查詢

  • 容易編輯

  • Dashboard

  • 輸出入 JSON

  • Plugins

Dashboard

自己做自己喜歡的畫面

Q & A

ELK 介紹

By Ming-der Wang

ELK 介紹

  • 1,116