萬能資料收集器 Fluentd - 每天5分鐘玩轉 Docker 容器技術(91)
萬能資料收集器 Fluentd - 每天5分鐘玩轉 Docker 容器技術(91)
原創 CloudMan CloudMan 2017-11-08
第91篇
萬能資料收集器 Fluentd
前面的 ELK 中我們是用 Filebeat 收集 Docker 容器日誌,利用的是 Docker 預設的 logging driver json-file
,本節我們將使用 fluentd
來收集容器的日誌。
Fluentd 是一個開源的資料收集器,它目前有超過 500 種的 plugin,可以連線各種資料來源和資料輸出元件。在接下來的實踐中,Fluentd 會負責收集容器日誌,然後傳送給 Elasticsearch。日誌處理流程如下:
這裡我們用 Filebeat 將 Fluentd 收集到的日誌轉發給 Elasticsearch。這當然不是唯一的方案,Fluentd 有一個 plugin fluent-plugin-elasticsearch
可以直接將日誌傳送給 Elasticsearch。條條道路通羅馬,開源世界給予了我們多種可能性,可以根據需要選擇合適的方案。
安裝 Fluentd
同樣的,最高效的實踐方式是執行一個 fluentd 容器。
docker run -d -p 24224:24224 -p 24224:24224/udp -v /data:/fluentd/log fluent/fluentd
fluentd 會在 TCP/UDP 埠 24224 上接收日誌資料,日誌將儲存在 Host 的 /data
目錄中。
重新配置 Filebeat
編輯 Filebeat 的配置檔案 /etc/filebeat/filebeat.yml
,將 /data
新增到監控路徑中。
重啟 Filebeat。
systemctl restart filebeat.service
監控容器日誌
啟動測試容器。
docker run -d \
--log-driver=fluentd \
--log-opt fluentd-address=localhost:24224 \
--log-opt tag="log-test-container-A" \
busybox sh -c 'while true; do echo "This is a log message from container A"; sleep 10; done;'
docker run -d \
--log-driver=fluentd \
--log-opt fluentd-address=localhost:24224 \
--log-opt tag="log-test-container-B" \
busybox sh -c 'while true; do echo "This is a log message from container B"; sleep 10; done;'
--log-driver=fluentd
告訴 Docker 使用 Fluentd 的 logging driver。
--log-opt fluentd-address=localhost:24224
將容器日誌傳送到 Fluentd 的資料接收埠。
--log-opt tag="log-test-container-A"
和 --log-opt tag="log-test-container-B"
在日誌中新增一個可選的 tag,用於區分不同的容器。
容器啟動後,Kibana 很快就能夠查詢到容器的日誌。
Fluentd 我們們就討論到這裡,下一節開始學習 Graylog。
書籍:
1.《每天5分鐘玩轉Docker容器技術》
https://item.jd.com/16936307278.html(點選“閱讀原文”直達)
2.《每天5分鐘玩轉OpenStack》
https://item.jd.com/12086376.html
相關文章
- 每天5分鐘玩轉Docker容器技術(二)Docker
- 【Docker】(9)---每天5分鐘玩轉 Docker 容器技術之映象Docker
- Kubernetes Dashboard - 每天5分鐘玩轉 Docker 容器技術(173)Docker
- 回收 PV - 每天5分鐘玩轉 Docker 容器技術(152)Docker
- Network Policy - 每天5分鐘玩轉 Docker 容器技術(171)Docker
- Prometheus Operator - 每天5分鐘玩轉 Docker 容器技術(177)PrometheusDocker
- PV & PVC - 每天5分鐘玩轉 Docker 容器技術(150)Docker
- 外部 Storage Provider - 每天5分鐘玩轉 Docker 容器技術(149)IDEDocker
- Liveness 探測 - 每天5分鐘玩轉 Docker 容器技術(143)Docker
- Helm 架構 - 每天5分鐘玩轉 Docker 容器技術(161)架構Docker
- 再次實踐 MySQL chart - 每天5分鐘玩轉 Docker 容器技術MySqlDocker
- 什麼是 stack?- 每天5分鐘玩轉 Docker 容器技術(111)Docker
- MySQL 使用 PV 和 PVC - 每天5分鐘玩轉 Docker 容器技術(154)MySqlDocker
- 通過 Service 訪問 Pod - 每天5分鐘玩轉 Docker 容器技術(136)Docker
- Kubernetes 叢集日誌管理 - 每天5分鐘玩轉 Docker 容器技術(180)Docker
- ELK 完整部署和使用 - 每天5分鐘玩轉 Docker 容器技術(90)Docker
- 部署 Graylog 日誌系統 - 每天5分鐘玩轉 Docker 容器技術(92)Docker
- 如何用 Graylog 管理日誌? - 每天5分鐘玩轉 Docker 容器技術(93)Docker
- 用 Weave Scope 監控叢集 - 每天5分鐘玩轉 Docker 容器技術(175)Docker
- 用 k8s 管理機密資訊 - 每天5分鐘玩轉 Docker 容器技術(155)K8SDocker
- 在滾動更新中使用 Health Check - 每天5分鐘玩轉 Docker 容器技術(146)Docker
- 容器技術之Docker資料卷Docker
- 容器技術之Docker資源限制Docker
- Docker--容器技術Docker
- docker容器技術原理Docker
- 玩轉docker之自定義PHP容器DockerPHP
- 探秘Kubernetes:在本地環境中玩轉容器技術
- Docker技術( 容器虛擬化技術 )Docker
- Docker容器技術與Docker介紹Docker
- 容器技術之Docker映象Docker
- 容器技術之Docker-swarmDockerSwarm
- 容器技術之Docker網路Docker
- 容器技術和Docker介紹Docker
- Docker容器與虛擬化技術:OpenEuler 部署 docker容器應用Docker
- 1.01 容器技術和docker簡介Docker
- 技術選型之Docker容器引擎Docker
- Docker容器化技術初體驗Docker
- 容器技術|Docker三劍客之docker-swarmDockerSwarm